This README-dev is intended for maintainers of the repository for information on releases, standards, and anything that isn't pertinent to the wider community.
The PyPi package is kept under the Las Cumbres Observatory PyPi account. Upon tagging either the main or dev branch, a draft Github Release is created.
In order to trigger a draft Github Release of either dev or main, the branch must be given an annotated tag that matches the correct version format. The version formats are as follows:
Dev | Main | All other branches | |
---|---|---|---|
Tagged | Push to PyPi | Push to PyPi | No effect |
Not tagged | No effect | No effect | No effect |
Tagged branches must follow the semantic versioning syntax. Tagged versions will not be deployed unless they match the validation regex. The version format is as follows:
Dev | Main | |
---|---|---|
x.y.z-alpha.w | x.y.z |
The created Github Release this should be filled in with the relevant release notes. Upon publishing the new Github Release, a PyPi release will be created automatically by Github Actions.
This section of this document is a work-in-progress
-
Meet pre-deployment criteria.
- Includes appropriate release notes, including breaking changes, in
releasenotes.md
. - Pass Codacy code quality check.
- Doesn't decrease Coveralls test coverage.
- Passes Github Actions tests and code style check.
- Successfully builds ReadTheDocs documentation (not an automated check).
- One review approval by a repository owner.
- Includes appropriate release notes, including breaking changes, in
-
Merge your feature branch into the
dev
branchgit checkout dev
git merge feature/your_feature_branch
-
Tag the release, triggering GitHub Actions:
Release tags must follow semantic versioning syntax.
git tag -a x.y.z-alpha.w -m "x.y.z-alpha.w"
git push --tags
- Pushing the tags causes Github to create a draft release in GitHub
-
Edit the Release Notes in GitHub
When the tags were pushed above, GitHub created draft Release Notes which need to be filled out. (These can be found by following the
releases
link on the front page of the repo. Or, here).Edit, Update, and repeat until satisfied. Release notes should contain (as needed):
- Links to Read the Docs API (docstring) docs
- Links to Read the Docs higher level docs
- Link to Tom Demo feature demonstration
- Links to issues that have been fixed
-
Publish the Release
- When satisfied with the Release Notes,
Publish Release
. This will trigger the PyPi release automatically. Repo watchers are notified by email.
- When satisfied with the Release Notes,
-
Deploy
tom-demo-dev
with new features demonstrated, pullingtomtoolkit==x.y.z-alpha.w
from PyPI.Examples:
- Release of observation templates should include saving an observation template and submitting an observation via the observation_template
- Release of manual facility interface should include an implementation of the new interface
- Release of a new template tag should include that template tag in a template
The public release deployment workflow parallels the pre-release deployment work flow and more details for a particular step may be found above.
-
Create PR:
main <- dev
-
Meet pre-deployment criteria.
- Include docstrings for any new or updated methods
- Include tutorial documentation for any new major features as needed
- Pass Codacy code quality check.
- Doesn't decrease Coveralls test coverage.
- Passes Github Actions tests and code style check.
- Successfully builds ReadTheDocs documentation (not an automated check).
-
Merge PR
- Must be a repository owner to merge.
-
Tag the release, triggering GitHub and PyPI actions:
git tag -a x.y.z -m "Release x.y.z"
-- must follow semantic versioninggit push --tags
Triggers Github Actions to:- build
- create GitHub draft release
-
Update Release Notes in GitHub draft release.
This should be the accumulation of the all the dev-release release notes: For example, release notes for releases x.y.z-alpha.1, x.y.z-alpha.2, etc. should be combined into release notes for release x.y.z.
-
Publish Release
This will trigger Github Actions to push a new PyPi release.
-
deploy
tom-demo
with new features demonstrated, pullingtomtoolkit==x.y.z
from PyPI -
Post notification to Slack, Tom Toolkit workspace, #general channel. (In the future, we hope to have automated release notification to a dedicated #releases slack channel).
cd /path/to/tom_base/docs
pip install -r requirements.txt # make sure sphinx is installed to your venv
make html # make clean first, if things are weird
- point a browser to the html files in
./_build/html/
to proofread before deployment
pip install pycodestyle
pycodestyle tom_* --exclude=*/migrations/* --max-line-length=120
coverage run --include=tom_* manage.py test --exclude-tag=canary
coverage html
- point a browser to
index.html
in yourhtmlcov
directory
-
./manage.py test --exclude-tag=canary
to run non-canary tests -
Examples for running specific tests or test suites:
./manage.py test bhtom_targets.tests
./manage.py test bhtom_targets.tests.tests.TestTargetDetail
./manage.py test bhtom_targets.tests.tests.TestTargetDetail.test_sidereal_target_detail
The TOM Toolkit consists of the following repositories and external resources.
Releases are managed by the TOM Toolkit team unless otherwise specified.
tom_base
tom-toolkit-component-lib
- VueJS component library.tom_nonsidereal_airmass
- Provides airmass plots for non-sidereal targets.bhtom_registration
- Provides registration flows in the TOM Toolkit.tom_superevents
- Provides models and views for astronomical events.
tom_antares
- Provides ANTARES support. Primary contacts are Chien-Hsiu Lee and Nicholas Wolf. Maintained outside oftom_base
due toelasticsearch
dependency.tom_fink
- Provides Fink support. Primary contact is Julien Peloton. Releases are managed by Julien. Maintained outside oftom_base
due toelasticsearch
dependency.tom_lt
- Provides Liverpool Telescope support. Primary contact is Doug Arnold. Maintained outside oftom_base
due tolxml
andsoap
dependencies.tom_gemini_community
- Provides additional Gemini support beyond the Gemini module that ships withtom_base
. Primary contact is Bryan Miller. Releases are managed by Bryan. Maintained outside oftom_base
due togsselect
.tom_scimma
- Provides Skip support. Maintained outside oftom_base
due tohop-client
dependency.
dockertom
- Example TOM using Docker - Unmaintained, should be brought up to date.herokutom
- Example TOM deployment using Heroku - Unmaintained, should be brought up to date.
tom_calibrations
- Provides additional models (and potentially views) for keeping track of calibration-specific data. Currently a private repo.tom_publications
- Provides support for generating LaTeX summaries of target and observation data. Deprecated.skip-django
- Provides Plotly Dash Single-Page app for Skip interaction. Deprecated, to be replaced by VueJS components.tom-demo-frontend
- Prototype for implementation of pure VueJS app rather than using django-webpack. Patterned afterscience-archive-frontend
.bhtom_alerts_dash
- Provides Plotly Dash single-page app for broker interaction. Deprecated, should be replaced by an Django app with simple plots instead. Also out of date withdjango-plotly-dash
, and needs to be updated to use pattern-matching callbacks.
tomtoolkit.github.io
- Documentation page predating ReadTheDocs.
The following Github Actions exist for tom_base
, and some additional repositories have some or all of the actions.
The run-tests
workflow is triggered on any push or opened pull request. It runs the linter, runs non-canary tests, and publishes code coverage to Coveralls.
The run-canary-tests
workflow is triggered nightly. It runs just the canary tests, no others.
The github-release
workflow is triggered on tags matching x.y.z
or x.y.z-alpha.w
. It creates a Github Release draft for the tag.
The pypi-release
workflow is triggered on the publishing of a Github release. It pushes the package to PyPi.
Codacy provides code quality information for the TOM Toolkit repositories. Quality is graded on a letter grade scale from A to F, and covers things like unused variables, duplicate code, hardcoded passwords, and security vulnerabilities.
Codacy often provides duplicate issues, and sometimes flags things that aren't of interest. As an example, a unit test with a variable of password
would be flagged for a hardcoded password. In the event that a Codacy issue is not actually of interest, an issue can be ignored. Ignoring can be configured for an individual issue or all instances of that issue.
The codacy report is generated via Github webhook that triggers a static code analysis.
Coveralls - Provides code coverage information. Current tom_base
threshold is 89%, with no greater than 0.1% decrease per PR. No other repos have thresholds. Settings can be found on the Coveralls page for each specific repo.
Coveralls receives the report generated by the coverage
library by way of a Github Actions webhook. The coverage
library determines coverage simply by keeping track of whether a line of code is run by the tests. By default, Coveralls includes actual test files in test coverage, which artificially inflates our code coverage.
Dependabot is configured via the .github/dependabot.yml
file, as Dependabot is now a built-in Github integration. It runs weekly for a majority of repos, and automatically opens pull requests for any updated libraries.
In general, patch and minor releases are merged immediately, provided the pull request tests pass. For astropy
and astroquery
releases, it's generally best practice to update the version locally and do some smoke testing to ensure that aspects of the TOM Toolkit that use those two libraries will continue to work. Examples of astropy
- and astroquery
-dependent features are as follows:
- Data processing
- Catalog import
- Data plotting
For major versions of libraries that are not django
or djangorestframework
, it's best practice to check the release notes for any incompatibilities and smoke test the updates locally. If it's a particularly sketchy upgrade, an alpha release and a test in tom-demo
is also recommended.
Django major upgrades should be very carefully considered, with a particular focus on review of release notes.
Following dependabot merges to dev, any subsequent TOM Toolkit release should follow the normal release procedure at developer convenience.
The documentation is built on new Github releases of main
for the stable
version of the documentation, and on new pushes to dev
for the latest
version of the documentation. It is triggered by a Github webhook. Settings are maintained in the RTD project page. Version-specific RTD pages have to be activated manually via the versions page.
Repository | Codacy | Coveralls | Dependabot | PyPi Responsibility |
---|---|---|---|---|
dockertom |
N/A | N/A | N/A | N/A |
herokutom |
N/A | N/A | N/A | N/A |
skip-django |
No | No | No | TOM-Team |
tom-demo-frontend |
N/A | N/A | No | N/A |
tt-component-lib |
No | N/A | No | N/A |
bhtom_alerts_dash |
Yes | Yes | Yes | TOM Team |
tom_antares |
Yes | Yes | Yes | TOM Team |
tom_base |
Yes | >89% | Yes | TOM Team |
tom_calibrations |
No | No | No | TOM Team |
tom_fink |
Yes | Yes | Yes | Julien Peloton |
tom_gemini_communi |
No | No | No | Bryan Miller |
tom_lt |
No | No | Yes | TOM Team |
tom_nonsidereal |
No | No | Yes | TOM Team |
tom_publications |
No | No | Yes | TOM Team |
bhtom_registration |
Yes | Yes | Yes | TOM Team |
tom_scimma |
Yes | Yes | Yes | TOM Team |
tom_superevents |
Yes | Yes | Yes | TOM Team |