2020-03-20 22:22:21 -07:00
# Release Process
2021-05-12 19:10:56 -04:00
## Semantic Convention Generation
If a new version of the OpenTelemetry Specification has been released it will be necessary to generate a new
semantic convention package from the YAML definitions in the specification repository. There is a utility in
`internal/tools/semconv-gen` that can be used to generate the `semconv` package. This will ideally be done
shortly after the specification release is tagged, but it is also good practice to ensure that current conventions
are current before creating a release tag.
There are currently two categories of semantic conventions that must be generated, `resource` and `trace` .
```
cd internal/tools/semconv-gen
go run generate.go -i /path/to/specification/repo/semantic_conventions/resource
go run generate.go -i /path/to/specification/repo/semantic_conventions/trace
```
Using default values for all options other than `input` will result in using the `template.j2` template to
generate `resource.go` and `trace.go` in `/path/to/otelgo/repo/semconv` .
2020-03-20 22:22:21 -07:00
## Pre-Release
2020-07-31 10:08:50 -07:00
Update go.mod for submodules to depend on the new release which will happen in the next step.
1. Run the pre-release script. It creates a branch `pre_release_<new tag>` that will contain all release changes.
2020-03-20 22:22:21 -07:00
```
2020-05-26 11:35:34 -07:00
./pre_release.sh -t < new tag >
2020-07-13 13:09:59 -07:00
```
2. Verify the changes.
```
2021-02-04 11:13:25 -08:00
git diff main
2020-07-13 13:09:59 -07:00
```
2020-07-31 10:08:50 -07:00
This should have changed the version for all modules to be `<new tag>` .
2020-07-13 13:09:59 -07:00
2020-07-31 10:08:50 -07:00
3. Update the [Changelog ](./CHANGELOG.md ).
- Make sure all relevant changes for this release are included and are in language that non-contributors to the project can understand.
To verify this, you can look directly at the commits since the `<last tag>` .
```
git --no-pager log --pretty=oneline "< last tag > ..HEAD"
```
- Move all the `Unreleased` changes into a new section following the title scheme (`[<new tag>] - <date of release>` ).
- Update all the appropriate links at the bottom.
2020-03-20 22:22:21 -07:00
2020-07-31 10:08:50 -07:00
4. Push the changes to upstream and create a Pull Request on GitHub.
Be sure to include the curated changes from the [Changelog ](./CHANGELOG.md ) in the description.
2020-07-13 13:09:59 -07:00
2020-03-20 22:22:21 -07:00
## Tag
2020-07-31 10:08:50 -07:00
Once the Pull Request with all the version changes has been approved and merged it is time to tag the merged commit.
***IMPORTANT***: It is critical you use the same tag that you used in the Pre-Release step!
Failure to do so will leave things in a broken state.
***IMPORTANT***: [There is currently no way to remove an incorrectly tagged version of a Go module ](https://github.com/golang/go/issues/34189 ).
It is critical you make sure the version you push upstream is correct.
[Failure to do so will lead to minor emergencies and tough to work around ](https://github.com/open-telemetry/opentelemetry-go/issues/331 ).
2021-02-04 11:13:25 -08:00
1. Run the tag.sh script using the `<commit-hash>` of the commit on the main branch for the merged Pull Request.
2020-07-13 13:09:59 -07:00
```
./tag.sh < new tag > < commit-hash >
```
2020-07-31 10:08:50 -07:00
2. Push tags to the upstream remote (not your fork: `github.com/open-telemetry/opentelemetry-go.git` ).
Make sure you push all sub-modules as well.
2020-03-20 22:22:21 -07:00
```
git push upstream < new tag >
git push upstream < submodules-path / new tag >
2020-07-13 13:09:59 -07:00
...
2020-03-20 22:22:21 -07:00
```
## Release
2020-07-31 10:08:50 -07:00
Finally create a Release for the new `<new tag>` on GitHub.
The release body should include all the release notes from the Changelog for this release.
Additionally, the `tag.sh` script generates commit logs since last release which can be used to supplement the release notes.
2020-03-30 13:10:18 -07:00
## Verify Examples
2020-07-31 10:08:50 -07:00
After releasing verify that examples build outside of the repository.
2020-03-30 13:10:18 -07:00
```
./verify_examples.sh
```
2020-07-31 10:08:50 -07:00
The script copies examples into a different directory removes any `replace` declarations in `go.mod` and builds them.
This ensures they build with the published release, not the local copy.
2020-08-05 09:01:00 -07:00
2021-04-27 14:33:18 +00:00
## Post-Release
### Contrib Repository
2020-08-05 09:01:00 -07:00
2021-02-04 11:13:25 -08:00
Once verified be sure to [make a release for the `contrib` repository ](https://github.com/open-telemetry/opentelemetry-go-contrib/blob/main/RELEASING.md ) that uses this release.
2021-04-27 14:33:18 +00:00
### Website Documentation
Update [the documentation ](./website_docs ) for [the OpenTelemetry website ](https://opentelemetry.io/docs/go/ ).
Importantly, bump any package versions referenced to be the latest one you just released and ensure all code examples still compile and are accurate.