-
Notifications
You must be signed in to change notification settings - Fork 27
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
Add requirements.txt and update readme in wheel #488
base: main
Are you sure you want to change the base?
Conversation
New dependencies detected. Learn more about Socket for GitHub ↗︎
|
Pull Request Test Coverage Report for Build 8894841227Warning: This coverage report may be inaccurate.This pull request's base commit is no longer the HEAD commit of its target branch. This means it includes changes from outside the original pull request, including, potentially, unrelated coverage changes.
Details
💛 - Coveralls |
wheel/requirements.txt
Outdated
@@ -0,0 +1,6 @@ | |||
iniconfig==2.0.0 | |||
maturin==1.4.0 | |||
chia-blockchain==2.1.4 |
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.
When I pip freeze
with this locally, I get a lot more dependencies - should we be including those in this file too, or no? I don't know much about Python dependency management
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 believe those are installed from these and that doing it this way captures those too.
Although, I also don't know much about Python dependency management so I may be wrong.
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.
You can think of dependency management as applying additional constraints to a system.
Compare to sudoku. You have a bunch of empty squares (the version numbers for each dependency) and a bunch of numbers that can go in those squares (in this case, the list of all versions for a particular package). Then you have to find a set of numbers that go in those squares that satisfy the constraints. A general form of this is known as a "SAT solver" https://en.wikipedia.org/wiki/SAT_solver and there is a lot of academic work in trying to get SAT solvers to be as efficient as possible because they can be applied to a lot of sudoku-like search problems.
(The comparison becomes a lot more obvious when you use >=
constraints rather than ==
since ==
is a lot more restrictive and plain-spoken about its intention.)
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.
That said, there are two points I want to make:
- I believe there's a push towards putting dependency constraints in
pyproject.toml
rather thanrequirements.txt
. See for example https://github.com/Chia-Network/hsms/blob/main/pyproject.toml#L11 maturin
is a build-time dependency only. It does not need to be present when you're using the compiled wheel. So its version should really go inpyproject.toml
(which is the "this is how to build me" file); see https://github.com/Chia-Network/chia_rs/blob/main/wheel/pyproject.toml#L2
cd wheel | ||
python -m venv venv | ||
. ./venv/bin/activate | ||
python -m pip install -r requirements.txt |
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.
Consider instead
python -m pip install -e .
(for a "development install" which points to the python files in the repo rather than making a pristine own copy that can let you "try out" python changes without reinstalling) orpython -m pip install .
(to make a pristine own copy that ignore further repo changes).
maturin develop | ||
python -m pytest ../tests | ||
``` | ||
|
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.
Now, when you're doing development, you probably do want maturin
in your local venv so you can test rust changes by doing maturin develop
rather than pip install -e .
again, which takes longer because it creates a sandboxed venv to do the build.
So to do development, I guess ideally what you want
cd wheel
python -m venv venv
. ./venv/bin/activate
python -m pip install maturin==(whatever the version listed in pyproject.toml is)
python -m pip install -e '.[dev]'
maturin develop
python -m pytest ../tests
The .[dev]
line means "please install additional package that this pyproject.toml
file declares as being useful for development", so stuff like pytest
, ruff
, mypy
, etc. We have to add stuff like in https://github.com/Chia-Network/hsms/blob/main/pyproject.toml#L19
Also, for obvious reasons, I'm not happy with the python -m pip install maturin==(whatever the version listed in pyproject.toml is)
line. We could add maturin
to the dev = ["maturin==...]
line, but then we would have it in two places (the build section and the dev
section) which is a recipe for disaster if they get out of sync and some incompatibility pops up and it works locally because we're using the dev
version of maturin
but not in CI because it uses the build
version. I expect there is some pip
thing to install the build
tools, but I don't know what it is.
This comment is very dense with information, so feel free to ask for clarification if I'm not being clear.
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.
the python dependencies are all '.[dev]'
dependencies as the python is only used for running pytests
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.
There is a pyproject.toml
file so there is a “python” project… it’s the wheel chia_rs
. It happens to not have any python source code at the moment, but that’s okay. The CI still uses the pyproject.toml
file to build it (or at least, it should!). The idea of pyproject.toml
is to standardize how python-targeted wheels build lifecycles are specified, so IMO it's reasonable to add the dev dependencies here even if most developers end up using the maturin develop
shortcut during their build/test development cycle.
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 guess you're talking about https://github.com/Chia-Network/chia_rs/blob/main/README.md#python-tests ?
Looks good. It might be helpful to note in the README that this mechanism to run the tests is a hack that is necessary because the chia_rs
and chia_blockchain
wheels currently have a cyclic dependency. At some point this can be fixed and then we'll be able to run the chia_rs
tests with pip install .[tests]
and pyproject.toml
like I was hinting at above.
In any case, I think we can close this PR without merging it now. Thanks to @matt-o-how for bringing up this discussion. Prior to this, I hadn't internalized the cyclic dependency with chia-blockchain
.
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 richard's comment about pyproject.toml
should be a blocker
@arvid I discussed this further with Matt and his main goal here is to provide some instructions on how to run the tests. Knowing how to do this is handy for new people who are working on this project, and it's a bit tricky because it requires In other words, there is a cyclic dependency between @arvid You must have some way to set up to run the tests. Can you describe what that is? And we can put that in the If we factor out a base layer from |
We're already working on untangling the circular dependency - moving sized ints/bytes types to chia_rs has been the first step, and I'll continue work on this in the next few weeks |
That's good, but for now, it still might be good to have a README that describes how to run the tests, no? |
Yeah, I can help write this up this week if you want. I always just run |
The readme should be updated @richardkiss - let me know if this covers it for now or if more details are needed |
Does what it says on the tin