There are several ways to build its development environment. We could use miniconda directly and only. Or, we could follow the travis.yaml to build the isolated development environment.
Everything comes from miniconda:
Everything comes from miniconda:
export PATH="<YOUR_MINICONDA_ROOT>/bin:$PATH"
Then further configuration to be more automatic. This step is/should be optional:
conda config --set always_yes yes --set changeps1 no
conda update -q conda
conda info -a
Change PS1 option is not necessary. You could decide if you refer it or not.
Create a conda isolated python environment <YOUR_SOLVCON_SRC>/build/env/
<YOUR_SOLVCON_SRC>/contrib/devenv/create.sh
Go to this conda isolated python environment and activate the associated virtualenv
source <YOUR_SOLVCON_SRC>/build/env/start
Please note we won't see the prompt change as what we always get via usual conda activate. Check if we have already been in the conda virtual environment by:
which python
And this python should be the one in the conda virtual environment.
Now it is time to install everything in the conda virtual environment!
<YOUR_SOLVCON_SRC>/contrib/conda.sh
If you want to use the latest pybind11 (optional):
pip install -U https://github.com/pybind/pybind11/archive/master.zip
This month I found an issue and YYC identified it is a real issue of pybind11[1].
Now all packages and libraries are ready to build SOVLCON. Let's build by[2]:
python setup.py build_ext --inplace
That is it! Let's test it a bit:
Unit tests with doctest
nosetests --with-doctest -v
Function tests. Your test machine should be a SSH server to test parallel tests locally.
nosetests ftests/parallel/* -v
In the latest step of travis.yaml, there is a release.sh.
<YOUR_SOLVCON_SRC>/contrib/release.shThis step is optional if you run SOLVCON locally. The release.sh is for ephemeral build/test nodes. The script strips the build files and packs the necessary libraries with the SOLVCON source to distribute to the test/biuld nodes.
Time to "march" something!! : D
[1] https://github.com/pybind/pybind11/pull/836 No one but me noted the issue for one month!
[2] You may not want to perform "python setup.py install" because this will install your SOLVCON code into the conda environment. We want to keep conda and build/env virtual environment separately.
Summary
In this article we separate the conda and env virtual environment. The advantage to separate them is that we could install common packages via <YOUR_SOLVCON_SRC>/contrib/conda.sh and share them over different build/env virtual environments.
