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

Mitigate & document problems with mixed generated sources #3127

Open
wants to merge 3 commits into
base: main
Choose a base branch
from

Conversation

sam-mccall
Copy link
Contributor

  • deterministically prefer rust_library's crate spec over rust_test's.
    This means root_module gets remapped to a workspace path more often,
    and fixes flakiness of generated_srcs_test.
  • document the reasons and tradeoffs for this remapping.
  • stop adding include_dirs when remapping, it doesn't do anything to
    help with this problem, and is confusing.
  • fix test to strictly assert the path, which I broke in
    74f164b

Partially fixes #3126

- deterministically prefer rust_library's crate spec over rust_test's.
  This means root_module gets remapped to a workspace path more often,
  and fixes flakiness of generated_srcs_test.
- document the reasons and tradeoffs for this remapping.
- stop adding `include_dirs` when remapping, it doesn't do anything to
  help with this problem, and is confusing.
- fix test to strictly assert the path, which I broke in
  74f164b

Partially fixes bazelbuild#3126
Copy link
Collaborator

@illicitonion illicitonion left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks reasonable to me, thanks!

Is there something useful we can assert on here, perhaps in https://github.com/bazelbuild/rules_rust/blob/main/test/rust_analyzer/rust_analyzer_test_runner.sh?

@sam-mccall
Copy link
Contributor Author

Sorry about the delay here.

There is already a test for this in test/rust_analyzer/generated_srcs_test, it's "flaky" in that it always passed on the CI and always failed in my local workspace :-(
I think it's based on whether bazel returns the test or the lib first from aquery, which I don't know how to control.

@sam-mccall
Copy link
Contributor Author

(it looks like there are unrelated failures on buildkite, so I might need help getting this merged)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

rust_analyzer: unpredictable/broken behavior with generated sources
2 participants