mirror of
				https://github.com/k3s-io/kubernetes.git
				synced 2025-11-03 23:40:03 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			169 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			Makefile
		
	
	
	
	
	
			
		
		
	
	
			169 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			Makefile
		
	
	
	
	
	
# Copyright 2016 The Kubernetes Authors.
 | 
						|
#
 | 
						|
# 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.
 | 
						|
 | 
						|
# Old-skool build tools.
 | 
						|
#
 | 
						|
# Targets (see each target for more information):
 | 
						|
#   all: Build code.
 | 
						|
#   check: Run tests.
 | 
						|
#   test: Run tests.
 | 
						|
#   clean: Clean up.
 | 
						|
 | 
						|
OUT_DIR = _output
 | 
						|
 | 
						|
KUBE_GOFLAGS = $(GOFLAGS)
 | 
						|
export KUBE_GOFLAGS
 | 
						|
 | 
						|
KUBE_GOLDFLAGS = $(GOLDFLAGS)
 | 
						|
export KUBE_GOLDFLAGS
 | 
						|
 | 
						|
# Build code.
 | 
						|
#
 | 
						|
# Args:
 | 
						|
#   WHAT: Directory names to build.  If any of these directories has a 'main'
 | 
						|
#     package, the build will produce executable files under $(OUT_DIR)/go/bin.
 | 
						|
#     If not specified, "everything" will be built.
 | 
						|
#   GOFLAGS: Extra flags to pass to 'go' when building.
 | 
						|
#   GOLDFLAGS: Extra linking flags to pass to 'go' when building.
 | 
						|
#
 | 
						|
# Example:
 | 
						|
#   make
 | 
						|
#   make all
 | 
						|
#   make all WHAT=cmd/kubelet GOFLAGS=-v
 | 
						|
all:
 | 
						|
	hack/build-go.sh $(WHAT)
 | 
						|
.PHONY: all
 | 
						|
 | 
						|
# Build ginkgo
 | 
						|
#
 | 
						|
# Example:
 | 
						|
# make ginkgo
 | 
						|
ginkgo:
 | 
						|
	hack/build-go.sh vendor/github.com/onsi/ginkgo/ginkgo	
 | 
						|
.PHONY: ginkgo
 | 
						|
 | 
						|
# Runs all the presubmission verifications.
 | 
						|
#
 | 
						|
# Args:
 | 
						|
#   BRANCH: Branch to be passed to hack/verify-godeps.sh script.
 | 
						|
#
 | 
						|
# Example:
 | 
						|
#   make verify
 | 
						|
#   make verify BRANCH=branch_x
 | 
						|
verify:
 | 
						|
	KUBE_VERIFY_GIT_BRANCH=$(BRANCH) hack/verify-all.sh -v
 | 
						|
.PHONY: verify
 | 
						|
 | 
						|
# Build and run tests.
 | 
						|
#
 | 
						|
# Args:
 | 
						|
#   WHAT: Directory names to test.  All *_test.go files under these
 | 
						|
#     directories will be run.  If not specified, "everything" will be tested.
 | 
						|
#   TESTS: Same as WHAT.
 | 
						|
#   GOFLAGS: Extra flags to pass to 'go' when building.
 | 
						|
#   GOLDFLAGS: Extra linking flags to pass to 'go' when building.
 | 
						|
#
 | 
						|
# Example:
 | 
						|
#   make check
 | 
						|
#   make test
 | 
						|
#   make check WHAT=pkg/kubelet GOFLAGS=-v
 | 
						|
check test:
 | 
						|
	hack/test-go.sh $(WHAT) $(TESTS)
 | 
						|
.PHONY: check test
 | 
						|
 | 
						|
# Build and run integration tests.
 | 
						|
#
 | 
						|
# Example:
 | 
						|
#   make test_integration
 | 
						|
test_integration:
 | 
						|
	hack/test-integration.sh
 | 
						|
.PHONY: test_integration test_integ
 | 
						|
 | 
						|
# Build and run end-to-end tests.
 | 
						|
#
 | 
						|
# Example:
 | 
						|
#   make test_e2e
 | 
						|
test_e2e:
 | 
						|
	go run hack/e2e.go -v --build --up --test --down
 | 
						|
.PHONY: test_e2e
 | 
						|
 | 
						|
# Build and run node end-to-end tests.
 | 
						|
