From b777eb19e25240520b5122de299d9ee270c76017 Mon Sep 17 00:00:00 2001 From: Filipe Brandenburger Date: Wed, 27 Aug 2014 09:08:04 -0700 Subject: [PATCH] Add additional ldflags constants for Kubernetes versioning Now it is possible to push these variables through ldflags: - gitMajor - gitMinor - gitVersion (from latest annotated tag, output of git describe) - gitCommit (renamed commitFromGit, intended to have the full sha1) - gitTreeState (either "clean" or "dirty") These are spawned into its separate source file, since they are meant to be updated separately when a new version is released. Also use the notation vX.Y+ for when git information is not present. (This is consistent with the kernel build, e.g. Linux 3.15+ means its version is >= 3.15 and < 3.16.) v2: Added comments to the individual fields in pkg/version/base.go Tested: - Built it and checked the -version output: $ hack/build-go.sh $ output/go/bin/kubelet -version Kubernetes version 0.1+, build c328679ef8aa Signed-off-by: Filipe Brandenburger --- hack/build-go.sh | 2 +- pkg/version/base.go | 41 +++++++++++++++++++++++++++++++++++++++++ pkg/version/version.go | 22 ++++++++++++---------- 3 files changed, 54 insertions(+), 11 deletions(-) create mode 100644 pkg/version/base.go diff --git a/hack/build-go.sh b/hack/build-go.sh index dfcdafadbc4..9c6411a2e25 100755 --- a/hack/build-go.sh +++ b/hack/build-go.sh @@ -45,4 +45,4 @@ done # our cluster deploy. If we add more command line options to our standard build # we'll want to duplicate them there. As we move to distributing pre- built # binaries we can eliminate this duplication. -go install -ldflags "-X github.com/GoogleCloudPlatform/kubernetes/pkg/version.commitFromGit '${version}'" "${binaries[@]}" +go install -ldflags "-X github.com/GoogleCloudPlatform/kubernetes/pkg/version.gitCommit '${version}'" "${binaries[@]}" diff --git a/pkg/version/base.go b/pkg/version/base.go new file mode 100644 index 00000000000..184b011c816 --- /dev/null +++ b/pkg/version/base.go @@ -0,0 +1,41 @@ +/* +Copyright 2014 Google Inc. All rights reserved. + +Licensed under the Apache License, Version 2.0 (the "License"); +you may not use this file except in compliance with the License. +You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + +Unless required by applicable law or agreed to in writing, software +distributed under the License is distributed on an "AS IS" BASIS, +WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +See the License for the specific language governing permissions and +limitations under the License. +*/ + +package version + +// Base version information. +// +// This is the fallback data used when version information from git is not +// provided via go ldflags. It provides an approximation of the Kubernetes +// version for ad-hoc builds (e.g. `go build`) that cannot get the version +// information from git. +// +// The "+" in the version info indicates that fact, and it means the current +// build is from a version greater or equal to that version. +// (e.g. v0.7+ means version >= 0.7 and < 0.8) +// +// When releasing a new Kubernetes version, this file should be updated to +// reflect the new version, and then a git annotated tag (using format vX.Y +// where X == Major version and Y == Minor version) should be created to point +// to the commit that updates pkg/version/base.go + +var ( + gitMajor string = "0" // major version, always numeric + gitMinor string = "1+" // minor version, numeric possibly followed by "+" + gitVersion string = "v0.1+" // version from git, output of $(git describe) + gitCommit string = "" // sha1 from git, output of $(git rev-parse HEAD) + gitTreeState string = "not a git tree" // state of git tree, either "clean" or "dirty" +) diff --git a/pkg/version/version.go b/pkg/version/version.go index b44b7a185e1..b9af7cae42d 100644 --- a/pkg/version/version.go +++ b/pkg/version/version.go @@ -20,26 +20,28 @@ import ( "fmt" ) -// commitFromGit is a constant representing the source version that -// generated this build. It should be set during build via -ldflags. -var commitFromGit string - // Info contains versioning information. // TODO: Add []string of api versions supported? It's still unclear // how we'll want to distribute that information. type Info struct { - Major string `json:"major" yaml:"major"` - Minor string `json:"minor" yaml:"minor"` - GitCommit string `json:"gitCommit" yaml:"gitCommit"` + Major string `json:"major" yaml:"major"` + Minor string `json:"minor" yaml:"minor"` + GitVersion string `json:"gitVersion" yaml:"gitVersion"` + GitCommit string `json:"gitCommit" yaml:"gitCommit"` + GitTreeState string `json:"gitTreeState" yaml:"gitTreeState"` } // Get returns the overall codebase version. It's for detecting // what code a binary was built from. func Get() Info { + // These variables typically come from -ldflags settings and in + // their absence fallback to the settings in pkg/version/base.go return Info{ - Major: "0", - Minor: "1", - GitCommit: commitFromGit, + Major: gitMajor, + Minor: gitMinor, + GitVersion: gitVersion, + GitCommit: gitCommit, + GitTreeState: gitTreeState, } }