This directory contains a collection of tools for running Continuous Integration (CI) tests, conda installation, and other development tools not directly related to the coding process.
You should test your code, but do not feel compelled to use these specific programs. You also may not need Unix and Windows testing if you only plan to deploy on specific platforms. These are just to help you get started
travis-ci
: Linux and OSX based testing through Travis-CIbefore_install.sh
: Pip/Miniconda pre-package installation script for Travis
appveyor
: Windows based testing through AppVeyor (there are no files directly related to this)
This directory contains the files to build and deploy on Conda. Although the Cookiecutter does not do anything with this directory at the moment, we leave this here to show an example of how your conda-recipe folder should look, when you decide to start deployment.
conda-recipe
: directory containing all the build objects required for Conda. All files in this folder must have their given namesmeta.yaml
: The yaml file needed by Conda to construct the buildbuild.sh
: Unix-based instructions for how to install the software interpreted by Condabld.bat
: Windows-based instructions for how to install the software interpreted by Conda
This directory contains the files to setup the Conda environment for testing purposes
conda-envs
: directory containing the YAML file(s) which fully describe Conda Environments, their dependencies, and those dependency provenance'stest_env.yaml
: Simple test environment file with base dependencies. Channels are not specified here and therefore respect global Conda configuration
This directory contains OS agnostic helper scripts which don't fall in any of the previous categories
scripts
create_conda_env.py
: Helper program for spinning up new conda environments based on a starter file with Python Version and Env. Name command-line options
- Clone the repository if you have write access to the main repo, fork the repository if you are a collaborator.
- Make a new branch with
git checkout -b {your branch name}
- Make changes and test your code
- Ensure that the test environment dependencies (
conda-envs
) line up with the build and deploy dependencies (conda-recipe/meta.yaml
) - Push the branch to the repo (either the main or your fork) with
git push -u origin {your branch name}
- Note that
origin
is the default name assigned to the remote, yours may be different
- Note that
- Make a PR on GitHub with your changes
- We'll review the changes and get your code into the repo after lively discussion!
- Make sure there is an/are issue(s) opened for your specific update
- Create the PR, referencing the issue
- Debug the PR as needed until tests pass
- Tag the final, debugged version
git tag -a X.Y.Z [latest pushed commit] && git push --follow-tags
- Get the PR merged in
Versioneer will automatically infer what version
is installed by looking at the git
tags and how many commits ahead this version is. The format follows
PEP 440 and has the regular expression of:
\d+.\d+.\d+(?\+\d+-[a-z0-9]+)
If the version of this commit is the same as a git
tag, the installed version is the same as the tag,
e.g. paprika-0.1.2
, otherwise it will be appended with +X
where X
is the number of commits
ahead from the last tag, and then -YYYYYY
where the Y
's are replaced with the git
commit hash.