Difference between revisions of "Release Process"
|  (→Other stuff) |  (make mkdir fail on existing release once more) | ||
| (8 intermediate revisions by 2 users not shown) | |||
| Line 106: | Line 106: | ||
| === update developers.txt === | === update developers.txt === | ||
| − | Inside https://bitbucket.org/einsteintoolkit/www/src/master/ , you will find a developers.txt file, which needs to be updated with any new developers for this release. Any developers who helped with the last release but have not yet contributed code to the Toolkit need to be removed, and likewise any new folks who contributed to this release need to be added. | + | Inside https://bitbucket.org/einsteintoolkit/www/src/master/ , you will find a developers.txt file, which needs to be updated with any new developers for this release. Any developers who helped with the last release but have not yet contributed code to the Toolkit need to be removed, and likewise any new folks who contributed to this release need to be added. You can find them by looking for "FOO release team" for the FOO release. | 
| There is a script below under "Other Stuff" for getting the contributors from the git repos. | There is a script below under "Other Stuff" for getting the contributors from the git repos. | ||
| Line 253: | Line 253: | ||
| === regenerate files === | === regenerate files === | ||
| * regenerate McLachlan, WeylScal4, CTThorns, and EinsteinExact from their source with the current version of Kranc by running <code>make -j NJOBS</code> in their respective <code>m</code> directory. | * regenerate McLachlan, WeylScal4, CTThorns, and EinsteinExact from their source with the current version of Kranc by running <code>make -j NJOBS</code> in their respective <code>m</code> directory. | ||
| − | * check that BaikalVaccum and Baikal can be regenerated  | + | * check that BaikalVaccum and Baikal can be regenerated following their ReadMe instructions. Move into the wvuthorns directory and run <code>make -f Makefile-baikal_thorns</code>. Note: this requires the clang-format python package. | 
| * Next run the following script, which   | * Next run the following script, which   | ||
| ** generates the Cactus configure script by running <code>autoconf2.13</code> in <code>lib/make</code> | ** generates the Cactus configure script by running <code>autoconf2.13</code> in <code>lib/make</code> | ||
| Line 286: | Line 286: | ||
| set -x -e | set -x -e | ||
| for repo in */.git ; do | for repo in */.git ; do | ||
| + |   if [[ "${repo%/.git}" == "SKIP_REPO" ]]; then | ||
| + |     echo "Skipping SKIP_REPO" | ||
| + |     continue | ||
| + |   fi | ||
|    cd $repo/.. |    cd $repo/.. | ||
|    pwd |    pwd | ||
| Line 302: | Line 306: | ||
|    fi |    fi | ||
|    repo_name=$(basename $PWD) |    repo_name=$(basename $PWD) | ||
| − |    git checkout -b $ET_RELEASE | + |    if git show-ref --verify --quiet refs/heads/$ET_RELEASE; then | 
| + |     git checkout $ET_RELEASE | ||
| + |   else | ||
| + |     git checkout -b $ET_RELEASE | ||
| + |   fi | ||
|    if [ $repo_name = manifest ] ; then |    if [ $repo_name = manifest ] ; then | ||
|      sed -i "/!DEFINE  *COMPONENTLIST_TARGET/a \\\\n!DEFINE ET_RELEASE = $ET_RELEASE" einsteintoolkit.th |      sed -i "/!DEFINE  *COMPONENTLIST_TARGET/a \\\\n!DEFINE ET_RELEASE = $ET_RELEASE" einsteintoolkit.th | ||
| Line 310: | Line 318: | ||
|      git commit -m 'einsteintoolkit.th: use release branch' |      git commit -m 'einsteintoolkit.th: use release branch' | ||
|    fi |    fi | ||
| − |    git tag ${ET_RELEASE}_v0 | + |    if git show-ref --verify --quiet refs/tags/${ET_RELEASE}_v0; then | 
| + |     echo "Tag ${ET_RELEASE}_v0 already exists" | ||
| + |   else | ||
| + |     git tag ${ET_RELEASE}_v0 | ||
| + |   fi | ||
|    git push --tags --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 | + |      if git show-ref --verify --quiet refs/tags/${CCTK_VERSION}_v0; then | 
| + |       echo "Tag ${CCTK_VERSION}_v0 already exists" | ||
| + |     else | ||
| + |       git tag ${CCTK_VERSION}_v0 | ||
| + |     fi | ||
|      git push --tags --set-upstream origin $CCTK_VERSION |      git push --tags --set-upstream origin $CCTK_VERSION | ||
|    fi |    fi | ||
| Line 335: | Line 351: | ||
| export EDITOR=vim | export EDITOR=vim | ||
| − | export PREVIOUS_ET_RELEASE= | + | export PREVIOUS_ET_RELEASE=ET_2024_11 | 
| − | export ET_RELEASE= | + | export ET_RELEASE=ET_2025_05 | 
| − | export PREVIOUS_ET_RELEASE_CODENAME= | + | export PREVIOUS_ET_RELEASE_CODENAME=Cannon | 
| − | export ET_RELEASE_CODENAME= | + | export ET_RELEASE_CODENAME=Kruskal | 
| − | export ET_RELEASE_CODENAME_FULL=" | + | export ET_RELEASE_CODENAME_FULL="Martin D. Kruskal" | 
| − | export PREVIOUS_ET_RELEASE_URL="https://en.wikipedia.org/wiki/ | + | export PREVIOUS_ET_RELEASE_URL="https://en.wikipedia.org/wiki/Annie_Jump_Cannon" | 
| − | export ET_RELEASE_URL="https://en.wikipedia.org/wiki/ | + | export ET_RELEASE_URL="https://en.wikipedia.org/wiki/Martin_David_Kruskal" | 
| − | export ET_RELEASE_DATE=" | + | export ET_RELEASE_DATE="May 29th, 2025" | 
| − | export ET_RELEASE_DATE_ISO= | + | export ET_RELEASE_DATE_ISO=2025-05-29 | 
| ALL_FILES=$(git grep -l "\($PREVIOUS_ET_RELEASE\|$PREVIOUS_ET_RELEASE_CODENAME\)"  | grep -v 'about/releases/' | grep -vF past-releases.html | grep -vF publications/2013_MHD/index.php | grep -vF developers. | grep -vF members.txt | grep -vF mp.html) | ALL_FILES=$(git grep -l "\($PREVIOUS_ET_RELEASE\|$PREVIOUS_ET_RELEASE_CODENAME\)"  | grep -v 'about/releases/' | grep -vF past-releases.html | grep -vF publications/2013_MHD/index.php | grep -vF developers. | grep -vF members.txt | grep -vF mp.html) | ||
| Line 410: | Line 426: | ||
| set -e -x | set -e -x | ||
| − | PREVIOUS_ET_ITER=twenty- | + | PREVIOUS_ET_ITER=twenty-ninth | 
| − | ET_ITER= | + | ET_ITER=thirtieth | 
| − | PREVIOUS_CACTUS_VERSION=4. | + | PREVIOUS_CACTUS_VERSION=4.17.0 | 
| − | CACTUS_VERSION=4. | + | CACTUS_VERSION=4.18.0 | 
| − | PREVIOUS_ET_WIKIPEDIA=" | + | PREVIOUS_ET_WIKIPEDIA="Annie_Jump_Cannon" | 
| − | ET_WIKIPEDIA=" | + | ET_WIKIPEDIA="Martin_D._Kruskal" | 
| − | PREVIOUS_ET_NAME=" | + | PREVIOUS_ET_NAME="Cannon" | 
| − | ET_NAME=" | + | ET_NAME="Kruskal" | 
| − | PREVIOUS_ET_RELEASE= | + | PREVIOUS_ET_RELEASE=ET_2024_11 | 
| − | ET_RELEASE= | + | ET_RELEASE=ET_2025_05 | 
| ET_DATE="$(date +"%B %d, %Y")" | ET_DATE="$(date +"%B %d, %Y")" | ||
| Line 432: | Line 448: | ||
| # keep the mkdir below to so that it fails if the output directories already | # keep the mkdir below to so that it fails if the output directories already | ||
| # exist | # exist | ||
| + | mkdir $ET_RELEASE | ||
| − | |||
| cp -a $PREVIOUS_ET_RELEASE/* $ET_RELEASE/ | cp -a $PREVIOUS_ET_RELEASE/* $ET_RELEASE/ | ||
| sed -i "s!/$PREVIOUS_ET_WIKIPEDIA!/$ET_WIKIPEDIA!g" $ET_RELEASE/index.md | sed -i "s!/$PREVIOUS_ET_WIKIPEDIA!/$ET_WIKIPEDIA!g" $ET_RELEASE/index.md | ||
Latest revision as of 16:49, 28 May 2025
Contents
- 1 Release Process
- 1.1 Timeline for a release and estimated time required
- 1.2 Helpful tools and notes
- 1.2.1 add gallery runners
- 1.2.2 add testsuite runners
- 1.2.3 update developers.txt
- 1.2.4 drafting Zenodo entry
- 1.2.5 final Zenodo entry
- 1.2.6 update version information
- 1.2.7 regenerate files
- 1.2.8 create branches
- 1.2.9 update websites and online documentation
- 1.2.10 release anouncement issues
- 1.2.11 Other stuff
- 1.2.12 Emails to send to contributors and gallery runners
 
 
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.
Timeline for a release and estimated time required
- Form a release coordination team (6 months) (part of ET calls)
- a release coordinator
- a release coordinator assistant, who may be the release coordinator for the next release
- the former release coordinator to help out
- test runner(s) who will run the testsuites on the list of supported machines
- gallery runners for gallery examples
- final list may include others contributing directly to the release process
 
- Come up with release timeline (by translating the last release timeline forward in time), see (5 months) (30 minutes), see https://docs.einsteintoolkit.org/et-docs/Release_Details#Schedule_for_ET_2020_05
- Release coordinator needs write access to the following repos (or must arrange all needed changes with a repo maintainer)
- Frequently remind participants of timeline (part of ET calls)
- Begin discussions on the mailing list, reminding people to look at test cases, review patches etc. (5 minutes per week)
 
- Choose features which are going to be included, and those which won't be included (4 months)
- ask for review volunteers, assign tasks to people (part of ET calls) e.g. https://docs.einsteintoolkit.org/et-docs/Meeting_agenda#2020-09-10
- create tickets for each proposed item on https://trac.einsteintoolkit.org eg. https://bitbucket.org/einsteintoolkit/tickets/issues/2416
- Decide on a list of release-critical compute systems eg XSEDE, LCCF, DOE, PRACE: http://einsteintoolkit.org/testsuite_results/index.php
- get accounts for test runners
 
 
- Drive review of thorns for code quality, documentation, test cases (continuously)
- Include positively reviewed and voted on items in main ET repositories
- Remove new features without reviewer or negatively reviewed from list of new features
- Frequently remind participants of timeline
 
- Start testing on release-critical compute systems (2 months) (30 minutes per week per cluster to compile, run, check, upload)
- initially test to make sure clusters can still build code
- test code as they become positively reviewed (code is present in master before final positive review)
- report on test failures
- assign found bugs to volunteers
 
- Release preparation I (4 weeks)
- Announce feature freeze based on currently positively reviewed components
- Collect list of new features, newsworthy items, and acknowledgements for release announcement on wiki (there’s a script in the wiki to help with this) (45 minutes)
- Create Zenodo item (notes) (1 hour)
- Send to maintainers@einsteintoolkit.org for review re typos etc.
- Include in "do you want to be included" email to contributors.
 
- Contact contributors and release team about permanent (contributors) and one-off (release team) inclusion in the ET author list (10 minutes of work per author to poke and prod them to respond). Include maintainers@einsteintoolkit.org in cc to have a record.
- 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
 
 
 
 
- Draft release announcement (1 hour)
- send to maintainers@einsteintoolkit.org for review re typos etc.
 
- Announce release date publicly
 
- Draft release announcement (1 hour)
- Release preparation II (1 week), detailed list of items and partial scripts at end of text
- Finalize announcement draft (1 hour)
- Send to maintainers@einsteintoolkit.org for review re typos etc.
 
- Update einsteintoolkit.bib (https://bitbucket.org/einsteintoolkit/manifest/src/master/) with
- Update or add requested and suggested citations for all ET components in thorn list (10 minutes).
- Latest release info and DOI (from Zenodo entry above)
- move requested-for for main ET cite (Zenodo)
 
- Update version information in Makefile, the documentation tex files and Baikal documentation.tex file script (15 minutes)
- Regenerate all auto-generated files (30 minutes of work, plus time to wait for Kranc)
- Create release branch and tag for all ET codes (30 minutes)
- Update websites in a branch (2 hours)
- EinsteinToolkit.org (https://docs.einsteintoolkit.org/et-docs/Editing_the_Einstein_Toolkit_website ; be sure to update the main page; then about/releases/ET_202X_YZ_announcement.md; then from that directory run `mk_release_announcements.py ET_202X_YZ_announcement.md` [you'll need to `pip install markdown` for this to work]; then be sure to `git add` and commit the new files.)
- CactusCode.org (https://github.com/einsteintoolkit/www.cactuscode.org, see below for a script.
- Simfactory.org (https://github.com/einsteintoolkit/simfactory2-www/ make life using https://simfactory.org/update.php)
- CactusTutorial.ipynb (https://github.com/einsteintoolkit/jupyter-et.git)
- update docker image for tutorial server script, but do not yet push
 
 
- Finalize announcement draft (1 hour)
- The release (0 days)
- make all updated branches live (30 min)
- push tutorial server docker image to Dockerhub (only Erik, Steve, Roland, Ian can do so)
- announce on users@einsteintoolkit.org, news@cactuscode.org (5 min)
- http://hyperspace.uni-frankfurt.de/ based on previous release announcement (15 min)
- update Wikipedia Cactus entry https://en.wikipedia.org/wiki/Cactus_Framework (5 min)
- Run the testsuite using the release code on all supported machines (30 min per cluster)
- Update https://docs.einsteintoolkit.org/et-docs/Release_Process with lessons learned (30 minutes)
 
Helpful tools and notes
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.
add gallery runners
Gallery runners should be mentioned in their respective gallery example's ticket and should have the ticket assigned to them. This requires that they are a member of the Einstein Toolkit bitbucket organization.
- they must be invited to it using their email address on: https://bitbucket.org/einsteintoolkit/workspace/settings/groups
- they should be made members of the the "All Members" and "gallery runners" groups. The former to be assigned the ticket, the latter to be able to upload files to the website repository and edit the web-pages
- find the gallery ticket and use the "Edit" button to assign users
- gallery examples should be run using the "master" branch of the toolkit, that will become the release branch, of manifest and thornlist
- results should be archived in a tar archive as shown on https://bitbucket.org/einsteintoolkit/www/downloads/ and the archive name should include year, month and day of month YYYYMMDD following the pattern visible in the existing tar files. On macOS make sure to not include __MACOSXa folder. This is most easily achieved by using the command lineziptool and not a GUI tool or Finder (to be verified)
- some archives are large and special tools are needed to upload them, this is described in the ticket for the example
- after updating the archive, clone the website repo https://bitbucket.org/einsteintoolkit/www/src, edit the gallery page to point to the new archive file and update the "last run" line. Don't forget to update and add any images and plots you have regenerated. Verify the change by opening the html file in a local browsers. Commit and push to nmaster.
add testsuite runners
Testsuite runners should be mentioned in Release Details next to heir assigned machine.
Instructions on how to test and upload are on Testsuite Machines.
Test runners should be added to the "testsuite runners" group in the Einstein Toolkit bitbucket organization.
update developers.txt
Inside https://bitbucket.org/einsteintoolkit/www/src/master/ , you will find a developers.txt file, which needs to be updated with any new developers for this release. Any developers who helped with the last release but have not yet contributed code to the Toolkit need to be removed, and likewise any new folks who contributed to this release need to be added. You can find them by looking for "FOO release team" for the FOO release.
There is a script below under "Other Stuff" for getting the contributors from the git repos.
After updating, run
developers.py
Next, update zenodo.py. It contains the hard-coded information in between the EDIT BELOW and EDIT ABOVE tags.
release_team = [ "Zachariah B. Etienne", "Roland Haas", "Steven R. Brandt", "William E. Gabella", "Peter Diener", "Atul Kedia", "Miguel Gracia", ... ] contributers = [ "Roland Haas", "Steven R. Brandt", ... ] et_release = "ET_2021_05" et_release_codename = "Lorentz" et_description = ...
Publish to the sandbox (following the steps below). Once that is done and reviewed, it can be published without --sandbox.
drafting Zenodo entry
# get Steve Brandt's personal access token for zenodo.org # create your own personal access token for sandbox.zenodo.org: # https://sandbox.zenodo.org/account/settings/applications/tokens/new/ export ZENODO_ACCESS=STEVES_ZENODO_ACCESS_TOKEN export SANDBOX_ZENODO_ACCESS=YOUR_ZENODO_SANDBOX_ACCESS_TOKEN # note down ID of "Einstein Toolkit" (will change each release) ZENODO_PREVIOUS_ID=$(python3 ./zenodo.py --list | perl -n -e '/(\d*) The Einstein Toolkit/ && print ($1) && exit 0') # This will generate Definition.md and zupload.py (metadata) rm Definition.md zupload.py python3 ./zenodo.py --id $ZENODO_PREVIOUS_ID --generate # recreate current release in sandbox, note that zenodo.py will use # SANDBOX_ZENODO_ACCESS token and sanbox.zenodo.org when --sandbox is used. # note down ID of the deposit ZENODO_SANDBOX_ID=$(python3 ./zenodo.py --sandbox --create zupload.py | perl -n -e '/(\d*) The Einstein Toolkit/ && print ($1) && exit 0') # publish current release in sandbox python3 ./zenodo.py --sandbox --id $ZENODO_SANDBOX_ID --deposit Definition.md python3 ./zenodo.py --sandbox --id $ZENODO_SANDBOX_ID --publish # now we make the new release # Edit the lines in zenodo.py that are between the Edit Below/Edit Above comments. # This includes the release, the code name, the release team, etc. vi zenodo.py # This will generate Definition.md and zupload.py (metadata) rm Definition.md zupload.py python3 ./zenodo.py --sandbox --id $ZENODO_SANDBOX_ID --generate # create a new version in sandbox # and note down its id ZENODO_SANDBOX_ID=$(python3 ./zenodo.py --sandbox --id $ZENODO_SANDBOX_ID --newversion | perl -n -e '/(\d*) The Einstein Toolkit/ && print ($1) && exit 0') # upload updated metadata (zenodo.py) python3 ./zenodo.py --sandbox --id $ZENODO_SANDBOX_ID --upload # deposit updated dummy file python3 ./zenodo.py --sandbox --id $ZENODO_SANDBOX_ID --deposit Definition.md # publish new version (cannot be undone) python3 ./zenodo.py --sandbox --id $ZENODO_SANDBOX_ID --publish # create a new version in real Zenodo but *do not* publish (yet) # and not down its id ZENODO_ID=$(python3 ./zenodo.py --id $ZENODO_ID --newversion | perl -n -e '/(\d*) The Einstein Toolkit/ && print ($1) && exit 0') echo "Zenodo ID is: $ZENODO_ID." echo "You write down this ID." # generate metadata for actual Zenodo (different DOI!) rm Definition.md zupload.py python3 ./zenodo.py --id $ZENODO_ID --generate # upload updated metadata (zenodo.py) python3 ./zenodo.py --id $ZENODO_ID --upload # deposit updated dummy file python3 ./zenodo.py --id $ZENODO_ID --deposit Definition.md # re-download and check what we think we deposited mv Definition.md Definition.md.bak python3 ./zenodo.py --id $ZENODO_ID --retrieve Definition.md diff --report-identical-files Definition.md.bak Definition.md # display prereserved DOI of draft submission python3 ./zenodo.py --id $ZENODO_ID --show-doi
Send the Zenodo entry from the sandbox to maintainers@einsteintoolkit.org for proofreading, include in "do you want to be included" email to contributors.
final Zenodo entry
This replicates the latter steps of the draft to create a new entry on the real Zenodo site. Do so *only* after the draft has been reviewed since it cannot be undone.
export ZENODO_ACCESS=STEVES_ZENODO_ACCESS_TOKEN # note down ID of newest (topmost) "Einstein Toolkit" draft, # this should be identical to the one you wrote down earlier ZENODO_ID=$(python3 ./zenodo.py --list-draft | perl -n -e '/(\d*) The Einstein Toolkit/ && print ($1) && exit 0') # update metadata in case developers.txt has been changed python3 ./zenodo.py --id $ZENODO_ID --upload # publish new version (cannot be undone) python3 ./zenodo.py --id $ZENODO_ID --publish
At this point you can download the bibtex entry from the Zenodo link. With a few minor edits it should be suitable for inserting into the einsteintoolkit.bib in the manifest.
update version information
- update version information in flesh/Makefilein theCCTK_VERSION_XXXvariables
- update version information in  flesh/doc/latex/cactus.styin the\cactustitlepagecommand
export CCTK_VERSION=Cactus_4.X.0 CCTK_VERSION_MINOR=$(echo $CCTK_VERSION | cut -f2 -d.) sed -i "s/CCTK_VERSION_MINOR = .*/CCTK_VERSION_MINOR = $CCTK_VERSION_MINOR/" Makefile sed -i 's/\\cactustitlepage}\[4\]\[4\..*\]/\\cactustitlepage}[4][4.'$CCTK_VERSION_MINOR']/' doc/latex/cactus.sty git add Makefile doc/latex/cactus.sty git commit -m 'Cactus: update version in information in Makefile and docs'
- regenerate the documentation PDF files
make UsersGuide ReferenceManual MaintGuide cd doc # commit changed files git commit -a -m 'Cactus: regenerate documentation' || true
regenerate files
- regenerate McLachlan, WeylScal4, CTThorns, and EinsteinExact from their source with the current version of Kranc by running make -j NJOBSin their respectivemdirectory.
- check that BaikalVaccum and Baikal can be regenerated following their ReadMe instructions. Move into the wvuthorns directory and run make -f Makefile-baikal_thorns. Note: this requires the clang-format python package.
- Next run the following script, which
- generates the Cactus configure script by running autoconf2.13inlib/make
- generates the Cactus loop macros by running perl cctk_Loop.h.plinsrc/include
- generates UsersGuide, ReferenceManual and MaintGuide pdf files by running make UsersGuide ReferenceManual MaintGuide
 
