Skip to content

Latest commit

 

History

History
253 lines (171 loc) · 14.2 KB

README-dev.md

File metadata and controls

253 lines (171 loc) · 14.2 KB

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.

Deployment

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.

Deployment Workflow

This section of this document is a work-in-progress

Pre-release deployment

  1. Meet pre-deployment criteria.

  2. Merge your feature branch into the dev branch

    • git checkout dev
    • git merge feature/your_feature_branch
  3. 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
  4. 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
  5. Publish the Release

    • When satisfied with the Release Notes, Publish Release. This will trigger the PyPi release automatically. Repo watchers are notified by email.
  6. Deploy tom-demo-dev with new features demonstrated, pulling tomtoolkit==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

Public release deployment

The public release deployment workflow parallels the pre-release deployment work flow and more details for a particular step may be found above.

  1. Create PR: main <- dev

  2. Meet pre-deployment criteria.

  3. Merge PR

    • Must be a repository owner to merge.
  4. Tag the release, triggering GitHub and PyPI actions:

    • git tag -a x.y.z -m "Release x.y.z" -- must follow semantic versioning
    • git push --tags Triggers Github Actions to:
      • build
      • create GitHub draft release
  5. 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.

  6. Publish Release

    This will trigger Github Actions to push a new PyPi release.

  7. deploy tom-demo with new features demonstrated, pulling tomtoolkit==x.y.z from PyPI

  8. 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).

Development Notes - Doing checks locally

Preview Read the Docs doc strings

  • 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

Run code style checks

  • pip install pycodestyle
  • pycodestyle tom_* --exclude=*/migrations/* --max-line-length=120

Run coverage checks

  • coverage run --include=tom_* manage.py test --exclude-tag=canary
  • coverage html
  • point a browser to index.html in your htmlcov directory

Run tests

  • ./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

Project Information

The TOM Toolkit consists of the following repositories and external resources.

Repositories

Releases are managed by the TOM Toolkit team unless otherwise specified.

Core module

  • tom_base

Modules providing additional functionality

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

Third-party service modules

  • tom_antares - Provides ANTARES support. Primary contacts are Chien-Hsiu Lee and Nicholas Wolf. Maintained outside of tom_base due to elasticsearch dependency.
  • tom_fink - Provides Fink support. Primary contact is Julien Peloton. Releases are managed by Julien. Maintained outside of tom_base due to elasticsearch dependency.
  • tom_lt - Provides Liverpool Telescope support. Primary contact is Doug Arnold. Maintained outside of tom_base due to lxml and soap dependencies.
  • tom_gemini_community - Provides additional Gemini support beyond the Gemini module that ships with tom_base. Primary contact is Bryan Miller. Releases are managed by Bryan. Maintained outside of tom_base due to gsselect.
  • tom_scimma - Provides Skip support. Maintained outside of tom_base due to hop-client dependency.

Example modules

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

Experimental/prototype modules

  • 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 after science-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 with django-plotly-dash, and needs to be updated to use pattern-matching callbacks.

Archived

  • tomtoolkit.github.io - Documentation page predating ReadTheDocs.

Build resources

Github Actions

The following Github Actions exist for tom_base, and some additional repositories have some or all of the actions.

run-tests workflow

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.

run-canary-tests workflow

The run-canary-tests workflow is triggered nightly. It runs just the canary tests, no others.

github-release workflow

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.

pypi-release workflow

The pypi-release workflow is triggered on the publishing of a Github release. It pushes the package to PyPi.

Codacy

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

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

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.

Read the Docs

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