Difference between revisions of "Release Process"

From Einstein Toolkit Documentation
Jump to: navigation, search
(turn branch creation into a script)
(bugs in branch creation script)
Line 96: Line 96:
 
   git checkout -b $ET_RELEASE
 
   git checkout -b $ET_RELEASE
 
   git tag ${ET_RELEASE}_v0
 
   git tag ${ET_RELEASE}_v0
   git push -t --set-upstream origin $ET_RELEASE
+
   git push --tags --set-upstream origin $ET_RELEASE
 
   if git remote get-url origin | grep cactuscode ; then
 
   if git remote get-url origin | grep cactuscode ; then
 
     git branch $CCTK_VERSION
 
     git branch $CCTK_VERSION
 
     git tag ${CCTK_VERSION}_v0
 
     git tag ${CCTK_VERSION}_v0
     git push -t --set-upstream origin $CCTK_VERSION
+
     git push --tags --set-upstream origin $CCTK_VERSION
 
   fi
 
   fi
 
   cd - >/dev/null
 
   cd - >/dev/null

Revision as of 20:36, 27 May 2020

Release Process

This page describes the release process in some detail. Getting a release out of the door without embarrassing oversights requires a bit more planning and care than one would like.

TODO: reformat this page as a checklist which can be marked up for each release as each item is addressed

Long-term planning

A few months or weeks before the release:

  • Decide it is time to make another release
  • form a release coordination team
    • a release coordinator
    • a release coordinator assistant, who may be the release coordinator for the next release
    • the former release coordinator to help out
  • Choose features which are going to be included, and those which won't be included
  • Choose a tentative date
  • Begin discussions on the mailing list, reminding people to look at test cases, review patches etc.

Two months before the release

  • Set up a wiki planning page for the release
  • Review thorns for code quality, documentation, test cases
    • Ask for review volunteers, assign tasks to people
    • Remove new features without reviewer from list of new features
  • Decide on a thorn list
  • Choose a concrete date

One months before the release

  • Ask for example runner volunteers, assign tasks to people
  • Update einsteinttoolkit.bib with requested and suggested citations for all thorns in thorn list
  • Decide on a list of release-critical systems
  • Collect list of new features, newsworthy items, and acknowledgements for release announcement on wiki
  • Announce date publicly

Two weeks before the release

  • feature freeze, no more new features accepted
  • verify that gallery runs and example parfiles still work with new release
  • contact contributors and example runners about permanent (contributors) and one-off (example runners) inclusion in the ET author list
  • announce final member list of release team:
    • release coordinator(s)
    • test runner(s)
    • gallery example runner(s)
    • reviewer(s)
    • anyone putting in work specifically for the release

One or two days before the release

  • Have a telecon with the release team, discuss (and modify if necessary) release process and responsibilities
  • Get a list of all repositories that are involved (including repositories for tools such as GetComponents)
  • Publicly declare a freeze on all involved thorns and tools
  • Ensure that any manually-generated files are consistent
    • regenerate McLachlan, WeylScal4 and EinsteinExact from their source with the current version of Kranc
    • generate the Cactus configure script
    • generate the Cactus loop macros etc
    • generate UsersGuide, ReferenceManual and MaintGuide pdf files
  • Test all thorns on all systems, collect status reports on wiki
  • verify that new users tutorial still works
  • Update release planning wiki page with peoples', thorns', and systems' statuses
  • Set up a (smaller) technical release team who will be available all day on the day of the release
  • Draft release announcement

The release

  • Have the technical release team meet in the same room (brick, EVO, chat, phone)
  • Briefly re-check status of thorns and machines
  • Possibly disable all outside write access to all critical repositories
  • update version information:
    • update version information in flesh/Makefile in the CCTK_VERSION_XXX variables
    • update version information in flesh/doc/latex.sty in the \cactustitlepage command
    • Update tutorials on web sites (update version numbers, urls), searching for ET_YYYY_MM finds them all
    • Update simfactory.org https://svn.cct.lsu.edu/repos/numrel/simfactory2/www/
  • CREATE THE RELEASE BRANCH
    • svn: svn copy https://<repository-server>/<repository-path>/trunk https://<repository-server>/<repository-path>/branches/ET_2011_05
    • darcs: clone the repository, appending a suffix to the name
    • git: git checkout -b ET_2011_05 ; git push --set-upstream origin ET_2011_05
  • Create a release branch in master git repo at https://bitbucket.org/einsteintoolkit/einsteintoolkit via:
export ET_RELEASE=ET_XXXX_YY
git checkout -b $ET_RELEASE
sed -i "s/master/$ET_RELEASE/" .gitmodules
git add .gitmodules
git submodule foreach bash -c "git fetch ; git checkout origin/$ET_RELEASE"
git commit -am "Create release branch for $ET_RELEASE"
  • Note that for each repo one must create
    • A new ET branch ET_YYYY_MM
    • A new ET tag ET_YYYY_MM_v0
    • A new Cactus branch Cactus_4.X.0
    • A new Cactus tag Cactus_4.X.0_v0
#!/bin/bash
export ET_RELEASE=ET_XXXX_YY
export CCTK_VERSION=Cactus_4.X.0
set -x -e
for repo in */.git ; do
  cd $repo/..
  pwd
  git checkout -b $ET_RELEASE
  git tag ${ET_RELEASE}_v0
  git push --tags --set-upstream origin $ET_RELEASE
  if git remote get-url origin | grep cactuscode ; then
    git branch $CCTK_VERSION
    git tag ${CCTK_VERSION}_v0
    git push --tags --set-upstream origin $CCTK_VERSION
  fi
  cd - >/dev/null