- generates the Cactus configure script by running 
cd lib/make autoconf2.13 # commit changed files git commit -a -m 'Cactus: regenerate configure' || true cd ../../src/include perl cctk_Loop.h.pl # commit changed files git commit -a -m 'Cactus: regenerate cctk_Loop.h' || true
create branches
- Important! Before this step, add the new bibtex entry to einsteintoolkit.bib in https://bitbucket.org/einsteintoolkit/manifest.git
- This relies on the bibtex entry from zenodo, so make the zenodo entry first!
- The https://bitbucket.org/einsteintoolkit/manifest.git repo has a script called "utf8ToLaTeX.pl" to fix special characters in people's names
 
- Create release branches for all repositories in the ET
- A new ET branch ET_YYYY_MM
- A new ET tag ET_YYYY_MM_v0
- A new Cactus branch Cactus_4.X.0 if in CactusCode
- A new Cactus tag Cactus_4.X.0_v0 if in CactusCode
 
- Note: SelfForce-1D is not automatically downloaded with GetComponents, so the repo can either be manually cloned into the repos directory or the branch and tag can be made and pushed separately from the script
#!/bin/bash
# This script is run from inside the repos directory
export ET_RELEASE=ET_YYYY_MM
export CCTK_VERSION=Cactus_4.X.0
set -x -e
for repo in */.git ; do
  if [[ "${repo%/.git}" == "SKIP_REPO" ]]; then
    echo "Skipping SKIP_REPO"
    continue
  fi
  cd $repo/..
  pwd
  if git branch -a | grep -q origin/$ET_RELEASE ; then
    echo "Already pushed"
    cd - >/dev/null
    continue
  fi
  if ! grep -q 'fetch  *= *[+]refs/heads/[*]' .git/config ; then
    # unshallow in case --no-shallow was not passed to GetComponents
    if `git rev-parse --is-shallow-repository` ; then
      git fetch --unshallow
    fi
    git config remote.origin.fetch "+refs/heads/*:refs/remotes/origin/*"
    git fetch origin
  fi
  repo_name=$(basename $PWD)
  if git show-ref --verify --quiet refs/heads/$ET_RELEASE; then
    git checkout $ET_RELEASE
  else
    git checkout -b $ET_RELEASE
  fi
  if [ $repo_name = manifest ] ; then
    sed -i "/!DEFINE  *COMPONENTLIST_TARGET/a \\\\n!DEFINE ET_RELEASE = $ET_RELEASE" einsteintoolkit.th
    sed -i '/!URL/a \!REPO_BRANCH = $ET_RELEASE' einsteintoolkit.th
    sed -i 's!/trunk!/branches/$ET_RELEASE!' einsteintoolkit.th
    git add einsteintoolkit.th
    git commit -m 'einsteintoolkit.th: use release branch'
  fi
  if git show-ref --verify --quiet refs/tags/${ET_RELEASE}_v0; then
    echo "Tag ${ET_RELEASE}_v0 already exists"
  else
    git tag ${ET_RELEASE}_v0
  fi
  git push --tags --set-upstream origin $ET_RELEASE
  if git remote get-url origin | grep cactuscode ; then
    git branch $CCTK_VERSION
    if git show-ref --verify --quiet refs/tags/${CCTK_VERSION}_v0; then
      echo "Tag ${CCTK_VERSION}_v0 already exists"
    else
      git tag ${CCTK_VERSION}_v0
    fi
    git push --tags --set-upstream origin $CCTK_VERSION
  fi
  cd - >/dev/null
  sleep 5 # bitbucket enforces some rate limit on pushes its seems
