I just ran julia --project in my locally developed package with only a few dependencies, and then ran Pkg.test(). However, for some reason, the package manager spends a bunch of time precompiling packages like Plots, and does this everytime I run tests.
Plots is not in Project.toml or Manifest.toml for my package’s environment. However, I noticed it was in my global environment, and it seems like the global environment’s packages remain active even when I activate a local environment. Is this behaviour expected, and how can I disable it?
Got it. I feel like there should be an easier way to do this, like a script option, as the current state of affairs basically means that every local run of scripts or Pkg.test is affected by a potentially non-empty global environment, which could affect not just precompilation times but also correctness. (I understand why it’s useful for things like Revise.)
Right. My test script was actually activating another environment that imported Plots, which was the true cause of the precompilation, so that was my bad.
I still think it would be nice to have an easy way to not include the global environment – or at least further emphasize to users that the global environment should be treated with extreme care as it is included by default everywhere. (It’s also super easy to pollute the global environment: just forget to activate your local environment.)
Intuitively, based on the docs I’ve read so far on environments, I thought of the global environment with its Project.toml as just another environment. It feels very unintuitive that I can do using Plots in julia --project in the above example, even though Plots is not returned by ] st.
Yep, I agree. In particular with the point that it is to easy to pollute the global environment. IMO the default environment shouldn’t be the one that is global in the sense of being automatically stacked on top of local environments.
(I also think that stacking should be opt-in.)
Note however that this has been raised a few times before and, unfortunately, hasn’t led to a change. Maybe it’s just because no one went ahead and created a PR. Maybe it’s because there is no consensus. Don’t know.
The idea is to start Julia in a temporary environment which can nevertheless be saved, and use in practical way locally available packages. (and with that keep the global environment mostly clean).