Skip to content

Commit

Permalink
Merge pull request ukhsa-collaboration#105 from ukhsa-collaboration/dev
Browse files Browse the repository at this point in the history
Silent PR to Master to check updated documentation
  • Loading branch information
hareball90 authored Sep 1, 2023
2 parents 5c10d9c + 4db451d commit 24fabc3
Show file tree
Hide file tree
Showing 123 changed files with 16,338 additions and 5,512 deletions.
70 changes: 70 additions & 0 deletions .github/pull_request_template.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,70 @@
## Description of the PR

<!-- Add a description of your changes below this line -->
Replace this text with a description of the pull request including the issue number.

## Checks

This is an itemised checklist for the QA process within UKHSA and represents the bare minimum a QA should be.

Full instructions on reviewing work can be found at Confluence on the [ONS QA of code guidance](https://best-practice-and-impact.github.io/qa-of-code-guidance/intro.html) page.

**To the reviewer:** Check the boxes once you have completed the checks below.

- [ ] It runs
- Can you get the code run to completion in a new instance and from top to bottom in the case of notebooks, or in a new R session?
- Can original analysis results be accurately & easily reproduced from the code?
- [] tests pass
- [] CI is successful
This is a basic form of Smoke Testing
- [ ] Data and security
- Use nbstripout to prevent Jupyter notebook output being committed to git repositories
- Files containing individual user's secret files and config files are not in repo, however examples of these files and setup instructions are included in the repo.
- Secrets include s3 bucket names, login credentials, and organisation information. These can be handled using secrets.yml
- If you are unsure whether an item should be secret please discuss with repo owner
- The changes do not include unreleased policy or official information.
- [ ] Sensible
- Does the code execute the task accurately? This is a subjective challenge.
- Does the code do what the comments and readme say it does\*?
- Is the code robust enough to handle missing or challenging data?
- [ ] Documentation
- The purpose of the code is clearly defined, whether in a markdown chunk at the top of a notebook or in a README
- Assumptions of the analysis & input data are clearly displayed to the reader, whether in a markdown chunk at the top of a notebook or in a README
- Comments are included in the code so the reader can follow why the code behaves in the way it does
- Teams with high quality documentation are better able to implement technical practices more readily and perform better as a whole (DORA, 2021).
- Is the code written in a standard way? (In a hurry this may be a nice to have, but if at all possible, this standard from the beginning can cut long term costs dramatically)
- Code is modular, storing functions & classes in the src and being imported into a notebook or script
- Projects should be based on the UKHSA repo template developed to work with cookiecutter
- Variable, function & module names should be intuitive to the reader
- For example, intuitive names include df_geo_lookup & non-intuitive names include foobar
- Common and useful checks for coding we use broadly across UKHSA include:
- Rstyler
- lintr
- black
- flake8
- [ ] Pair coding review completed (optional, but highly recommended for QA in a hurry)
- Pair programming is a way of working and reviewing that can result in the same standard of work being completed 40%-50% faster (Williams et al., 2000, Nosek, 1998) and is better than solo programming for tasks involving efficient knowledge transferring and for working on highly connected systems (Dawande et al., 2008).
- Have the assignee and reviewer been on a video call or in person together during the code development in a line by line writing and review process?

\* If the comments or readme do not have enough information, this check fails.

## How to QA this PR

Before accepting the PR and merging to `main` or `master`, please follow these steps on a terminal in your development instance:

- `git status` check what branch you are on and if you have any uncommitted changes.
- Handle the work on your current branch:
- `git commit` if you would like to keep the changes you have made on your current branch.
- `git stash` if you do not want to keep these changes, although you can recover these later.
- `git checkout main` or `git checkout master` to go to the branch that will be merged to.
- `git pull origin main` or `git pull origin master` fetches the most up to date git info on this branch.
- `git branch -a` lists all the available branches.
- `git checkout BRANCHNAME-FOR-PR` moves you into the branch to QA.
- `git pull origin BRANCHNAME-FOR-PR` ensures you have the most recent changes for the PR.
- Run the notebooks or code.
- Run `pre-commit`. This runs some automated checks to check the code is well formatted and does not contain data.
- Are there any small changes that can be made to get it to run?
- Yes: make annotations on github and notify code creator to correct them
- No, it runs: done!
- No, and it looks like it would need a lot of work: note major points in Github PR chat and discuss with author.
- Carefully read through the code or documentation and make sure it makes sense.
62 changes: 62 additions & 0 deletions .github/workflows/book.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,62 @@
name: build-book

# only run when specific files change
# only run on install-fix-docs branch
# TODO change this to dev/main branch once integrated

on:
push:
branches:
- master

jobs:
build-book:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3

- uses: actions/cache@v3
with:
path: ~/.cache/pip
key: ${{ runner.os }}-pip-${{ hashFiles('**/requirements.txt') }}
restore-keys: |
${{ runner.os }}-pip-
steps:
- uses: actions/checkout@v3

- name: Setup Graphviz
uses: ts-graphviz/setup-graphviz@v1

# install python
- name: Set up Python 3.8
uses: actions/setup-python@v4
with:
python-version: 3.8

# install dependencies
- name: Install dependencies
run: |
python -m pip install --upgrade pip
pip install -r requirements.txt
pip install -r docs/requirements.txt
# set up pygom
- name: Build and install pygom
run: |
python setup.py build
python setup.py install
# build the book
# TODO check which flags are needed, -W
- name: Build the book
run: |
jupyter-book build --all -v docs/
# deploy book to github-pages
- name: GitHub Pages
uses: peaceiris/[email protected]
with:
github_token: ${{ secrets.GITHUB_TOKEN }}
publish_dir: docs/_build/html

9 changes: 7 additions & 2 deletions .github/workflows/main.yml
Original file line number Diff line number Diff line change
Expand Up @@ -7,17 +7,22 @@ on:
- dev
- feature/*
- bugfix/*

pull_request:
branches:
- master
- dev

env:
ACTIONS_ALLOW_UNSECURE_COMMANDS: true

jobs:
build:
runs-on: ${{ matrix.os }}
strategy:
matrix:
os: [ubuntu-latest, macos-latest, windows-latest]
python-version: [3.5, 3.6, 3.7, 3.8]
os: [ubuntu-latest, windows-latest] # macos-latest
python-version: ["3.7", "3.8", "3.9", "3.10", "3.11"]

steps:
- uses: actions/checkout@v2
Expand Down
91 changes: 0 additions & 91 deletions .github/workflows/python.yml

This file was deleted.

6 changes: 5 additions & 1 deletion .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ cover/*
__pycache__
*.egg-info
*.egg
.vscode/

# For jupyter / ipython
*/.ipynb_checkpoints
Expand All @@ -17,5 +18,8 @@ __pycache__
.settings

# For built documentation
/doc/_build*
/docs/pygom-doc/_build/*
/doc/_build/
/doc/source/savefig/*
/docs/pygom-doc/_autosummary/
*/_build/*
36 changes: 0 additions & 36 deletions .travis.yml

This file was deleted.

39 changes: 39 additions & 0 deletions CONTRIBUTING.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
# Contributor guidance

By contributing to PyGOM, you acknowledge that you are assigning copyright to us so we can continue to maintain package. PyGOM is licensed under (GPL2)[https://raw.githubusercontent.com/PublicHealthEngland/pygom/master/LICENSE.txt].

## suggested information for raising issues
- is it possible to produce a template for a new issue?

## requirements for amendments
- merge and pull requests should only be considered if the MR/PR explicitly states how the following has been addressed
- unit tests
- modified documentation
- justification
- successful execution of documentation (controlled by halting at errors in /docs/_config.yml, demonstrated by successful action)
- #TODO is there a reasonable limit on the code quantity that is submitted per review? (e.g. 200 lines) to ensure a suitable review can be completed

## workflow for incorporating merge and pull requests
- dev and master are protected and require a code review by the project owner (or designated reviewer)
- dev should contain all working amendments and collated before the next versioned merge request to master
- only a merge request should be made to master from dev from the UKHSA repo
- forked repo pull requests should be made into UKHSA dev branch (or others where appropriate)
- master branch is for versioned releases, which should be tagged and a summary of alterations made to README.md
- merge and pull requests to be made to dev, where builds and actions must run successfully before being incorporated
- if closing a ticket, if possible, include the commit reference which addresses the issue
- code reviewer should use the template to work through requirements (e.g. confirming tests have been added, documentation is appropriate, added to contributor file)

## adding to the documentation how to add to the jupyterbook;
The documentation directory (docs)[docs/] contains folders for each filetype used to build the documentation. Folders that exist under these are associated with sections (defined by [docs/_toc.yml]()). The basic steps for adding pages to the Jupyter Book are here, and for more detailed configuration see comments in the config file)[docs/_config.yml], Jupyter Book documentation, or Sphinx documentation.
- save your ipynb, md, or rst file to the appropriate folder
- update the (table of contents file)[docs/_toc.yml] so that the file is incorporated
- from the root of the repository run `jupyter-book build docs/' to build the html files
- check for build errors or warnings, and view your additions in `docs/_build/html`

## acknowledgements from contributors
- what counts as a contribution?
- ticket? pr/mr?
- how are contributors acknowledged?
- contributor md file?
- who adds the name to the contributor? suggest code reviewer on approval of MR/PR
- #TODO provide citable repo link?
6 changes: 3 additions & 3 deletions README.rst
Original file line number Diff line number Diff line change
Expand Up @@ -2,18 +2,18 @@
pygom - ODE modelling in Python
===============================

|Build status| |Github actions| |Documentation Status| |pypi version| |licence|
|Build status| |Github actions| |Documentation Status| |pypi version| |licence| |Jupyter Book Badge|

.. |pypi version| image:: https://img.shields.io/pypi/v/pygom.svg
:target: https://pypi.python.org/pypi/pygom
.. |Build status| image:: https://travis-ci.org/PublicHealthEngland/pygom.svg?branch=master
:target: https://travis-ci.org/PublicHealthEngland/pygom
.. |Documentation Status| image:: https://readthedocs.org/projects/pygom/badge/?version=master
:target: https://pygom.readthedocs.io/en/master/?badge=master
.. |licence| image:: https://img.shields.io/pypi/l/pygom?color=green :alt: PyPI - License
:target: https://raw.githubusercontent.com/PublicHealthEngland/pygom/master/LICENSE.txt
.. |Github actions| image:: https://github.com/PublicHealthEngland/pygom/workflows/pygom/badge.svg
:target: https://github.com/PublicHealthEngland/pygom/actions/
.. |Jupyter Book Badge| image:: https://jupyterbook.org/badge.svg
:target: https://hwilliams-phe.github.io/pygom/intro.html

A generic framework for ode models, specifically compartmental type problems.

Expand Down
4 changes: 3 additions & 1 deletion conda-env.yml
Original file line number Diff line number Diff line change
Expand Up @@ -10,4 +10,6 @@ dependencies:
- sympy
- graphviz
- cython
# - pip: []
- pip
-pip:
- -r requirements.txt
Loading

0 comments on commit 24fabc3

Please sign in to comment.