done
- create a new version and milestone on https://bitbucket.org/einsteintoolkit/tickets/admin/issues/versions and https://bitbucket.org/einsteintoolkit/tickets/admin/issues/milestones
update websites and online documentation
https://docs.einsteintoolkit.org/et-docs/Editing_the_Einstein_Toolkit_website
- Update main ET web site (update version numbers, urls), searching for ET_YYYY_MMfinds them all
#!/bin/bash
set -e -x
export EDITOR=vim
export PREVIOUS_ET_RELEASE=ET_2024_11
export ET_RELEASE=ET_2025_05
export PREVIOUS_ET_RELEASE_CODENAME=Cannon
export ET_RELEASE_CODENAME=Kruskal
export ET_RELEASE_CODENAME_FULL="Martin D. Kruskal"
export PREVIOUS_ET_RELEASE_URL="https://en.wikipedia.org/wiki/Annie_Jump_Cannon"
export ET_RELEASE_URL="https://en.wikipedia.org/wiki/Martin_David_Kruskal"
export ET_RELEASE_DATE="May 29th, 2025"
export ET_RELEASE_DATE_ISO=2025-05-29
ALL_FILES=$(git grep -l "\($PREVIOUS_ET_RELEASE\|$PREVIOUS_ET_RELEASE_CODENAME\)"  | grep -v 'about/releases/' | grep -vF past-releases.html | grep -vF publications/2013_MHD/index.php | grep -vF developers. | grep -vF members.txt | grep -vF mp.html)
# update URL first since it tends to include the release codename
sed -i "s!$PREVIOUS_ET_RELEASE_URL!$ET_RELEASE_URL!g" index.html
# update release names
sed -i "s/$PREVIOUS_ET_RELEASE/$ET_RELEASE/g" $ALL_FILES
sed -i "s/$PREVIOUS_ET_RELEASE_CODENAME/$ET_RELEASE_CODENAME/g" $ALL_FILES
# release date
sed -i "s/[(]released on [^)]*[)]/(released on $ET_RELEASE_DATE)/g" download.html
# update past reelases, mark this one as most recent
# TODO: use something other than sed for this
sed -i -e '/List of Einstein Toolkit releases:/{n;b add_release}' -e 'b end' -e ':add_release;a\
          <li>'$ET_RELEASE' "'"$ET_RELEASE_CODENAME_FULL"'", <a href="about/releases/'$ET_RELEASE'_announcement.html">released '$ET_RELEASE_DATE_ISO'</a>\
          </li>' -e ':end' past-releases.html
