Skip to main content

Testing GitHub actions, Cirrus CI, documentation, and publishing releases of Python packages.

Project description

workflow-sandbox

Testing GitHub actions, Cirrus CI, documentation, and publishing releases of Python packages.

This will be a Python package on test PyPI in its own right, with package name workflow-sandbox and module name workflow_sandbox (yes, the mixing of hyphenation and underscores is inelegant but deliberate).

Inception

This repository was created on GitHub using the following settings.

GitHub Create a new repository settings

Development environment

To develop this package, I first cloned the repository (others would fork on GitHub then clone their fork):

$ git clone https://github.com/<origin>/workflow-sandbox.git
$ cd workflow-sandbox

where <origin> is the GitHub account of the fork.

For now, I'm going to use <origin>=rpanderson and not work on a fork.

If you are developing on a fork, set the upstream remote:

$ git remote add upstream https://github.com/<upstream>/workflow-sandbox.git

where <upstream> is the base repository used for pull requests and publishing releases and documentation. If you forked your development repository from https://github.com/rpanderson/workflow-sandbox for example, you'd use <upstream>=rpanderson.

Create a virtual environment:

$ python -m venv .venv
$ .venv\Scripts\activate
$ python -m pip install --upgrade pip setuptools wheel

Roadmap

The first port of call will be to test:

CirrusCI

  • Formatting using black.
  • Linting using flake8.
  • Hosting documentation using GitHub pages (on an orphaned gh-pages branch).

GitHub actions

  • Create release using actions/create_release: :
jobs:
  release:
    name: Release
    env:
      VERSION: ${${{ github.ref }}//v}
    ...
    steps:
      ...
      # Only publish tagged merges elsewhere
      - name: Create GitHub Release
        if: startsWith(github.event.ref, 'refs/tags') && startsWith(github.ref, 'v')
        id: create_release
        uses: actions/create-release@latest
        env:
          GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
        with:
          tag_name: ${{ github.ref }}
          release_name: ${{ env.VERSION }}
          draft: true
          prerelease: ${{ contains(github.ref, 'rc') }}
  • Publish release on GitHub using actions/upload-release-asset with the body above extracted from the appropriate release notes based on git tags, similar to napari/napari#1138.

  • Using pypa/gh-action-pypi-publish:

    • Publish releases (and release candidates) on PyPI.
    • Publish merges into master branch (including untagged development versions) to TestPyPI with an appropriate dev version suffix.

Acknowledgements

Much of this is guided by the practices of other development communities—especially napari (and, increasingly, labscript-suite)—and many helpful conversations with @chrisjbillington and @philipstarkey.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

workflow-sandbox-0.1.0rc10.tar.gz (54.5 kB view details)

Uploaded Source

Built Distribution

workflow_sandbox-0.1.0rc10-py3-none-any.whl (4.4 kB view details)

Uploaded Python 3

File details

Details for the file workflow-sandbox-0.1.0rc10.tar.gz.

File metadata

  • Download URL: workflow-sandbox-0.1.0rc10.tar.gz
  • Upload date:
  • Size: 54.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/46.1.3 requests-toolbelt/0.9.1 tqdm/4.46.0 CPython/3.7.7

File hashes

Hashes for workflow-sandbox-0.1.0rc10.tar.gz
Algorithm Hash digest
SHA256 2b537ee0d4e317df5c666b44d09c8b58f1b9c4b0c140d1fd52debbbce2dd910e
MD5 ab33521014232395b3ee1351ca9a04db
BLAKE2b-256 629b1a8e7ec8a7e8b668bc6c54886a6b1a5fd30b949735cabe7f04f566bf9f5c

See more details on using hashes here.

File details

Details for the file workflow_sandbox-0.1.0rc10-py3-none-any.whl.

File metadata

  • Download URL: workflow_sandbox-0.1.0rc10-py3-none-any.whl
  • Upload date:
  • Size: 4.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/46.1.3 requests-toolbelt/0.9.1 tqdm/4.46.0 CPython/3.7.7

File hashes

Hashes for workflow_sandbox-0.1.0rc10-py3-none-any.whl
Algorithm Hash digest
SHA256 fbdb5c83964144821e6ad9f75305002a74e129c80f7e66758adfadb94772b008
MD5 b006f9a97d373ad36709cf556161f3bd
BLAKE2b-256 452814c4106610c6e25a77be78d323a03f673a3b339181c7fdfb219ccd79a6c8

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page