For packaging Python projects
Usage | Development | Release |
---|---|---|
Author: Samuel Farrens
Email: samuel.farrens@cea.fr
Year: 2020
The Pyralid template is designed to enable users to quickly package a Python project. After following the set-up instructions you should be able to automatically run CI tests and generate API documentation for your code.
See pyraliddemo for a demo package created with the Pyralid template.
In order to use this template please follow the instructions provided below.
The following instructions are for the GitHub website.
-
Click the
Use this template
button.This will take you to a page that says "Create a new repository from pyralid-template".
-
Specify a
Repository name
for your package.Ideally your package name should match the repository name. Avoid using hyphens or underscores in your package name as this can cause issues later. Note that you can change the name later if necessary.
-
Click the box next to
Include all branches
.This will ensure your template includes the
gh-pages
branch you will need for your API documentation. -
Click the
Create repository from template
button.This should create a new repository on your GitHub account.
-
Take note of your repository URL.
The following instructions should be run in a terminal on your local machine.
- Clone your remote repository using your repository URL. e.g. for a package called
mypackage
you would run:
git clone https://github.com/username/mypackage
- Go to the package directory. e.g.
cd mypackage
- Run the configuration script and follow the instructions.
./configure.sh
- If you chose not to run git commands in the configuration script then manually push your changes to GitHub.
git add .
git commit -m "updated template with package name"
git push
The following instructions are for the codecov website.
- Go to https://codecov.io/.
- Log in using your GitHub account details.
- Click the
Add new repository
button. - Find the your repository from the list provided and click on it.
The following instructions are for the PyUp website.
- Go to https://pyup.io/.
- Log in using your GitHub account details.
- Click the
Add Repo
button. - Find the your repository from the list provided and click on the
Add
button. - In the pop-up window leave the Setup options as they are and click the
Add
button.
If you added any dependencies with the configure.sh
script then PyUp will open some pull requests to pin these to the latest versions.
PyUp will also create branch called pyup-config
with a new .pyup.yml
file. You can delete this branch as follows:
git push origin -d pyup-config
Please do the following to make sure everything is working as expected.
- On your machine, create a new branch. e.g.
git checkout -b new_branch
- Make a modification to any of the files. e.g. add a new function to
example/math.py
.
def add_two_floats(first_value: float, second_value: float) -> float:
"""Add Two Floats.
Add two float values.
Parameters
----------
first_value : float
First float value
second_value : float
Second float value
Returns
-------
float
Result of addition
Raises
------
TypeError
For invalid input types.
"""
fv_is_float = isinstance(first_value, float)
sv_is_float = isinstance(second_value, float)
if not all((fv_is_float, sv_is_float)):
raise TypeError('Inputs must be floats.')
return first_value + second_value
- Add, commit and push your changes.
git add .
git commit -m "testing CI"
git push origin new_branch
- Go to the your remote repository and click on the
Compare & pull request
button that should have appeared for your branch. - Provide a title and description for your pull request and click the
Create pull request
button. - Once open, your pull request should automatically launch the GitHub actions CI tests. Note that this may take a few seconds to start. Click on the link that appears if you want to follow the progress of the tests.
- codecov will raise an error if your new function is not covered by unit tests. You can either add some or ignore this error.
- Once your CI tests have passed you can merge your pull request, which should automatically launch the CD process. This will generate your package API documentation. Go to e.g. https://username.github.io/mypackage/ to view your documentation.
Now that your package is set up you can start managing your own code.
- Add new subpackages following the contents of the
example
folder. Be sure to include a__init__.py
file in every new directory you create. - Add new submodules following the contents of
classes.py
,hello.py
andmath.py
. Be sure to follow the Numpy docstring conventions and wemake-python-styleguide in writing your API documentation and code. - Write unit tests as you add new functions and classes to retain the highest possible code coverage. Follow the examples in
tests
. - To manage your code development you should follow the procedure described in Step 5 of the set-up. Note that you can continue to work on a branch you created for an open pull request up until it is merged. After merging a branch it is good practice to delete it.
- Once you have added some of your own content remove the
example
subpackage and corresponding tests. - Update
requirements.txt
with a list of your code dependencies so that they can be installed automatically with your package. - Replace this
README.md
with your own package documentation. - Update
docs/source/index.rst
with a more detailed description of your package. - Delete the
configure.sh
script.
- Get a grade for your package from CodeFactor.
- Define your package contribution guidelines in
CONTRIBUTING.md
. - Customise your API documentation in
docs/source/conf.py
. - Customise your CI tests in
setup.cfg
. - Customise the running of your CI/CD tests in
.github/workflows
.
To speed up development of your package it may be convenient to run tests locally before submitting a pull request. This can be done as follows:
- Install the developer tools.
pip install -r develop.txt
- Run the tests locally.
python setup.py test
Before deploying your code you should make a release.
-
Click the button on the right of your GitHub repo that says
Create a new release
. -
Specify a Tag version (e.g.
v0.0.1
).This should be identical to the version specified in
setup.py
. -
Provide a Release title (e.g.
First Release
). -
Describe what is included in your release.
It is good practice to specify things that have changed from previous releases.
In order to upload your package to PyPi (which allows users to install your package with pip
), you should follow these steps:
- Check if your package name has already been taken. e.g.
pip search mypackage
- If the name is already taken, you may want to rename your package.
- Create an account on https://pypi.org/.
- Install twine.
pip install twine
- Build a distribution of your package.
python setup.py sdist bdist_wheel
- Finally, upload your distribution to PyPi.
twine upload dist/*
- Your package can now be installed anywhere using
pip
. e.g.
pip install mypackage
- To update your package, change the version number in
setup.py
and repeat steps 5 and 6.
Note that step 6 can be simplied by creating a .pypirc file.