# add news item to front page
$EDITOR index.html
git diff
git add $ALL_FILES past-releases.html download.html index.html
git commit -m "update to $ET_RELEASE"
echo 'Use git show and git commit --amend to correct mistakes'
- Update simfactory.org https://github.com/EinsteinToolkit/simfactory2-www.git
 
sed -i "s/$PREVIOUS_ET_RELEASE/$ET_RELEASE/g" simfactory/download/index.php
- update CactusTutorial.ipynb in https://github.com/einsteintoolkit/jupyter-et.git
 
export KUIBIT_RELEASE=... sed -i "s/$PREVIOUS_ET_RELEASE/$ET_RELEASE/g" CactusTutorial.ipynb sed -i "s/kuibit==[0-9.]*/kuibit==$KUIBIT_RELEASE/" CactusTutorial.ipynb
From the https://github.com/einsteintoolkit/jupyter-et repo, do the following
cd tutorial-server
sed -i "s/ENV ET_RELEASE.*/ENV ET_RELEASE ${ET_RELEASE}/" base.docker
sed -i "s/ENV KUIBIT_RELEASE.*/ENV KUIBIT_RELEASE ${KUIBIT_RELEASE}/" base.docker
git add base.docker
git commit -m "All changes for the $ET_RELEASE release"
touch variables.env
docker-compose -f docker-compose.base.yml build --no-cache --pull 2>&1 | tee docker-compose.base.log
docker-compose -f docker-compose.base.yml push
for c in notebook cilogon cyol ; do
    docker-compose -f docker-compose.$c.yml build 2>&1 | tee docker-compose.$c.log
    docker-compose -f docker-compose.$c.yml push
