-
Notifications
You must be signed in to change notification settings - Fork 146
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
Make EvaP pip-installable and publish to PyPI #2328
base: main
Are you sure you want to change the base?
Conversation
b9bd7a6
to
501bd68
Compare
@richardebeling Thoughts? Furthermore, if you create a PyPI account, I can add you as a co-owner of the package. (I also requested the creation of an e-valuation organization on PyPI, not sure if it will be nicer / needed, we'll see once it's processed) |
pyproject.toml
Outdated
name = "evap" | ||
description = "EvaP" | ||
authors = [ "EvaP Developers" ] |
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.
Should we add the organization members here? Right now, PyPI displays "EvaP Developers" under unverified details, I suppose we could also just add the names which will hopefully be deduplicated then
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.
Looks like it won't be deduplicated, I suppose no one really cares about this, see https://test.pypi.org/project/evap/2024.10.0/ or https://pypi.org/project/black/
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 must be blind -- what section exactly would contain duplicated names? I see 5 unique user names on the black project page under "Maintainers"
I'd be fine with just putting "EvaP Developers", which will always remain correct.
Do we even need this in the pyproject.toml? I would expect that for username mapping, you need to configure this on PyPI separately anyway?
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.
"Ambv" is the same person as the unverified "author" (=> big projects don't care about about unverified data) and also on the evap release my name appears twice (=> it doesn't get deduplicated). Therefore, "evap developers" also seems fine to me.
We need to add something because otherwise poetry will complain :/
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.
Ah, I see -- I was looking for duplication inside one list. Yeah, "evap developers" 👍
cb69e3b
to
501bd68
Compare
One thing we discussed in person was that we now don't really need a full checkout of the EvaP repository on production. In fact, this is a chance to move most of the (apache-)deployment files out of the main repository and into a separate repository in the e-valuation organization. @janno42 agreed that this would be a nice (while not really needed) change. The only drawback seems to be that testing the backup process in the EvaP repository will be more complicated. Currently, I believe that we would want to pin a commit of the deployment repository, for example through flake.lock, and run the tests here. I believe that we could add the backup process test logic through nix in the deployment repository and then import this test in the EvaP repository to use the updated source of EvaP. In particular, this would allow us to share the test definition and "easily" run the same tests in both repos. I am not too settled on this approach though. Thoughts @richardebeling ? |
While certainly unexpected, I think it's a funny and efficient solution, and I don't have any reasons against doing this.
Why? "Backup" essentially is "Dump database via Re (separate repo, version pinning): Adds complexity, but if there is a need for this or it helps in any way, I guess we won't die 🤷♂️ A proper release procedure with some github magic action could also be used to deliver compiled TS and SCSS files automatically, something that I dislike a bit about our current approach (necessity to have npm somewhere). (We should keep in mind though: Automation is always nice up to the point where it stops working) |
Publish on main PyPI Remove unneeded code to add `evap` to PYTHONPATH Run `manage.py` on `python -m evap` fix manage.py possibly package with hatch?
4b3bef6
to
ee6a6e3
Compare
This reverts commit 354a5c1.
This doesn't work when installing evap, so we should pick a better default. Now that we have data/ for database contents anyways, it makes sense to put the uploads there too.
${python-dev}/bin/python ./manage.py compilemessages | ||
${python-dev}/bin/python ./manage.py scss --production | ||
${python-dev}/bin/python ./manage.py ts compile --fresh | ||
${python-build}/bin/python -m build |
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.
We now use nix, npm, uv, hatch/hatchling, and build. Granted, nix is just for dev environments. But still, do we need them all? uv promises that it can create distributions? If there's some specific thing we need missing it would be nice to have this documented. It would be nice in general to have a very brief explanation of the job of every tool used here.
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.
Code changes look fine to me, my biggest concern is complicated release process adding dependencies/complexity that add maintenance and security burden.
One future bug I expect to happen sooner or later is forgetting to add files to the release.
Closes #2303
Since we don't want to use nix in production (for example because security updates might take a long time to propagate through nixpkgs / through our github release cycle),
pip install .
orpip install evap
seems to be the most canonical way. This allows us to install security patches viapip install --upgrade evap
.If we really need to override a dependency version beyond the allowed range in
pyproject.toml
, we can install EvaP from sources outside of PyPI. The script to build the release artifacts is available asnix run .#build-dist
. It is possible to run this on a development machine and copy the.whl
file over to the server.The release wheel includes compiled TypeScript, SCSS and translation files, so there is no need to install NodeJS or gettext on the production server.
The new release workflow is:
pyproject.toml
, runnix develop .#impure --command uv lock
, commit it, tag it, push it.The versioning scheme we agreed on is year-month-patch, for example "2024.11.0". I suppose we should take care that we don't necessarily push breaking changes like updating the Python version in a new patch.
Since upgrading to the next stable revision of EvaP is handled by pip, there is no need for the
release
branch anymore.See