-
Notifications
You must be signed in to change notification settings - Fork 40
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
Rapid deployment to Github, PyPI and anaconda.org #271
Comments
These are the steps to implement all of the rapid deployment goodies in a Python project:
|
With the above changes to your project, making a new release takes the following steps:
|
Hi @matt-chan, there was some talk at PyQC this year that we should shut down the PyQC channel on anaconda.org (https://anaconda.org/pyqc/repo). In particular, PySCF has its own channel, but the pyqc pyscf channel version was showing up in google instead (who googles anaconda.org?). How does that interact with your Horton distribution scheme? Paul Ayers suggested to consult you. No rush, just saw the reminder tab I've kept open. |
Hi @loriab, yep, we've moved almost everything over to the "theochem" channel. We used to get libint and libxc from PyQC, but we simplified things for our users so they could do a 1-step install. I'm not sure if we should keep it or not, since technically we should have a common deps. Maybe push for inclusion of common dependencies to conda-forge? And it turns out I'm guilty of googling for those anaconda packages =S, although I've never searched Psi4. |
I've made an example project of how to build and deploy packages with Travis (Linux and OSX) and AppVeyor (Windows).
https://github.com/theochem/python-cython-ci-example
To make a new release for this package (source tar.gz on Github, PyPI and compiled package on anaconda.org), I only need to push a version tag (like 1.4.1) to the github repo, thanks to the deployment features of Travis-CI and some PowerShell scripting on AppVeyor. Also the documentation is rebuilt on Travis-CI when such a tag is pushed. This makes it super easy to publish new releases.
This rapid deployment could help us when splitting up HORTON in smaller packages without ending up in dependency hell. I'm mainly thinking of two relevant use cases:
(1) End users can simply install Conda as a standardized Python environment, which works on all platforms. Installing miniconda or anaconda is trivial. E.g. for Miniconda with Python 3, these are the steps:
Once you have conda installed, installing the demo project just takes:
The
-c tovrstra
option selects my channel: https://anaconda.org/tovrstra. This command will install all dependencies as well. We can even put our compilations of LibXC and LibInt in such a channel, to avoid issues like #262.When a user is interested in a package that only has Python dependencies, then pip can be used as well. For example, if your computer has Python and pip installed, one just has to run:
Pip has some limitations, which make it not suitable for all purposes:
import numpy
orimport Cython
insetup.py
, pip cannot install your package from scratch, e.g. in a new venv. There is an ugly workaround for numpy: https://stackoverflow.com/questions/19919905/how-to-bootstrap-numpy-installation-in-setup-py(2) Developers can easily install a development environment, making use of the conda environments. My first idea was to work with so-called
environment.yml
files, but these do not allow easy upgrading when the development version moves on to newer versions of dependencies. It would be better to add a script that takes the dependencies out ofconda.recipe/meta.yaml
and that installs/upgrades/downgrades these in the current Conda environment. On top of these, one may clone git repos for a few dependencies, in case one wants to develop against a development version of the dependency. Installing these into a conda environment (without root) is relatively easy.The text was updated successfully, but these errors were encountered: