Skip to content

Latest commit

 

History

History
75 lines (47 loc) · 2 KB

RELEASE.md

File metadata and controls

75 lines (47 loc) · 2 KB

Release process for changelist

Introduction

Example version number

  • 1.8rc0.dev0 # development version of first 1.8 release candidate
  • 1.8rc0 # first 1.8 release candidate
  • 1.8rc1.dev0 # development version of second 1.8 release candidate
  • 1.8 # 1.8 release
  • 1.9rc0.dev0 # development version of first 1.9 release candidate

Process

  • Set release variables:

    export VERSION=<version number>
    export PREVIOUS=<previous version number>
    export ORG="scientific-python"
    export REPO="changelist"
    export LOG="CHANGELOG.md"
    
  • Update main branch

    git switch main
    git pull origin main
    

    where origin is the name of the github.com:scientific-python/changelist repository

  • Autogenerate release notes

    changelist ${ORG}/${REPO} v${PREVIOUS} main --version ${VERSION} --out ${VERSION}.md
    
  • Put the output of the above command at the top of CHANGELOG.md

    cat ${VERSION}.md | cat - ${LOG} > temp && mv temp ${LOG}
    
  • Update version in pyproject.toml.

  • Commit changes:

    git add pyproject.toml ${LOG}
    git commit -m "Designate ${VERSION} release"
    
  • Tag the release in git:

    git tag -s v${VERSION} -m "signed ${VERSION} tag"
    

    If you do not have a gpg key, use -u instead; it is important for Debian packaging that the tags are annotated

  • Push the new meta-data to github:

    git push --tags origin main
    
  • Create release from tag

    - go to https://github.com/scientific-python/changelist/releases/new?tag=v${VERSION}
    - add v${VERSION} for the `Release title`
    - paste contents (or upload) of ${VERSION}.md in the `Describe this release section`
    - if pre-release check the box labelled `Set as a pre-release`
    
  • Update https://github.com/scientific-python/changelist/milestones:

    - close old milestone
    - ensure new milestone exists (perhaps setting due date)
    
  • Update version in pyproject.toml.

  • Commit changes:

    git add pyproject.toml
    git commit -m 'Bump version'
    git push origin main