done
  • Possibly update version numbers in stable/development branches
  • Update component lists to point to new stable version
  • Check out release branch on all systems, re-run all quick tests
  • Update documentation on web sites (set up fresh copies of pdfs/htmls)
  • Update documenation and examples of simfactory and Kranc to refer to the current release
  • Re-enable write access to all repositories
  • Finalise release announcement
  • Ensure email does not go past column 72 to support old email clients.
  • Send the announcement to the release team to ensure that the email client and/or server does not scramble the text in any way.
  • ANNOUNCE: users@einsteintoolkit.org, {news|users}@cactuscode.org, Jennifer Claudet <jennifer@cct.lsu.edu> for AllCCT, http://hyperspace.uni-frankfurt.de/, http://astro-sim.org/, HPCWire
    • Keywords used on hyperspace: Einstein Toolkit, numerical relativity, cactus, carpet, software
    • In the URL section, put the html link.
    • No manual breaks or non-ascii characters.
    • Post as a news item.
  • Add news item to the main page of einsteintoolkit.org.
  • To update cactuscode.org: "svn checkout https://svn.cactuscode.org/www" After modifying, visit http://cactuscode.org/x to make changes live.
  • To update simfactory.org: 'svn checkout https://svn.cct.lsu.edu/repos/numrel/simfactory2/www' and modify

After the release

  • Watch mailing lists for problem reports
  • Use released version to repeat a few production simulations
  • Update this page with new lessons learned

Helpful Tools

This section collects a handful of useful commands that may become critical to guarantee the quality of the release. The descriptions below are quite technical and intended for the developers and maintainers only.

Technical Details

On einsteintoolkit.org

  • ThornGuide.php is in /www/einstein/www/documentation
  • It draws on the autogenerated http doc files, which are found here:
 /var/www/einstein/documentation
 docker build --no-cache -f etk-website.docker -t stevenrbrandt/etk-website .
 docker push stevenrbrandt/etk-website


Other stuff

On https://stevenrbrandt@bitbucket.org/einsteintoolkit/www.git

  • Create new docs in about/releases/

On https://svn.cactuscode.org/www

News announcement to users@einsteintoolkit.org, users@cactuscode.org, news@cactuscode.org, allcct@cct.lsu.edu

Post to Ad, news on http://hyperspace.uni-frankfurt.de/

Post announcement to the Einstein Toolkit Facebook page.

Update and commit the changes to the thornlist in the manifest

   https://bitbucket.org/einsteintoolkit/manifest.git

Create the git tags and branches: ET_2018_02_v0, Cactus_4.4.0

  • in each git repo:
       git tag ET_2018_02_v0; git push origin ET_2018_02_v0
       git checkout -b ET_2018_02; git push origin ET_2018_02
  • use git fetch -t to get the latest tags.
  • Create svn tags and branches (no longer needed since ET_2019_03 "Proca")
 for i in BLAS LORENE GSL PETSc LAPACK FFTW3 pciutils  hwloc OpenBLAS MPI OpenCL HDF5 PAPI zlib libjpeg
 do
     cd /home/sbrandt/cactus/Cactus/arrangements/ExternalLibraries/$i
     svn copy https://svn.cactuscode.org/projects/ExternalLibraries/$i/trunk \
         https://svn.cactuscode.org/projects/ExternalLibraries/$i/tags/ET_2018_02_v0 \
         -m "Tagging release ET_2018_02"
done
for i in BLAS LORENE GSL PETSc LAPACK FFTW3 pciutils  hwloc OpenBLAS MPI OpenCL HDF5 PAPI zlib libjpeg
do
    cd /home/sbrandt/cactus/Cactus/arrangements/ExternalLibraries/$i
    svn copy https://svn.cactuscode.org/projects/ExternalLibraries/$i/trunk \
        https://svn.cactuscode.org/projects/ExternalLibraries/$i/branches/ET_2018_02 \
        -m "New branch for release ET_2018_02"
done

Creating and working with git branches

Some basic git commands to create and work with branches:

Check in your local repository which branch you are in:

%git branch
* master

Check the branches of your project in the remote repository:

%git branch -r
  origin/HEAD
  origin/master

Create a new branch called test:

%git checkout -b test
Switched to a new branch "test"
%git branch  
  master
* test

Work on files in that branch:

%vi test.txt

Verify the status of files you modified in that branch:

%git status
 # On branch test
 # Untracked files:
 #   (use "git add <file>..." to include in what will be committed)
 #
 #       test.txt
 nothing added to commit but untracked files present (use "git add" to track)

Add the file(s) edited to the git stage area:

%git add test.txt
%git status
 # On branch test
 # Changes to be committed:
 #   (use "git reset HEAD <file>..." to unstage)
 #
 #       new file:   test.txt
 #

Commit your changes to your local repository:

%git commit -m "test file only"
 Created commit 14644af: test file only
  1 files changed, 1 insertions(+), 0 deletions(-)
  create mode 100644 test.txt

Now you want to push these changes to a remote repository that you have writing permission:

%git push origin test

Note however that, unless git is configured so, your local branch of "test" does not track any changes committed by others to the remote branch "test". Maybe the simplest way to proceed then is just to delete your local branch:

%git branch -D test
Deleted branch test.

and checkout the remote branch you just created but letting git know you want to track remote changes to that branch as well:

%git checkout --track -b test origin/test

You may want to see how two branches differ or how your modifications of the branch compare to the HEAD of the branch, for example. Suppose you just added the test.txt file to the staged git area called the index. To know the difference between the index and the HEAD, essentially what would be committed if 'git commit' is issued, just use git diff as follows:

%git diff  --cached
 diff --git a/test.txt b/test.txt
 new file mode 100644
 index 0000000..373c7b0
 --- /dev/null
 +++ b/test.txt
 @@ -0,0 +1 @@
 +Hello, world!