Merge pull request #81 from dlorenc/version

Set the k8s version strings during build.
pull/90/head
Lucas Käldström 2016-05-22 13:29:53 +03:00
commit 2cee5ca3c9
2 changed files with 54 additions and 2 deletions

View File

@ -25,6 +25,9 @@ endif
REPOPATH ?= k8s.io/minikube
export GO15VENDOREXPERIMENT=1
# Set the version information in kubernetes.
LD_FLAGS = "-s -w $(shell python hack/get_k8s_version.py)"
clean:
rm -rf $(GOPATH)
rm -rf $(BUILD_DIR)
@ -40,9 +43,9 @@ out/minikube: out/minikube-$(GOOS)-$(GOARCH)
out/localkube: $(LOCALKUBEFILES)
$(MKGOPATH)
ifeq ($(GOOS),linux)
CGO_ENABLED=1 go build -ldflags="-s" -o $(BUILD_DIR)/localkube ./cmd/localkube
CGO_ENABLED=1 go build -ldflags=$(LD_FLAGS) -o $(BUILD_DIR)/localkube ./cmd/localkube
else
docker run -w /go/src/k8s.io/minikube -e IN_DOCKER=1 -v $(shell pwd):/go/src/k8s.io/minikube golang:1.6 make out/localkube
docker run -w /go/src/$(REPOPATH) -e IN_DOCKER=1 -v $(shell pwd):/go/src/$(REPOPATH) golang:1.6 make out/localkube
endif
out/minikube-$(GOOS)-$(GOARCH): $(MINIKUBEFILES) pkg/minikube/cluster/localkubecontents.go

49
hack/get_k8s_version.py Normal file
View File

@ -0,0 +1,49 @@
"""
Copyright 2016 The Kubernetes Authors 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.
"""
"This package gets the LD flags used to set the version of kubernetes."
import json
import subprocess
K8S_PACKAGE = 'k8s.io/kubernetes/'
X_ARG_BASE = '-X k8s.io/minikube/vendor/k8s.io/kubernetes/pkg/version.'
def get_rev():
with open('./Godeps/Godeps.json') as f:
contents = json.load(f)
for dep in contents['Deps']:
if dep['ImportPath'].startswith(K8S_PACKAGE):
return 'gitCommit=%s' % dep['Rev']
def get_version():
# Update when vendor/k8s.io/kubernetes is updated.
return 'gitVersion=v1.3.0-alpha.3-838+ba170aa191f8c7'
def get_tree_state():
git_status = subprocess.check_output(['git', 'status', '--porcelain'])
if git_status:
result = 'dirty'
else :
result = 'clean'
return 'gitTreeState=%s' % result
def main():
args = [get_rev(), get_version(), get_tree_state()]
return ' '.join([X_ARG_BASE + arg for arg in args])
if __name__ == '__main__':
print main()