diff --git a/Makefile b/Makefile index 23f787a65531..7828d24a5af3 100644 --- a/Makefile +++ b/Makefile @@ -499,6 +499,8 @@ release-manifests: $(RELEASE_DIR) $(KUSTOMIZE) ## Builds the manifests to publis cat $(RELEASE_DIR)/bootstrap-components.yaml >> $(RELEASE_DIR)/cluster-api-components.yaml echo "---" >> $(RELEASE_DIR)/cluster-api-components.yaml cat $(RELEASE_DIR)/control-plane-components.yaml >> $(RELEASE_DIR)/cluster-api-components.yaml + # Add metadata to the release artifacts + cp metadata.yaml $(RELEASE_DIR)/metadata.yaml .PHONY: release-manifests-dev release-manifests-dev: ## Builds the development manifests and copies them in the release folder diff --git a/cmd/clusterctl/hack/create-local-repository.py b/cmd/clusterctl/hack/create-local-repository.py index 69cbef14b2c6..1e2610ef3d8f 100755 --- a/cmd/clusterctl/hack/create-local-repository.py +++ b/cmd/clusterctl/hack/create-local-repository.py @@ -44,6 +44,7 @@ import subprocess import os from distutils.dir_util import copy_tree +from distutils.file_util import copy_file import errno import sys @@ -52,24 +53,24 @@ providers = { 'cluster-api': { 'componentsFile': 'core-components.yaml', - 'nextVersion': 'v0.3.8', + 'nextVersion': 'v0.4.0', 'type': 'CoreProvider', }, 'bootstrap-kubeadm': { 'componentsFile': 'bootstrap-components.yaml', - 'nextVersion': 'v0.3.8', + 'nextVersion': 'v0.4.0', 'type': 'BootstrapProvider', 'configFolder': 'bootstrap/kubeadm/config/default', }, 'control-plane-kubeadm': { 'componentsFile': 'control-plane-components.yaml', - 'nextVersion': 'v0.3.8', + 'nextVersion': 'v0.4.0', 'type': 'ControlPlaneProvider', 'configFolder': 'controlplane/kubeadm/config/default', }, 'infrastructure-docker': { 'componentsFile': 'infrastructure-components.yaml', - 'nextVersion': 'v0.3.8', + 'nextVersion': 'v0.4.0', 'type': 'InfrastructureProvider', 'configFolder': 'test/infrastructure/docker/config/default', }, @@ -116,7 +117,7 @@ def get_repository_folder(): home = get_home() return os.path.join(home, '.cluster-api', 'dev-repository') -def write_local_repository(provider, version, components_file, components_yaml): +def write_local_repository(provider, version, components_file, components_yaml, metadata_file): try: repository_folder = get_repository_folder() provider_folder = os.path.join(repository_folder, provider, version) @@ -130,6 +131,8 @@ def write_local_repository(provider, version, components_file, components_yaml): f.write(components_yaml) f.close() + copy_file(metadata_file, provider_folder) + if provider == "infrastructure-docker": copy_tree("test/infrastructure/docker/templates", provider_folder) @@ -148,6 +151,7 @@ def create_local_repositories(): repo = p.get('repo', '.') config_folder = p.get('configFolder', 'config/default') + metadata_file = repo+'/metadata.yaml' next_version = p.get('nextVersion') assert next_version is not None, 'invalid configuration for provider {}: please provide nextVersion value'.format(provider) @@ -159,7 +163,7 @@ def create_local_repositories(): assert components_file is not None, 'invalid configuration for provider {}: please provide componentsFile value'.format(provider) components_yaml = execCmd(['kustomize', 'build', os.path.join(repo, config_folder)]) - components_path = write_local_repository(provider, next_version, components_file, components_yaml) + components_path = write_local_repository(provider, next_version, components_file, components_yaml, metadata_file) yield name, type, next_version, components_path diff --git a/metadata.yaml b/metadata.yaml new file mode 100644 index 000000000000..69306d3bef40 --- /dev/null +++ b/metadata.yaml @@ -0,0 +1,13 @@ +# maps release series of major.minor to cluster-api contract version +# the contract version may change between minor or major versions, but *not* +# between patch versions. +# +# update this file only when a new major or minor version is released +apiVersion: clusterctl.cluster.x-k8s.io/v1alpha3 +releaseSeries: + - major: 0 + minor: 4 + contract: v1alpha4 + - major: 0 + minor: 3 + contract: v1alpha3