-
Notifications
You must be signed in to change notification settings - Fork 119
/
releasing_a_new_buildpack_version.html.md.erb
97 lines (69 loc) · 4.54 KB
/
releasing_a_new_buildpack_version.html.md.erb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
---
title: Releasing a new Cloud Foundry buildpack version
owner: Buildpacks
---
You can update and release a new version of a Cloud Foundry (CF) buildpack through the
CF Buildpacks Team Concourse [pipeline](https://buildpacks.ci.cf-app.com/). 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](http://github.com/cloudfoundry/buildpacks-ci) GitHub repository.
## <a id="releasing-a-new-buildpack-version"></a>Releasing a new buildpack version
To release a new buildpack version, do the following:
1. Download the `buildpacks-ci` repository:
<pre class="terminal">
$ git clone https<span>:</span>//github.com/cloudfoundry/buildpacks-ci.git
</pre>
2. From the buildpack directory, check out the `develop` branch of the buildpack:
<pre class="terminal">
$ cd /system/path/to/buildpack
$ git checkout develop
</pre>
3. Make sure you have the most current version of the repository:
<pre class="terminal">
$ git pull -r
</pre>
4. Run `bump` to update the version in the buildpack repository:
<pre class="terminal">
$ /system/path/to/buildpacks-ci/scripts/bump
</pre>
5. Modify the `CHANGELOG` file manually to condense recent commits
into relevant changes. For more information, see [Modify Changelogs](#changelogs).
6. Add and commit your changes:
<pre class="terminal">
$ git add VERSION CHANGELOG
$ git commit -m "Bump version to $(cat VERSION) [{insert story #}]"
</pre>
7. Push your changes to the `develop` branch:
<pre class="terminal">
$ git push origin develop
</pre>
## <a id="concourse"></a>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:
1. Concourse starts the `buildpack-to-master` job in the pipeline for the updated buildpack. This job merges into the master or main branch of the buildpack.
1. The `detect-new-buildpack-and-upload-artifacts` job starts in the pipeline for the updated buildpack. This job creates a cached and uncached buildpack, and uploads them to an AWS S3 bucket.
1. The `specs-lts-master` and `specs-edge-master` jobs start and
run the buildpack test suite, and the buildpack-specific tests of the [Buildpack Runtime Acceptance Tests (BRATS)](https://github.com/cloudfoundry/brats).
1. If you use [Pivotal Tracker](https://www.pivotaltracker.com), paste the links for
the `specs-edge-master` and `specs-lts-master` builds in the related buildpack release story,
and deliver the story.
1. Your project manager can manually start the `buildpack-to-github` job on Concourse as part
of the acceptance process. This releases the buildpack to GitHub.
1. After the buildpack has been released to GitHub, the `cf-release` pipeline is started using the manual initiation of
the `recreate-bosh-lite` job in that pipeline. If the new buildpack has been released to GitHub, the CF that
is deployed for testing in the `cf-release` pipeline is tested against that new buildpack.
1. After the `cats` job has successfully completed, your project manager can include the new buildpacks in the `cf-release` repository and create the new buildpack BOSH release by manually starting the `ship-it` job.
If errors occur during this workflow, you might need to remove unwanted tags. For more information, see <a href="#dealing-with-unwanted-tags">Handle Unwanted Tags</a>.
## <a id="changelogs"></a>Modifying changelogs
The [Ruby buildpack changelog](https://github.com/cloudfoundry/ruby-buildpack/blob/master/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.
## <a id="dealing-with-unwanted-tags"></a>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:
1. Verify that the repository is in a valid state and is building successfully.
1. Remove the tag from your local repository and from GitHub.
1. Start a build. The pipeline build script tags the build again if it is successful.