done
The tutorial server at https://etk.cct.lsu.edu checks for a new image once a day.
- To update cactuscode.org: git clone git@github.com:EinsteinToolkit/www.cactuscode.org.git
#!/bin/bash
set -e -x
PREVIOUS_ET_ITER=twenty-ninth
ET_ITER=thirtieth
PREVIOUS_CACTUS_VERSION=4.17.0
CACTUS_VERSION=4.18.0
PREVIOUS_ET_WIKIPEDIA="Annie_Jump_Cannon"
ET_WIKIPEDIA="Martin_D._Kruskal"
PREVIOUS_ET_NAME="Cannon"
ET_NAME="Kruskal"
PREVIOUS_ET_RELEASE=ET_2024_11
ET_RELEASE=ET_2025_05
ET_DATE="$(date +"%B %d, %Y")"
AUTHOR="$(git config --get user.name)"
cd media/news
# keep the mkdir below to so that it fails if the output directories already
# exist
mkdir $ET_RELEASE
cp -a $PREVIOUS_ET_RELEASE/* $ET_RELEASE/
sed -i "s!/$PREVIOUS_ET_WIKIPEDIA!/$ET_WIKIPEDIA!g" $ET_RELEASE/index.md
sed -i "s!$PREVIOUS_ET_NAME!$ET_NAME!g" $ET_RELEASE/index.md
sed -i "s!$PREVIOUS_ET_ITER!$ET_ITER!g" $ET_RELEASE/index.md
sed -i "s!^### .*!### $ET_DATE $AUTHOR!" $ET_RELEASE/index.md
mkdir -p cactus_$CACTUS_VERSION
cp -a cactus_$PREVIOUS_CACTUS_VERSION/* cactus_$CACTUS_VERSION/
sed -i "s!${PREVIOUS_CACTUS_VERSION//./[.]}!$CACTUS_VERSION!g;" cactus_$CACTUS_VERSION/index.md
sed -i "s!/$PREVIOUS_ET_WIKIPEDIA!/$ET_WIKIPEDIA!g" cactus_$CACTUS_VERSION/index.md
sed -i "s!$PREVIOUS_ET_NAME!$ET_NAME!g" cactus_$CACTUS_VERSION/index.md
sed -i "s!^### .*!### $ET_DATE $AUTHOR!" cactus_$CACTUS_VERSION/index.md
NEWS="$(<../../_data/news.yml)"
cat >../../_data/news.yml <<EOF
- date: "$ET_DATE"
  link: "$ET_RELEASE/index.html"
  title: 'Einstein Toolkit "$ET_NAME" Release'
- date: "$ET_DATE"
  link: "cactus_$CACTUS_VERSION/index.html"
  title: 'Cactus $CACTUS_VERSION Release'
$NEWS
EOF
git add ../../_data/news.yml $ET_RELEASE/index.md cactus_$CACTUS_VERSION/index.md
git commit -m "news: add $ET_RELEASE announcement"
- update Cactus Wikipedia entry https://en.wikipedia.org/wiki/Cactus_Framework
release anouncement issues
- Ensure email does not go past column 72 to support old email clients.
- Send the announcement to the release team and maintainers@einsteintoolkit.org to ensure that the email client and/or server does not scramble the text in any way.
- ANNOUNCE: users@einsteintoolkit.org, news@cactuscode.org, users@cactuscode.org
- ANNOUNCE: http://hyperspace.uni-frankfurt.de/
- 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.
- must be short enough to be acceptable: compare http://einsteintoolkit.org/about/releases/ET_2020_05_announcement.html and https://hyperspace.uni-frankfurt.de/2020/06/02/the-twentieth-release-of-the-einstein-toolkit-2/ . The hypersapce editor says that https://hyperspace.uni-frankfurt.de/2020/06/02/the-twentieth-release-of-the-einstein-toolkit-2/ is now of appropriate length.
 
Other stuff
Changes to announce
First grab the latest dev version:
curl -kLO https://raw.githubusercontent.com/gridaphobe/CRL/master/GetComponents chmod a+x GetComponents ./GetComponents --no-shallow --parallel --no-anonymous https://bitbucket.org/einsteintoolkit/manifest/raw/master/einsteintoolkit.th git clone git@bitbucket.org:peterdiener/selfforce-1d.git Cactus/repos/SelfForce-1D
Then in that directory, the following script may be helpful in figuring out what has changed since the last release:
#!/bin/bash
PREVRELEASEMONTH=05
PREVRELEASEYEAR=2024
FORMAT="%h %ae %an: %s"
####
TAG="ET_${PREVRELEASEYEAR}_${PREVRELEASEMONTH}_v0"
DATE="${PREVRELEASEMONTH}/01/${PREVRELEASEYEAR}"
echo -n > .people.txt
for i in repos/*/.git
do
  export GIT_DIR=$i
  DEFAULT_BRANCH=$(git symbolic-ref refs/remotes/origin/HEAD | sed 's@^refs/remotes/origin/@@')
  REPO_URL=$(git remote get-url origin | sed 's!git@!https://!;s!:\([^/]\)!/\1!;s![.]git$!!;')
  if [[ $REPO_URL == *bitbucket* ]]; then
    COMMIT_URL=$REPO_URL/commits/
  elif [[ $REPO_URL == *github* ]]; then
    COMMIT_URL=$REPO_URL/commit/
  else
    COMMIT_URL=$REPO_URL/
  fi
  echo "========================="
  echo "CHANGES FOR $(dirname $i) $COMMIT_URL"
  git fetch --tags 1>/dev/null 2>/dev/null
  git log --format="$FORMAT" ${TAG}..${DEFAULT_BRANCH} -- 2>/dev/null
  git log --format="%an %ae" ${TAG}..${DEFAULT_BRANCH} 2>/dev/null >> .people.txt
  E=$?
  if [ $E != 0 ]
  then
    # Pick your desired behavior in the absense of tags
    echo " >> TAG ${TAG} missing for repo, using date."
    git log --format="$FORMAT" $(git rev-list -n 1 --before="${DATE} 00:00" ${DEFAULT_BRANCH})..${DEFAULT_BRANCH} --
    git log --format="%an %ae" $(git rev-list -n 1 --before="${DATE} 00:00" ${DEFAULT_BRANCH})..${DEFAULT_BRANCH} -- >> .people.txt 2>/dev/null
    #echo " >> TAG ${TAG} missing for repo, assume it's a new contribution"
    #git log --format="$FORMAT" --
    #git log --format="%an %ae" -- >> .people.txt 2>/dev/null
  fi
