Add a Makefile to replace build.sh and test.sh.

pull/43/head
dlorenc 2016-05-04 14:29:13 -07:00
parent 638bb3e843
commit d8e2d8e2b7
5 changed files with 47 additions and 64 deletions

View File

@ -7,4 +7,4 @@ install:
- echo "Don't run anything."
# Run unit tests and linters.
script: ./test.sh
script: make test

43
Makefile Normal file
View File

@ -0,0 +1,43 @@
GO ?= go
GOOS ?= $(shell go env GOOS)
GOARCH ?= $(shell go env GOARCH)
BUILD_DIR ?= ./out
GOPATH := $(shell pwd)/.gopath
REPOPATH ?= k8s.io/minikube
.PHONY: clean
clean:
rm -rf $(GOPATH)
rm -rf $(BUILD_DIR)
.PHONY: gopath
gopath: clean
rm -rf $(GOPATH)
mkdir -p $(shell dirname $(GOPATH)/src/$(REPOPATH))
ln -s $(shell pwd) $(GOPATH)/src/$(REPOPATH)
.PHONY: minikube
minikube: minikube-$(GOOS)-$(GOARCH)
cp $(BUILD_DIR)/minikube-$(GOOS)-$(GOARCH) $(BUILD_DIR)/minikube
.PHONY: localkube
localkube: localkube-$(GOOS)-$(GOARCH)
cp $(BUILD_DIR)/localkube-$(GOOS)-$(GOARCH) $(BUILD_DIR)/localkube
.PHONY: minikube-$(GOOS)-$(GOARCH)
minikube-$(GOOS)-$(GOARCH): gopath
GOPATH=$(GOPATH) CGO_ENABLED=0 GOARCH=$(GOARCH) GOOS=$(GOOS) $(GO) build --installsuffix cgo -a -o $(BUILD_DIR)/minikube-$(GOOS)-$(GOARCH) ./cmd/minikube
.PHONY: localkube-$(GOOS)-$(GOARCH)
localkube-$(GOOS)-$(GOARCH): gopath
GOARCH=$(GOARCH) GOOS=$(GOOS) $(GO) build -o $(BUILD_DIR)/localkube-$(GOOS)-$(GOARCH) -i --ldflags '-extldflags "-static" --s -w' ./cmd/localkube
integration: minikube
$(GO) test -v ./integration --tags=integration
.PHONY: test
test: gopath
for TEST in $$(find -name "*.go" | grep -v vendor | grep -v integration | grep _test.go | cut -d/ -f2- | sed 's|/\w*.go||g' | uniq); do \
echo $$TEST; \
$(GO) test -v $(REPOPATH)/$${TEST}; \
done

View File

@ -35,7 +35,7 @@ For more information about minikube, see the [proposal](https://github.com/kuber
## Build Instructions
```shell
./build.sh
make minikube
```
## Run Instructions
@ -72,7 +72,7 @@ See [CONTRIBUTING.md](CONTRIBUTING.md) for an overview of how to send pull reque
Unit tests are run on Travis before code is merged. To run as part of a development cycle:
```shell
./test.sh
make test
```
#### Integration Tests
@ -81,6 +81,5 @@ Integration tests are currently run manually.
To run them, build the binary and run the tests:
```shell
./build.sh
go test ./integration --tags=integration
make integration
```

View File

@ -1,33 +0,0 @@
#!/bin/bash
# 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.
cd "$( dirname "${BASH_SOURCE[0]}" )"
REPO_PATH="k8s.io/minikube"
BUILD_DIR="${PWD}/out"
export GOPATH=${PWD}/.gopath
export GO15VENDOREXPERIMENT=1
export OS=${OS:-$(go env GOOS)}
export ARCH=${ARCH:-$(go env GOARCH)}
rm -f ${GOPATH}/src/${REPO_PATH}
mkdir -p $(dirname ${GOPATH}/src/${REPO_PATH})
ln -s ${PWD} $GOPATH/src/${REPO_PATH}
CGO_ENABLED=0 GOARCH=${ARCH} GOOS=${OS} go build --installsuffix cgo -a -o ${BUILD_DIR}/minikube k8s.io/minikube/cmd/minikube
# Build minimal localkube binary
GOARCH=${ARCH} GOOS=${OS} go build -o ${BUILD_DIR}/localkube -i --ldflags '-extldflags "-static" --s -w' k8s.io/minikube/cmd/localkube

26
test.sh
View File

@ -1,26 +0,0 @@
#!/bin/bash
# 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.
# First, build the binary
source ./build.sh
# Then run all test files
for TEST in $(find -name "*.go" | grep -v vendor | grep -v integration | grep _test.go | cut -d/ -f2- | sed 's|/\w*.go||g' | uniq); do
echo $TEST
go test -v ${REPO_PATH}/${TEST}
done
# Check gofmt
diff -u <(echo -n) <(gofmt -l -s . | grep -v vendor)