gson-comments/ReleaseProcess.md

6.8 KiB

Gson Release Process

The following is a step-by-step procedure for releasing a new version of Google-Gson.

  1. Go through all open bugs and identify which will be fixed in this release. Mark all others with an appropriate release tag. Identify duplicates, and close the bugs that will never be fixed. Fix all bugs for the release, and mark them fixed.

  2. Ensure all changelists are code-reviewed and have +1

  3. cd gson to the parent directory; ensure there are no open files and all changes are committed.

  4. Run mvn release:clean

  5. Start the release: mvn release:prepare

    • Answer questions: usually the defaults are fine. Try to follow Semantic Versioning when choosing the release version number.
    • This will do a full build, change version from -SNAPSHOT to the released version, commit and create the tags. It will then change the version to -SNAPSHOT for the next release.
  6. Complete the release: mvn release:perform

  7. Log in to Nexus repository manager at Sonatype and close the staging repository for Gson.

  8. Download and sanity check all downloads. Do not skip this step! Once you release the staging repository, there is no going back. It will get synced with Maven Central and you will not be able to update or delete anything. Your only recourse will be to release a new version of Gson and hope that no one uses the old one.

  9. Release the staging repository for Gson. Gson will now get synced to Maven Central with-in the next hour. For issues consult Sonatype Guide.

  10. Create a GitHub release for the new version. You can let GitHub automatically generate the description for the release, but you should edit it manually to point out the most important changes and potentially incompatible changes.

  11. Update version references in (version might be referenced multiple times):

    Note: When using the Maven Release Plugin as described above, these version references should have been replaced automatically, but verify this manually nonetheless to be on the safe side.

  12. Optional: Create a post on the Gson Discussion Forum.

  13. Optional: Update the release version in Wikipedia and update the current "stable" release.

Important: When aborting a release / rolling back release preparations, make sure to also revert all changes to files which were done during the release (e.g. automatic replacement of version references).

Configuring a machine for deployment to Sonatype Repository

This section was borrowed heavily from Doclava release process.

  1. Install/Configure GPG following this guide.
  2. Create encrypted passwords.
  3. Create ~/.m2/settings.xml similar to as described in Doclava release process.
  4. Now for deploying a snapshot repository, use mvn deploy.

Getting Maven Publishing Privileges

See OSSRH Publish Guide.

Testing Maven release workflow locally

The following describes how to perform the steps of the release locally to verify that they work as desired.

Warning: Be careful with this, these steps might be outdated or incomplete. Doublecheck that you are working on a copy of your local Gson Git repository and make sure you have followed all steps. To be safe you can also temporarily turn off your internet connection to avoid accidentally pushing changes to the real remote Git or Maven repository.
As an alternative to the steps described below you can instead perform a dry run, though this might not behave identical to a real release.

  1. Make a copy of your local Gson Git repository and only work with that copy

  2. Make sure you are on the main branch

  3. Create a temp directory outside the Gson directory
    In the following steps this will be called #gson-remote-temp#; replace this with the actual absolute file path of the directory, using only forward slashes. For example under Windows C:\my-dir becomes C:/my-dir.

  4. Create the directory #gson-remote-temp#/git-repo

  5. In that directory run

    git init --bare --initial-branch=main .
    
  6. Create the directory #gson-remote-temp#/maven-repo

  7. Edit the root pom.xml of Gson

    1. Change the <developerConnection> to

      scm:git:file:///#gson-remote-temp#/git-repo
      
    2. Change the <url> of the <distributionManagement> to

      file:///#gson-remote-temp#/maven-repo
      
    3. If you don't want to use GPG, remove the maven-gpg-plugin entry from the 'release' profile.
      There is also an entry under <pluginManagement>; you can remove that as well.

  8. Commit the changes using Git

  9. Change the remote repository of the Git project

    git remote set-url origin file:///#gson-remote-temp#/git-repo
    
  10. Push the changes

    git push origin main
    

Now you can perform the steps of the release:

  1. mvn release:clean
    
  2. mvn release:prepare
    
  3. mvn release:perform
    
  4. Verify that #gson-remote-temp#/git-repo and #gson-remote-temp#/maven-repo contain all the desired changes

  5. Afterwards delete all Gson files under ${user.home}/.m2/repository/com/google/code/gson which have been installed in your local Maven repository during the release.
    Otherwise Maven might not download the real Gson artifacts with these version numbers, once they are released.

Running Benchmarks or Tests on Android

  • Download vogar

  • Put adb on your $PATH and run:

    vogar --benchmark --classpath gson.jar path/to/Benchmark.java
    

For example, here is how to run the CollectionsDeserializationBenchmark:

export ANDROID_HOME=~/apps/android-sdk-mac_x86
export PATH=$PATH:$ANDROID_HOME/platform-tools/:$ANDROID_HOME/android-sdk-mac_x86/tools/
$VOGAR_HOME/bin/vogar \
    --benchmark \
    --sourcepath ../gson/src/main/java/ \
    src/main/java/com/google/gson/metrics/CollectionsDeserializationBenchmark.java \
    -- \
    --vm "app_process -Xgc:noconcurrent,app_process"