#
 | 
						|
# Args:
 | 
						|
#  FOCUS: regexp that matches the tests to be run.  Defaults to "".
 | 
						|
#  SKIP: regexp that matches the tests that needs to be skipped.  Defaults to "".
 | 
						|
#  RUN_UNTIL_FAILURE: Ff true, pass --untilItFails to ginkgo so tests are run repeatedly until they fail.  Defaults to false.
 | 
						|
#  REMOTE: If true, run the tests on a remote host instance on GCE.  Defaults to false.
 | 
						|
#  IMAGES: for REMOTE=true only.  Comma delimited list of images for creating remote hosts to run tests against.  Defaults to "e2e-node-containervm-v20160321-image".
 | 
						|
#  LIST_IMAGES: If true, don't run tests.  Just output the list of available images for testing.  Defaults to false.
 | 
						|
#  HOSTS: for REMOTE=true only.  Comma delimited list of running gce hosts to run tests against.  Defaults to "".
 | 
						|
#  DELETE_INSTANCES: for REMOTE=true only.  Delete any instances created as part of this test run.  Defaults to false.
 | 
						|
#  ARTIFACTS: for REMOTE=true only.  Local directory to scp test artifacts into from the remote hosts.  Defaults to ""/tmp/_artifacts".
 | 
						|
#  REPORT: for REMOTE=false only.  Local directory to write juntil xml results to.  Defaults to "/tmp/".
 | 
						|
#  CLEANUP: for REMOTE=true only.  If false, do not stop processes or delete test files on remote hosts.  Defaults to true.
 | 
						|
#  IMAGE_PROJECT: for REMOTE=true only.  Project containing images provided to IMAGES.  Defaults to "kubernetes-node-e2e-images".
 | 
						|
#  INSTANCE_PREFIX: for REMOTE=true only.  Instances created from images will have the name "${INSTANCE_PREFIX}-${IMAGE_NAME}".  Defaults to "test"/
 | 
						|
#
 | 
						|
# Example:
 | 
						|
#   make test_e2e_node FOCUS=kubelet SKIP=container
 | 
						|
#   make test_e2e_node REMOTE=true DELETE_INSTANCES=true
 | 
						|
# Build and run tests.
 | 
						|
test_e2e_node: ginkgo
 | 
						|
	hack/e2e-node-test.sh
 | 
						|
.PHONY: test_e2e_node
 | 
						|
 | 
						|
# Remove all build artifacts.
 | 
						|
#
 | 
						|
# Example:
 | 
						|
#   make clean
 | 
						|
clean:
 | 
						|
	build/make-clean.sh
 | 
						|
	rm -rf $(OUT_DIR)
 | 
						|
	rm -rf Godeps/_workspace # Just until we are sure it is gone
 | 
						|
.PHONY: clean
 | 
						|
 | 
						|
# Run 'go vet'.
 | 
						|
#
 | 
						|
# Args:
 | 
						|
#   WHAT: Directory names to vet.  All *.go files under these
 | 
						|
#     directories will be vetted.  If not specified, "everything" will be
 | 
						|
#     vetted.
 | 
						|
#   TESTS: Same as WHAT.
 | 
						|
#   GOFLAGS: Extra flags to pass to 'go' when building.
 | 
						|
#   GOLDFLAGS: Extra linking flags to pass to 'go' when building.
 | 
						|
#
 | 
						|
# Example:
 | 
						|
#   make vet
 | 
						|
#   make vet WHAT=pkg/kubelet
 | 
						|
vet:
 | 
						|
	hack/verify-govet.sh $(WHAT) $(TESTS)
 | 
						|
.PHONY: vet
 | 
						|
 | 
						|
# Build a release
 | 
						|
#
 | 
						|
# Example:
 | 
						|
#   make release
 | 
						|
release:
 | 
						|
	build/release.sh
 | 
						|
.PHONY: release
 | 
						|
 | 
						|
# Build a release, but skip tests
 | 
						|
#
 | 
						|
# Example:
 | 
						|
#   make release-skip-tests
 | 
						|
release-skip-tests quick-release:
 | 
						|
	KUBE_RELEASE_RUN_TESTS=n KUBE_FASTBUILD=true build/release.sh
 | 
						|
.PHONY: release-skip-tests quick-release
 | 
						|
 |