Fix unwanted rebuilds in xtask commands #1559
Open
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Recently,
cargo xtask test
started doing a lot of rebuilding. Possibly this started with cargo 1.85, but I'm not sure.The behavior was:
cargo xtask test
buildsxtask
and all of its dependencies in order to launchxtask
. Then it would rebuild everything again to run the test command. If you then rancargo xtask test
a second time, everything would again be rebuilt. In other words, the build cache essentially wasn't working.Fix by clearing all
CARGO
env vars infix_nested_cargo_env
.Also update
command_to_string
to exclude cleared env vars, otherwise the command logging gets quite verbose.Checklist