Skip to content
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

Merged
merged 13 commits into from
Jan 14, 2025

Conversation

LoopedBard3
Copy link
Member

@LoopedBard3 LoopedBard3 commented Jan 13, 2025

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

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.
@LoopedBard3 LoopedBard3 added the dependencies Pull requests that update a dependency file label Jan 13, 2025
@LoopedBard3 LoopedBard3 requested a review from Copilot January 13, 2025 21:00
@LoopedBard3 LoopedBard3 self-assigned this Jan 13, 2025
Copy link

@Copilot Copilot AI left a 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(.+)"

Copy link
Contributor

@e-kharion e-kharion left a 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")
Copy link
Contributor

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?

Copy link
Member

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

Copy link
Member

@ivanpovazan ivanpovazan left a 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")
Copy link
Member

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

Copy link
Member

@matouskozak matouskozak left a 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!

@LoopedBard3 LoopedBard3 merged commit eae9f65 into dotnet:main Jan 14, 2025
48 of 58 checks passed
@LoopedBard3 LoopedBard3 deleted the UpdateXHarnessAndroidNov2024 branch January 14, 2025 21:09
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
dependencies Pull requests that update a dependency file
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants