1.4. Common Steps#

This section describes the installation steps that are common to both new and existing repositories. Follow these steps when you are asked to do so in the respective installation guides:

  1. Add a GitHub Personal Access Token (PAT) to the repository.

  2. Activate trusted publishing (OIDC) for PyPI and TestPyPI.

  3. Add an Anaconda token to the repository

  4. Add a Zenodo token to the repository.

  5. Create a Codecov account and install the Codecov GitHub app.

Note that other than the first step (GitHub PAT), all others are optional and you can skip them if you do not wish to use the respective services.

1.4.1. GitHub PAT#

The repository owner (or a member with admin permissions to the repository) needs to create a PAT with the required permissions, and store it as a secret in the repository.

To add a fine-grained personal access token to your repository:

  1. Click here or alternatively in your GitHub user account, navigate to Settings > Developer settings > Personal access tokens > Fine-grained tokens > Generate new token.

  2. Under Token name, enter a name for your token (e.g. <YOUR-REPO-NAME>_REPODYNAMICS_ADMIN_TOKEN), and choose an expiration date under Expiration. Note that you have to repeat these steps to replace the token after it expires.

  3. Under Repository access choose Only select repositories and then select your new repository from the dropdown menu.

  4. Under Permissions select Repository permissions and set the Administration, Contents, and Pages access to Read and write.

  5. Click on the Generate token button at the bottom of the page.

  6. Copy the displayed token to your clipboard.

  7. Go to Settings > Security > Secrets and variables > Actions > Secrets > New repository secret in your repository.

  8. In the Name field, enter REPO_ADMIN_TOKEN, paste the token you copied in step 6 into the Secret field, and click on the Add secret button.

1.4.2. PyPI Trusted Publishing#

PyPackIT uses trusted publishing (OIDC) to automatically authenticate with PyPI servers and publish your Python package and test suite on TestPyPI and PyPI, without the need to manually set authentication credentials such as username and password (cf. PyPI docs and GiHub docs).

To activate trusted publishing for PyPI and TestPyPI in your respective accounts:

  1. Create an account on PyPI or log in to your existing account.

  2. If you have not published this project to PyPI before, go to the Publishing page of your account and navigate to the Add a new pending publisher section at the bottom of the page. Alternatively, if you have already published this project to PyPI, go to the Your projects page of your account, find your project and click on the Manage button, then go to the Publishing tab and navigate to the Add a new publisher section at the bottom of the page.

  3. Fill in the fields in the trusted publishing form for GitHub with following data:

    1. PyPI Project Name (only for new projects): Distribution name of your Python package as given in the $.pkg.name field of your project’s metadata. If you haven’t specifically defined a package name, this will be the automatically derived package name as described in the installation guide.

    2. Owner: GitHub username or organization name that owns the repository.

    3. Reposiroty name: Name of your GitHub repository.

    4. Workflow name: cd-pypi.yaml

    5. Environment name: Name of the deployment environment defined at $.workflow.publish.pypi, PyPI (<YOUR-PACKAGE-NAME>) by default.

  4. Click on the Add button to submit the form. Make sure the submission is accepted by checking the response message that appears at the top of the page. If the submission is rejected due to a name conflict, you have to try a different name for the project. In that case, don’t forget to update your package name in the project metadata (and/or rename your repository) afterwards.

  5. Repeat the above steps for your test suite, replacing PyPI Project Name and Environment name with $.test.name and PyPI (<YOUR-TEST-SUITE-NAME>).

  6. Repeat the above steps in your TestPyPI account, only this time under the Environment name field enter the name of the deployment environment defined at $.workflow.publish.testpypi, TestPyPI (<YOUR-PACKAGE-NAME>) and TestPyPI (<YOUR-TEST-SUITE-NAME>) by default.

1.4.3. Anaconda Token#

PyPackIT can also build a conda package and publish it to your Anaconda channel. To enable automatic publishing on Anaconda:

  1. Create an account on Anaconda or log in to your existing account.

  2. In the Settings page of your account, click on Access under the left panel.

  3. In the Token Name field, enter a name (for your own reference) for the token.

  4. From the Scopes section, select Allow all operations.

  5. Choose an expiration date under Expiration date. Note that you have to repeat these steps to replace the token after it expires.

  6. Click on the Create button and copy the displayed token to your clipboard.

  7. Go to Settings > Security > Secrets and variables > Actions > Secrets > New repository secret in your repository.

  8. In the Name field, enter ANACONDA_TOKEN, paste the token you copied in step 6 into the Secret field, and click on the Add secret button.

1.4.4. Zenodo Token#

To enable the automatic publishing to Zenodo and/or Zenodo Sandbox:

  1. Create an account on Zenodo or log in to your existing account.

  2. In the Applications page of your account, click on New token under the Personal access tokens panel.

  3. Add a Name (e.g., name of your GitHub repository), select deposit:actions under Scopes, and click on the Create button.

  4. Copy the displayed token to your clipboard, and then click on the Save button.

  5. Go to Settings > Security > Secrets and variables > Actions > Secrets > New repository secret in your repository.

  6. In the Name field, enter ZENODO_TOKEN, paste the token you copied in step 4 into the Secret field, and click on the Add secret button.

  7. Repeat the above steps for Zenodo Sandbox, only this time in step 6, enter ZENODO_SANDBOX_TOKEN instead of ZENODO_TOKEN.

1.4.5. CodeCov Account#

To automatically upload your test coverage results to CodeCov:

  1. Create an account on CodeCov using your GitHub account.

  2. Install the Codecov GitHub app either by clicking on the Configure Codecov’s GitHub app link on the Codecov website, or directly from the app page. You can choose to install it for all your repositories or only for the current repository.