This repository is a template repository for Python projects under neutrons. After you create a new repository using this repo as template, please follow the following steps to adjust it for the new project.
-
Adjust the branch protection rules for the new repo. By default, we should protect the
main
(stable),qa
(release candidate), andnext
(development) branches.1.1 Go to the
Settings
tab of the new repo.1.2 Click on
Branches
on the left side.1.3 Click on
Add rule
button.1.4 Follow the instructions from Github.
-
Change the License if MIT license is not suitable for you project. For more information about licenses, please refer to Choose an open source license.
-
Update the environment dependency file
environment.yml
, which contain both runtime and development dependencies. For more information about conda environment file, please refer to Conda environment file.3.1 Specify environment 'name' field to match package name
3.2 We strongly recommended using a single
environment.yml
file to manage all the dependencies, including the runtime and development dependencies.3.3 Please add comments to the
environment.yml
file to explain the dependencies.3.4 Please prune the dependencies to the minimum when possible, we would like the solver to figure out the dependency tree for us.
-
Adjust pre-commit configuration file,
.pre-commit-config.yaml
to enable/disable the hooks you need. For more information about pre-commit, please refer to pre-commit. -
Having code coverage,
codecov.yaml
is strongly recommended, please refer to Code coverage for more information. -
Adjust the demo Github action yaml files for CI/CD. For more information about Github action, please refer to Github action.
6.1 Specify package name at: .github/workflows/package.yml#L34
6.2 Specify package name at: .github/workflows/package.yml#L46
-
Adjust the conda recipe,
conda-recipe/meta.yaml
to provide the meta information for the conda package. For more information about conda recipe, please refer to Conda build.7.1 Specify package name at: conda.recipe/meta.yaml#L15
7.2 Update license family, if necessary: conda.recipe/meta.yaml#L42
-
Adjust
pyproject.toml
to match your project. For more information aboutpyproject.toml
, please refer to pyproject.toml.8.1 Specify package name at: pyproject.toml#L2
8.2 Specify package description at: pyproject.toml#L3
8.3 Specify package name at: pyproject.toml#L39
8.4 Specify any terminal entry points (terminal commands) at: pyproject.toml#48.
In the example, invoking packagename-cli
in a terminal is equivalent to running the python script from packagenamepy.packagename.import main; main()
8.5 Projects will use a single `pyproject.toml` file to manage all the project metadata, including the project name, version, author, license, etc.
8.6 Python has moved away from `setup.cfg`/`setup.py`, and we would like to follow the trend for our new projects.
-
Specify package name at src/packagenamepy
-
Specify package name at: src/packagenamepy/packagename.py
-
If a GUI isn't used, delete the MVP structure at src/packagenamepy: 11.1: mainwindow.py 11.2: home/ 11.3: help/
-
Clear the content of this file and add your own README.md as the project README file. We recommend putting badges of the project status at the top of the README file. For more information about badges, please refer to shields.io.
Here we assume your intent is to upload the conda package to the anaconda.org/neutrons organization.
An administrator of anaconda.org/neutrons
must create an access token for your repository in the access settings.
After created, the token must be stored in a repository secret
:
- Navigate to the main page of the repository on GitHub.com.
- Click on the "Settings" tab.
- In the left sidebar, navigate to the "Security" section and select "Secrets and variables" followed by "Actions".
- Click on the "New repository secret" button.
- Enter
ANACONDA_TOKEN
for the secret name - Paste the Anaconda access token
- Click on the "Add secret" button
- Test the setup by creating a release candidate tag, which will result in a package built and uploaded to https://anaconda.org/neutrons/mypackagename
Follow the instructions in the Confluence page to create the access token.
The default package publishing service is anaconda. However, we also support PyPI publishing as well.
- Make sure you have the correct access to the project on PyPI.
- Make sure
git status
returns a clean state. - At the root of the repo, use
python -m build
to generate the wheel. - Check the wheel with
twine check dist/*
, everything should pass before we move to next step. - When doing manual upload test, make sure to use testpypi instead of pypi.
- Use
twine upload --repository testpypi dist/*
to upload to testpypi, you will need to specify the testpipy url in your~/.pypirc
, i.e.
[distutils]
index-servers = pypi, testpypi
[testpypi]
repository = https://test.pypi.org/legacy/
username = __token__
password = YOUR_TESTPYPI_TOKEN
- Test the package on testpypi with
pip install --index-url https://test.pypi.org/simple/ mypackagename
. - If everything is good, use the Github workflow,
package.yml
to trigger the publishing to PyPI.
Publishing to Anaconda is handled via workflow, package.yml
.
- By default, we recommend providing a single
environment.yml
that covers all necessary packages for development. - The runtime dependency should be in
meta.yaml
for anaconda packaging, andpyproject.toml
for PyPI publishing. - When performing editable install for your feature branch, make sure to use
pip install --no-deps -e .
to ensure thatpip
does not install additional packages frompyproject.toml
into development environment by accident.