Releasing a new Cloud Foundry buildpack version
Page last updated:
You can update and release a new version of a Cloud Foundry (CF) buildpack through the CF Buildpacks Team Concourse pipeline. Concourse is a continuous integration (CI) tool for software development teams. This process is used by the CF Buildpacks Team and other CF buildpack development teams. You can use this process as a model for using Concourse to build and release new versions of your own buildpacks.
The Concourse pipelines for Cloud Foundry buildpacks are located in the buildpacks-ci GitHub repository.
Releasing a new buildpack version
To release a new buildpack version, do the following:
- Download the - buildpacks-cirepository:- $ git clone https://github.com/cloudfoundry/buildpacks-ci.git
- From the buildpack directory, check out the - developbranch of the buildpack:- $ cd /system/path/to/buildpack $ git checkout develop 
- Make sure you have the most current version of the repository: - $ git pull -r 
- Run - bumpto update the version in the buildpack repository:- $ /system/path/to/buildpacks-ci/scripts/bump 
- Modify the - CHANGELOGfile manually to condense recent commits into relevant changes. For more information, see Modify Changelogs.
- Add and commit your changes: - $ git add VERSION CHANGELOG $ git commit -m "Bump version to $(cat VERSION) [{insert story #}]"
- Push your changes to the - developbranch:- $ git push origin develop 
Concourse buildpack workflow
If buildpacks-ci is not deployed to Concourse, manually add
a Git tag to the buildpack, and mark the tag as a release on GitHub.
If buildpacks-ci is deployed to Concourse, the buildpack update passes through the following life cycle:
- Concourse starts the - buildpack-to-masterjob in the pipeline for the updated buildpack. This job merges into the master or main branch of the buildpack.
- The - detect-new-buildpack-and-upload-artifactsjob starts in the pipeline for the updated buildpack. This job creates a cached and uncached buildpack, and uploads them to an AWS S3 bucket.
- The - specs-lts-masterand- specs-edge-masterjobs start and run the buildpack test suite, and the buildpack-specific tests of the Buildpack Runtime Acceptance Tests (BRATS).
- If you use Pivotal Tracker, paste the links for the - specs-edge-masterand- specs-lts-masterbuilds in the related buildpack release story, and deliver the story.
- Your project manager can manually start the - buildpack-to-githubjob on Concourse as part of the acceptance process. This releases the buildpack to GitHub.
- After the buildpack has been released to GitHub, the - cf-releasepipeline is started using the manual initiation of the- recreate-bosh-litejob in that pipeline. If the new buildpack has been released to GitHub, the CF that is deployed for testing in the- cf-releasepipeline is tested against that new buildpack.
- After the - catsjob has successfully completed, your project manager can include the new buildpacks in the- cf-releaserepository and create the new buildpack BOSH release by manually starting the- ship-itjob.
If errors occur during this workflow, you might need to remove unwanted tags. For more information, see Handle Unwanted Tags.
Modifying changelogs
The Ruby buildpack changelog shows an example layout, and content of a changelog. In general, changelogs follow these conventions:
- Reference public tracker stories whenever possible.
- Exclude unnecessary files.
- Combine and condense commit statements into individual stories containing valuable changes.
Handling unwanted tags
If you encounter problems with the commit that contains the new version, change the target of the release tag by performing the following:
- Verify that the repository is in a valid state and is building successfully.
- Remove the tag from your local repository and from GitHub.
- Start a build. The pipeline build script tags the build again if it is successful.