From 3a48438a0f65e7ea93594916b7d5d9fc329e848a Mon Sep 17 00:00:00 2001 From: lo-simon Date: Wed, 4 Oct 2023 17:59:16 +0100 Subject: [PATCH] In AUTH mode macOS Registry could take up to 20+ seconds for obtaining the Authorization Server Public Keys. --- .github/workflows/build-test.yml | 4 ++++ .github/workflows/src/amwa-test.yml | 2 ++ 2 files changed, 6 insertions(+) diff --git a/.github/workflows/build-test.yml b/.github/workflows/build-test.yml index 333afe093..92ec565bf 100644 --- a/.github/workflows/build-test.yml +++ b/.github/workflows/build-test.yml @@ -420,6 +420,8 @@ jobs: mv nmostesting/GenericTest.py nmostesting/GenericTest.py.old printf 'import socket\nold_getaddrinfo = socket.getaddrinfo\ndef new_getaddrinfo(host, port, family=0, type=0, proto=0, flags=0):\n return old_getaddrinfo(host, port, socket.AF_INET, type, proto, flags)\nsocket.getaddrinfo = new_getaddrinfo\n' > nmostesting/GenericTest.py cat nmostesting/GenericTest.py.old >> nmostesting/GenericTest.py + # in AUTH mode macos could take up to 20+ seconds for obtaining the Authorization Server Public Keys + printf '\n\ndef run_noninteractive_tests_with_delay(args):\n endpoints = []\n for i in range(len(args.host)):\n if args.host[i] == "null":\n args.host[i] = None\n if args.port[i] == 0:\n args.port[i] = None\n if args.version[i] == "null":\n args.version[i] = None\n selector = None\n if len(args.selector) == len(args.host) and args.selector[i] != "null":\n selector = args.selector[i]\n endpoints.append(\n {\n "host": args.host[i],\n "port": args.port[i],\n "version": args.version[i],\n "selector": selector,\n }\n )\n try:\n # in AUTH mode macOS could take up to 20+ seconds for obtaining the Authorization Server Public Keys\n if CONFIG.ENABLE_AUTH:\n time.sleep(30)\n results = run_tests(args.suite, endpoints, [args.selection])\n if args.output:\n exit_code = write_test_results(results, endpoints, args)\n else:\n exit_code = print_test_results(results, endpoints, args)\n except Exception as e:\n print(" * ERROR: {}".format(str(e)))\n exit_code = ExitCodes.ERROR\n return exit_code\n\n\nrun_noninteractive_tests = run_noninteractive_tests_with_delay\n' >> nmostesting/NMOSTesting.py fi if [[ "${{ runner.os }}" == "Linux" && "${{ matrix.use_conan }}" == "false" ]]; then @@ -954,6 +956,8 @@ jobs: mv nmostesting/GenericTest.py nmostesting/GenericTest.py.old printf 'import socket\nold_getaddrinfo = socket.getaddrinfo\ndef new_getaddrinfo(host, port, family=0, type=0, proto=0, flags=0):\n return old_getaddrinfo(host, port, socket.AF_INET, type, proto, flags)\nsocket.getaddrinfo = new_getaddrinfo\n' > nmostesting/GenericTest.py cat nmostesting/GenericTest.py.old >> nmostesting/GenericTest.py + # in AUTH mode macos could take up to 20+ seconds for obtaining the Authorization Server Public Keys + printf '\n\ndef run_noninteractive_tests_with_delay(args):\n endpoints = []\n for i in range(len(args.host)):\n if args.host[i] == "null":\n args.host[i] = None\n if args.port[i] == 0:\n args.port[i] = None\n if args.version[i] == "null":\n args.version[i] = None\n selector = None\n if len(args.selector) == len(args.host) and args.selector[i] != "null":\n selector = args.selector[i]\n endpoints.append(\n {\n "host": args.host[i],\n "port": args.port[i],\n "version": args.version[i],\n "selector": selector,\n }\n )\n try:\n # in AUTH mode macOS could take up to 20+ seconds for obtaining the Authorization Server Public Keys\n if CONFIG.ENABLE_AUTH:\n time.sleep(30)\n results = run_tests(args.suite, endpoints, [args.selection])\n if args.output:\n exit_code = write_test_results(results, endpoints, args)\n else:\n exit_code = print_test_results(results, endpoints, args)\n except Exception as e:\n print(" * ERROR: {}".format(str(e)))\n exit_code = ExitCodes.ERROR\n return exit_code\n\n\nrun_noninteractive_tests = run_noninteractive_tests_with_delay\n' >> nmostesting/NMOSTesting.py fi if [[ "${{ runner.os }}" == "Linux" && "${{ matrix.use_conan }}" == "false" ]]; then diff --git a/.github/workflows/src/amwa-test.yml b/.github/workflows/src/amwa-test.yml index 7e91ff390..165f446fa 100644 --- a/.github/workflows/src/amwa-test.yml +++ b/.github/workflows/src/amwa-test.yml @@ -95,6 +95,8 @@ mv nmostesting/GenericTest.py nmostesting/GenericTest.py.old printf 'import socket\nold_getaddrinfo = socket.getaddrinfo\ndef new_getaddrinfo(host, port, family=0, type=0, proto=0, flags=0):\n return old_getaddrinfo(host, port, socket.AF_INET, type, proto, flags)\nsocket.getaddrinfo = new_getaddrinfo\n' > nmostesting/GenericTest.py cat nmostesting/GenericTest.py.old >> nmostesting/GenericTest.py + # in AUTH mode macos could take up to 20+ seconds for obtaining the Authorization Server Public Keys + printf '\n\ndef run_noninteractive_tests_with_delay(args):\n endpoints = []\n for i in range(len(args.host)):\n if args.host[i] == "null":\n args.host[i] = None\n if args.port[i] == 0:\n args.port[i] = None\n if args.version[i] == "null":\n args.version[i] = None\n selector = None\n if len(args.selector) == len(args.host) and args.selector[i] != "null":\n selector = args.selector[i]\n endpoints.append(\n {\n "host": args.host[i],\n "port": args.port[i],\n "version": args.version[i],\n "selector": selector,\n }\n )\n try:\n # in AUTH mode macOS could take up to 20+ seconds for obtaining the Authorization Server Public Keys\n if CONFIG.ENABLE_AUTH:\n time.sleep(30)\n results = run_tests(args.suite, endpoints, [args.selection])\n if args.output:\n exit_code = write_test_results(results, endpoints, args)\n else:\n exit_code = print_test_results(results, endpoints, args)\n except Exception as e:\n print(" * ERROR: {}".format(str(e)))\n exit_code = ExitCodes.ERROR\n return exit_code\n\n\nrun_noninteractive_tests = run_noninteractive_tests_with_delay\n' >> nmostesting/NMOSTesting.py fi if [[ "${{ runner.os }}" == "Linux" && "${{ matrix.use_conan }}" == "false" ]]; then