From 5c6efe2a7c74a7ac17ebdda523f1252a31241c6d Mon Sep 17 00:00:00 2001 From: Scott McKay Date: Mon, 26 Feb 2024 15:10:34 +1000 Subject: [PATCH] Handle all retries being used the same way as if subprocess.run was used with check=True --- .../github/apple/test_apple_packages.py | 36 +++++++++++-------- 1 file changed, 21 insertions(+), 15 deletions(-) diff --git a/tools/ci_build/github/apple/test_apple_packages.py b/tools/ci_build/github/apple/test_apple_packages.py index 3933f14b07008..3c0df994ffd3d 100644 --- a/tools/ci_build/github/apple/test_apple_packages.py +++ b/tools/ci_build/github/apple/test_apple_packages.py @@ -134,20 +134,23 @@ def _test_apple_packages(args): # Add a couple of retries if we get this error: # ios_package_testUITests-Runner Failed to initialize for UI testing: # Error Domain=com.apple.dt.XCTest.XCTFuture Code=1000 "Timed out while loading Accessibility." - retries = 3 - while retries > 0: + attempts = 0 + cmd = [ + "xcrun", + "xcodebuild", + "test", + "-workspace", + "./apple_package_test.xcworkspace", + "-scheme", + "ios_package_test", + "-destination", + f"platform=iOS Simulator,id={simulator_device_info['device_udid']}", + ] + + while True: + attempts += 1 completed_process = subprocess.run( - [ - "xcrun", - "xcodebuild", - "test", - "-workspace", - "./apple_package_test.xcworkspace", - "-scheme", - "ios_package_test", - "-destination", - f"platform=iOS Simulator,id={simulator_device_info['device_udid']}", - ], + cmd, shell=False, capture_output=True, check=False, @@ -164,10 +167,13 @@ def _test_apple_packages(args): print(completed_process.stderr) print("---") - if "Timed out while loading Accessibility" in completed_process.stderr: - retries -= 1 + if "Timed out while loading Accessibility" in completed_process.stderr and attempts < 3: continue + raise subprocess.CalledProcessError( + completed_process.returncode, " ".join(cmd), completed_process.stdout, completed_process.stderr + ) + break if PackageVariant[args.variant] != PackageVariant.Mobile and not args.skip_macos_test: