Skip to content
/ pyralid-template Public template

A template for easy to distribute Python packages

License

Notifications You must be signed in to change notification settings

sfarrens/pyralid-template

Repository files navigation

Pyralid Template

For packaging Python projects

Usage Development Release
docs build release
license deploy pypi
wemake-python-styleguide codecov python
contribute CodeFactor
coc Updates

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.

Contents

  1. Set-Up
  2. Management
  3. Deployment
  4. CosmoStat

Set-Up

In order to use this template please follow the instructions provided below.

Step 1: Get a remote copy of the template

The following instructions are for the GitHub website.

  1. Click the Use this template button.

    This will take you to a page that says "Create a new repository from pyralid-template".

  2. 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.

  3. 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.

  4. Click the Create repository from template button.

    This should create a new repository on your GitHub account.

  5. Take note of your repository URL.

Step 2: Configure the template

The following instructions should be run in a terminal on your local machine.

  1. 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
  1. Go to the package directory. e.g.
cd mypackage
  1. Run the configuration script and follow the instructions.
./configure.sh
  1. 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

Step 3: Activate coverage tests

The following instructions are for the codecov website.

  1. Go to https://codecov.io/.
  2. Log in using your GitHub account details.
  3. Click the Add new repository button.
  4. Find the your repository from the list provided and click on it.

Step 4: Activate dependency checks

The following instructions are for the PyUp website.

  1. Go to https://pyup.io/.
  2. Log in using your GitHub account details.
  3. Click the Add Repo button.
  4. Find the your repository from the list provided and click on the Add button.
  5. 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

Step 5: Check that everything works

Please do the following to make sure everything is working as expected.

  1. On your machine, create a new branch. e.g.
git checkout -b new_branch
  1. 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
  1. Add, commit and push your changes.
git add .
git commit -m "testing CI"
git push origin new_branch
  1. Go to the your remote repository and click on the Compare & pull request button that should have appeared for your branch.
  2. Provide a title and description for your pull request and click the Create pull request button.
  3. 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.
  4. codecov will raise an error if your new function is not covered by unit tests. You can either add some or ignore this error.
  5. 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.

Management

Now that your package is set up you can start managing your own code.

Add new content

  1. Add new subpackages following the contents of the example folder. Be sure to include a __init__.py file in every new directory you create.
  2. Add new submodules following the contents of classes.py, hello.py and math.py. Be sure to follow the Numpy docstring conventions and wemake-python-styleguide in writing your API documentation and code.
  3. Write unit tests as you add new functions and classes to retain the highest possible code coverage. Follow the examples in tests.
  4. 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.

Clean up

  1. Once you have added some of your own content remove the example subpackage and corresponding tests.
  2. Update requirements.txt with a list of your code dependencies so that they can be installed automatically with your package.
  3. Replace this README.md with your own package documentation.
  4. Update docs/source/index.rst with a more detailed description of your package.
  5. Delete the configure.sh script.

Optional

  1. Get a grade for your package from CodeFactor.
  2. Define your package contribution guidelines in CONTRIBUTING.md.
  3. Customise your API documentation in docs/source/conf.py.
  4. Customise your CI tests in setup.cfg.
  5. Customise the running of your CI/CD tests in .github/workflows.

Local Tests

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:

  1. Install the developer tools.
pip install -r develop.txt
  1. Run the tests locally.
python setup.py test

Deployment

Make a release

Before deploying your code you should make a release.

  1. Click the button on the right of your GitHub repo that says Create a new release.

  2. Specify a Tag version (e.g. v0.0.1).

    This should be identical to the version specified in setup.py.

  3. Provide a Release title (e.g. First Release).

  4. Describe what is included in your release.

    It is good practice to specify things that have changed from previous releases.

Deploy package on PyPi

In order to upload your package to PyPi (which allows users to install your package with pip), you should follow these steps:

  1. Check if your package name has already been taken. e.g.
pip search mypackage
  1. If the name is already taken, you may want to rename your package.
  2. Create an account on https://pypi.org/.
  3. Install twine.
pip install twine
  1. Build a distribution of your package.
python setup.py sdist bdist_wheel
  1. Finally, upload your distribution to PyPi.
twine upload dist/*
  1. Your package can now be installed anywhere using pip. e.g.
pip install mypackage
  1. 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.

About

A template for easy to distribute Python packages

Resources

License

Code of conduct

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published