done |& tee full.txt
sort -u < .people.txt > people.txt
rm .people.txt
cat people.txt
Note that when analyzing the output from the *nrpytutorial/* repo, you'll need to be careful to only check for changes to NRPyPN; all other changes are not ET related.
This misses changes in subversion repositories, currently only in ExternalLibraries which can be queried manually using svn log and usually contain very few changes.
This misses new repositories (or at best only considers recent changes to them).
Emails to send to contributors and gallery runners
Contributors
Dear $CONTRIBUTOR,
In preparation for the upcoming "$RELEASE" release of the Einstein Toolkit I am collecting information about all who contributed to this release of the Einstein Toolkit. All contributors will be listed as authors as shown in this draft
https://sandbox.zenodo.org/record/$ZENODO
You are shown as a contributor to $CODE in
$GIT_COMMIT_HASH_URL
Since you therefore contributed to this release, would you agree to be listed as an author in this and all future releases of the Einstein Toolkit?
If you agree to be listed I will add the information found here
https://www.einsteintoolkit.org/developers.html
to Zenodo.
Please let me or any of the other maintainers know, no later than $DEADLINE_DATE, if you agree to be included as an author and whether the information shown is correct. If there are additional persons that should be listed as authors, please let myself or one of the other maintainers know soon, so that they can be contacted.
Yours, $YOURNAME
To the main contributor (champion) send a request for citations
Dear $CHAMPION,
For each component the Einstein Toolkit keeps track of requested ("required") and suggested ("optional") citations that those who use the component should cite.
These are listed on:
https://www.einsteintoolkit.org/citation.html
and auto-generated from the main bibtex file (einsteintoolkit.bib) using the suggested-for and requested-for tags.
For you contributions, if you have any, please send me bibtex entries (in SPIRES style, see the beginning of
https://bitbucket.org/einsteintoolkit/manifest/raw/master/einsteintoolkit.bib
for the desired format) of any requested and suggested citations.
Typically we would suggest one requested citation and any number of suggested citations (eg for optional features or secondary citations).
Websites and Zenodo DOIs are fine, it does not have to be a published paper (though having a DOI would be good).
Yours, $YOURNAME
Release team
Dear $RELEASE_TEAM_MEMBER,
in preparation for the upcoming "$RELEASE" release of the Einstein Toolkit I am collecting information about the release team for this release of the Einstein Toolkit. All release team members will be listed as authors in
https://sandbox.zenodo.org/record/$ZENODO
Since you are a member of the release team, would you agree to be listed as an author in this release of the Einstein Toolkit?
If you agree to be listed I will add the information found here
https://www.einsteintoolkit.org/developers.html
to Zenodo.
Please let me or any of the other maintainers know, no later than $DEADLINE_DATE, if you agree to be included as an author and whether the information shown is correct. If there are additional persons that should be listed as authors, please let myself or one of the other maintainers know soon, so that they can be contacted.
Yours, $YOURNAME
