-
Notifications
You must be signed in to change notification settings - Fork 66
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
Move to a conda only install of pymc (local dev workflow) #304
Conversation
Check out this pull request on See visual diffs & provide feedback on Jupyter Notebooks. Powered by ReviewNB |
Looks like the ci workflow is failing. I'm not strong on GitHub actions (see |
pyproject.toml
Outdated
"statsmodels", | ||
"xarray>=v2022.11.0", | ||
] | ||
dependencies = [] |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think the problem comes because you are deleting these dependencies and you are pip installing the package in the CI
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think you can try to mimic the way is done in https://github.com/pymc-devs/pymc-experimental/blob/main/.github/workflows/test.yml
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm not that experienced with GitHub workflows. What am I looking for? Are you referring to the environment-file:
in the with:
block?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I mean concretely: https://github.com/pymc-devs/pymc-experimental/blob/main/.github/workflows/test.yml#L16-#L70 Here they are installing the conda env and installing the library. However, I see that they have a setup.py
so this might not apply to this case 🙈
How I see it environment.yml
is a specification of an environment but you still need to indicate de package dependencies and I think this is why the tests are failing unless you keep the dependencies = [ ... ]
in the pyproject.toml
. Maybe @maresb has a hint on how to make this cleaner?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Hey, I'm on vacation now, but we should discuss (and update) #281.
As for Conda vs pyproject dependencies, ideally we keep both. Pyproject dependencies define the python-only dependencies that you have. On the other hand, Conda takes care of both Python and non-Python dependencies.
I haven't read carefully any of the details, so I may be missing stuff, but the way I like to handle this is to:
- Create a Conda environment that satisfies all the dependencies, Python or otherwise
pip install
the project into the Conda environment with the--no-dependencies
flag so thatpip
installs only the project- Run
pip check
to ensure all of the project's Python dependencies are satisfied within the Conda environment. This will trip on the case when you declare a Python dependency inpyproject.toml
that is missing from yourenvironment.yaml
file. I don't really know of any tests that go in the other direction, and I don't know that it would even make sense.
Note that this means that your primary source of truth for a project's dependencies should be the pyproject.toml
file, not the environment.yaml
file! I think this is how it should be. It enables masochistic "experts" to do an unsupported pip install
if they are so inclined.
Regarding #281, conda-lock
can parse the pyproject.toml
for the requirements and generate a lockfile, so apart from specifying special requirements, we may be able to replace the environment.yml
with a lockfile.
Just updated requirement to |
When building the environment (locally) using the methods in this PR (i.e. conda):
That suggests that it's not a pip/conda environment construction issue We also get 12 failing doctests in the remove tests. |
Codecov ReportAll modified and coverable lines are covered by tests ✅
Additional details and impacted files@@ Coverage Diff @@
## main #304 +/- ##
=======================================
Coverage 77.27% 77.27%
=======================================
Files 21 21
Lines 1395 1395
=======================================
Hits 1078 1078
Misses 317 317 ☔ View full report in Codecov by Sentry. |
Would be good to get a sanity check to ensure I won't break everything before we merge this :) |
At a glance this looks sound, but this seems to be completely user-facing, meaning it doesn't seem like anything is being validated/tested in the CI. |
(At worst you're breaking something minor in the development workflow.) |
On the CI front, it would be nice to move forward on #281. |
Yes, this one is user-facing. Will try to progress the ci PR very soon. |
Closes Remove the(Addressed by Fix #287 Update Makefile #309)pip install
lines inMakefile
and add the--no-deps
flag for the local install #287taken out ofduplicated inpyproject.toml
and moved intoenvironment.yml
environment.yml
CONTRIBUTING.md
WARNING (pytensor.tensor.blas): Using NumPy C-API based implementation for BLAS functions
. which is indicative of pymc being pip installed rather than conda installed.