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

build-info causes rebuilds when tests are changed #10

Open
jbellis opened this issue Jan 18, 2023 · 1 comment
Open

build-info causes rebuilds when tests are changed #10

jbellis opened this issue Jan 18, 2023 · 1 comment

Comments

@jbellis
Copy link

jbellis commented Jan 18, 2023

The globbing in rebuild_if_project_changes goes over all .rs files in any subdirectory, including tests/ which are separate crates.

In my case, this causes a recompile of the entire project when a test file is changed, turning a 0.3s build into a 30s build.

My first thought was, we could improve this by making it ignore tests/ by default, or just scan src/.

My second thought was, isn't this what cargo does by default? What problem is build-info trying to solve by adding a rerun-if-changed to every file?

@danielschemmel
Copy link
Owner

This issue is quite a bit more annoying than it seems at first glance, and explicitly rerunning when any *.rs file changes is the most robust solution I have found so far.

First of, rerunning the build script on any change is necessary, as the output may change. For example, modifying any file under source control will make your repository dirty, which means that the build script has to be rerun to provide the changed info, which then requires anything using that info to be rebuilt, so that finally your binary introduces itself as 0123456.dirty or however you may wish to represent that info. I assume this is part of what you are experiencing - maybe not a great result, but at least somewhat intentional.

Second, we do not completely own the build script, meaning that other rerun-if-changed lines might be emitted by different code (e.g., you could be running a parser generator). If that happens, the build script is only rerun for anything that triggers one of the rerun-if-changed lines.

I would love a better / more customizable solution for globbing, but the default behavior should be correct and as complete as possible.

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

No branches or pull requests

2 participants