-
Notifications
You must be signed in to change notification settings - Fork 277
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Update hardcoded xHarness version and adb call flow #4635
Update hardcoded xHarness version and adb call flow #4635
Conversation
Mostly functionality changes Add some more logs and try a copilot solution to the hanging. Add some more logs and try a copilot solution to the hanging. Forcefully close the proc.stdout fd. Update some versions. Remove incorrect closing of stdout holder. Update some versions. Fix a few more locations using adb path. Fix some more missed locations. Comment out testing log statements. Reenable output logging. Update some versions. Update some versions. Update versions to match main.
… STDERR to None to hopefully bypass the hang.
…old adb calls. Along with some other smaller cleanup.
…get runs working with minimal or no changes to it.
… to be printed out in the case of failure during memory consumption tests.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Copilot reviewed 6 out of 9 changed files in this pull request and generated 1 comment.
Files not reviewed (3)
- eng/performance/maui_scenarios_android.proj: Language not supported
- src/scenarios/shared/devicepowerconsumption.py: Evaluated as low risk
- scripts/performance/common.py: Evaluated as low risk
Comments suppressed due to low confidence (1)
src/scenarios/shared/androidhelper.py:21
- [nitpick] The variable name run_split_regex should be consistently renamed throughout the file.
run_split_regex = r":\s(.+)"
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM, few minor questions
adb = RunCommand(cmdline, verbose=True) | ||
adb.run() | ||
# Try calling xharness with stdout=None and stderr=None to hopefully bypass the hang | ||
getLogger().info("Clearing xharness stdout and stderr to avoid hang") |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
this pretty much duplicates the code of pre.py. I know it's probably out of scope of this PR, but if there is gonna be an additional one with further refactoring, would it make sense to deduplicate this part?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
+1 especially since it is a tricky problem
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM, thank you!
adb = RunCommand(cmdline, verbose=True) | ||
adb.run() | ||
# Try calling xharness with stdout=None and stderr=None to hopefully bypass the hang | ||
getLogger().info("Clearing xharness stdout and stderr to avoid hang") |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
+1 especially since it is a tricky problem
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thank you for fixing this and allowing us to use new XHarness versions!
Updated xHarness version we have hardcoded for android runs and minor cleanup of src/scenarios/shared/androidinstrumentation.py by removing a layer from try except finally. The version update was accomplished primarily by updating all previous direct adb arguments with xharness_adb arguments (added to common.py for easy reuse and updating) and implementing a hang workaround where xharness hangs if the first call to xharness adb pipes to STDOUT.
This will solve problems 1 and 2 from #4574, using an outdated version and having outdated command conventions. More work will need to be done to standardize the iOS and android xharness versions to be the same and have them auto-update using maestro.
Successful Pixel test run: https://dev.azure.com/dnceng/internal/_build/results?buildId=2619524&view=logs&j=efa3ffcd-91e9-5b69-9db7-650958b3131c&t=a635f724-5afe-5774-89bd-de12fd2d4e6e