2.0 KiB
		
	
	
	
	
	
	
	
			
		
		
	
	Release
Release cycle
Currently we don't release regularly. Whenever we think it makes sense to release a new version we do it, but we aim to do a new release every month. You might want to ask in our Slack channel external-dns when the next release will come out.
Versioning convention
These are the conventions that we will be using for releases following 0.7.6:
- 
Patch version should be updated if we need to merge bugfixes, e.g. provider a does need a fix in order make updates working again. I would see updating or improving documentation here. 
- 
Minor version should be updated if new features are implemented in existing providers or new provider get introduced. 
- 
Major version should be upgraded if we introduce breaking changes. 
How to release a new image
Prerequisite
We use https://github.com/cli/cli to automate the release process. Please install it according to the official documentation.
You must be an official maintainer of the project to be able to do a release.
Steps
- Run scripts/releaser.shto create a new GitHub release.
- The step above will trigger the Kubernetes based CI/CD system Prow. Verify that a new image was built and uploaded to gcr.io/k8s-staging-external-dns/external-dns.
- Create a PR in the k8s.io repo (see https://github.com/kubernetes/k8s.io/pull/540 for reference) by taking the current staging image using the sha256 digest. Once the PR is merged, the image will be live with the corresponding tag specified in the PR.
- Verify that the image is pullable with the given tag (i.e. v0.7.5).
- Branch out from the default branch and run scripts/kustomize-version-udapter.shto update the image tag used in the kustomization.yaml.
- Create a PR with the kustomize change.
- Once the PR is merged, all is done :-)