2016-04-06 20:45:21 +00:00
.PHONY : all binary build build -gccgo cross default docs docs -build docs -shell shell gccgo test test -docker -py test -integration -cli test -unit validate help
2013-11-14 05:34:25 +00:00
2016-03-24 16:12:40 +00:00
# set the graph driver as the current graphdriver if not set
2016-04-06 21:45:32 +00:00
DOCKER_GRAPHDRIVER := $( if $( DOCKER_GRAPHDRIVER) ,$( DOCKER_GRAPHDRIVER) ,$( shell docker info 2>& 1 | grep "Storage Driver" | sed 's/.*: //' ) )
2016-03-24 16:12:40 +00:00
2015-11-05 14:38:41 +00:00
# get OS/Arch of docker engine
2016-03-11 03:19:33 +00:00
DOCKER_OSARCH := $( shell bash -c 'source hack/make/.detect-daemon-osarch && echo $${DOCKER_ENGINE_OSARCH:-$$DOCKER_CLIENT_OSARCH}' )
DOCKERFILE := $( shell bash -c 'source hack/make/.detect-daemon-osarch && echo $${DOCKERFILE}' )
2015-11-05 14:38:41 +00:00
2014-11-13 23:04:13 +00:00
# env vars passed through directly to Docker's build scripts
# to allow things like `make DOCKER_CLIENTONLY=1 binary` easily
# `docs/sources/contributing/devenvironment.md ` and `project/PACKAGERS.md` have some limited documentation of some of these
DOCKER_ENVS := \
-e BUILDFLAGS \
2016-02-04 14:41:48 +00:00
-e KEEPBUNDLE \
2016-01-26 21:17:05 +00:00
-e DOCKER_BUILD_GOGC \
2016-01-15 23:37:46 +00:00
-e DOCKER_BUILD_PKGS \
2014-11-13 23:04:13 +00:00
-e DOCKER_CLIENTONLY \
2015-05-07 12:22:44 +00:00
-e DOCKER_DEBUG \
2015-05-19 22:09:58 +00:00
-e DOCKER_EXPERIMENTAL \
2016-03-24 16:12:40 +00:00
-e DOCKER_GRAPHDRIVER = $( DOCKER_GRAPHDRIVER) \
2016-01-26 21:17:05 +00:00
-e DOCKER_INCREMENTAL_BINARY \
2015-11-21 16:31:25 +00:00
-e DOCKER_REMAP_ROOT \
2015-04-15 06:39:15 +00:00
-e DOCKER_STORAGE_OPTS \
2015-05-06 22:39:29 +00:00
-e DOCKER_USERLANDPROXY \
2014-11-13 23:04:13 +00:00
-e TESTDIRS \
-e TESTFLAGS \
-e TIMEOUT
# note: we _cannot_ add "-e DOCKER_BUILDTAGS" here because even if it's unset in the shell, that would shadow the "ENV DOCKER_BUILDTAGS" set in our Dockerfile, which is very important for our official builds
2015-02-13 22:50:42 +00:00
# to allow `make BIND_DIR=. shell` or `make BIND_DIR= test`
2014-07-07 16:50:48 +00:00
# (default to no bind mount if DOCKER_HOST is set)
2015-02-13 22:50:42 +00:00
# note: BINDDIR is supported for backwards-compatibility here
BIND_DIR := $( if $( BINDDIR) ,$( BINDDIR) ,$( if $( DOCKER_HOST) ,,bundles) )
DOCKER_MOUNT := $( if $( BIND_DIR) ,-v " $( CURDIR) / $( BIND_DIR) :/go/src/github.com/docker/docker/ $( BIND_DIR) " )
2014-11-13 23:04:13 +00:00
2016-02-27 16:12:12 +00:00
# This allows the test suite to be able to run without worrying about the underlying fs used by the container running the daemon (e.g. aufs-on-aufs), so long as the host running the container is running a supported fs.
# The volume will be cleaned up when the container is removed due to `--rm`.
# Note that `BIND_DIR` will already be set to `bundles` if `DOCKER_HOST` is not set (see above BIND_DIR line), in such case this will do nothing since `DOCKER_MOUNT` will already be set.
DOCKER_MOUNT := $( if $( DOCKER_MOUNT) ,$( DOCKER_MOUNT) ,-v "/go/src/github.com/docker/docker/bundles" )
2014-03-29 01:40:16 +00:00
2014-04-02 04:43:38 +00:00
GIT_BRANCH := $( shell git rev-parse --abbrev-ref HEAD 2>/dev/null)
2015-05-02 00:28:08 +00:00
DOCKER_IMAGE := docker-dev$( if $( GIT_BRANCH) ,:$( GIT_BRANCH) )
2014-04-02 04:43:38 +00:00
DOCKER_DOCS_IMAGE := docker-docs$( if $( GIT_BRANCH) ,:$( GIT_BRANCH) )
2014-03-29 01:40:16 +00:00
2015-10-21 03:10:49 +00:00
DOCKER_FLAGS := docker run --rm -i --privileged $( DOCKER_ENVS) $( DOCKER_MOUNT)
2014-11-13 23:04:13 +00:00
2015-10-21 03:10:49 +00:00
# if this session isn't interactive, then we don't want to allocate a
# TTY, which would fail, but if it is interactive, we do want to attach
# so that the user can send e.g. ^C through.
INTERACTIVE := $( shell [ -t 0 ] && echo 1 || echo 0)
i f e q ( $( INTERACTIVE ) , 1 )
DOCKER_FLAGS += -t
e n d i f
2014-11-13 23:04:13 +00:00
2015-10-21 03:10:49 +00:00
DOCKER_RUN_DOCKER := $( DOCKER_FLAGS) " $( DOCKER_IMAGE) "
2015-02-25 00:37:36 +00:00
2013-12-03 22:51:43 +00:00
default : binary
2016-04-06 20:45:21 +00:00
all : build ## validate all checks, build linux binaries, run all tests\ncross build non-linux binaries and generate archives
2013-12-03 22:51:43 +00:00
$( DOCKER_RUN_DOCKER) hack/make.sh
2016-04-06 20:45:21 +00:00
binary : build ## build the linux binaries
2013-12-03 22:51:43 +00:00
$( DOCKER_RUN_DOCKER) hack/make.sh binary
2013-11-14 05:34:25 +00:00
2015-11-21 16:31:25 +00:00
build : bundles
2016-01-12 07:15:17 +00:00
docker build ${ DOCKER_BUILD_ARGS } -t " $( DOCKER_IMAGE) " -f " $( DOCKERFILE) " .
2015-11-21 16:31:25 +00:00
2016-03-31 17:35:56 +00:00
build-gccgo : bundles
docker build ${ DOCKER_BUILD_ARGS } -t " $( DOCKER_IMAGE) -gccgo " -f Dockerfile.gccgo .
2015-11-21 16:31:25 +00:00
bundles :
mkdir bundles
2016-04-06 20:45:21 +00:00
cross : build ## cross build the binaries for darwin, freebsd and\nwindows
2015-11-06 07:35:47 +00:00
$( DOCKER_RUN_DOCKER) hack/make.sh dynbinary binary cross
2016-03-11 06:55:07 +00:00
2016-04-06 20:45:21 +00:00
win : build ## cross build the binary for windows
2016-03-10 04:33:21 +00:00
$( DOCKER_RUN_DOCKER) hack/make.sh win
2016-04-06 20:45:21 +00:00
tgz : build ## build the archives (.zip on windows and .tgz\notherwise) containing the binaries
2016-03-31 16:27:50 +00:00
$( DOCKER_RUN_DOCKER) hack/make.sh dynbinary binary cross tgz
2013-12-19 06:06:14 +00:00
2016-04-06 20:45:21 +00:00
deb : build ## build the deb packages
2015-11-06 07:35:47 +00:00
$( DOCKER_RUN_DOCKER) hack/make.sh dynbinary build-deb
2015-07-09 21:51:02 +00:00
2016-04-06 20:45:21 +00:00
docs : ## build the docs
2015-11-21 16:31:25 +00:00
$( MAKE) -C docs docs
2016-04-06 20:45:21 +00:00
gccgo : build -gccgo ## build the gcc-go linux binaries
2016-03-31 17:35:56 +00:00
$( DOCKER_FLAGS) " $( DOCKER_IMAGE) -gccgo " hack/make.sh gccgo
2016-01-18 15:33:12 +00:00
2016-04-06 20:45:21 +00:00
rpm : build ## build the rpm packages
2015-11-06 07:35:47 +00:00
$( DOCKER_RUN_DOCKER) hack/make.sh dynbinary build-rpm
2014-12-16 04:25:37 +00:00
2016-04-06 20:45:21 +00:00
shell : build ## start a shell inside the build env
2015-11-21 16:31:25 +00:00
$( DOCKER_RUN_DOCKER) bash
2016-04-06 20:45:21 +00:00
test : build ## un the unit, integration and docker-py tests
2015-11-06 07:35:47 +00:00
$( DOCKER_RUN_DOCKER) hack/make.sh dynbinary cross test-unit test-integration-cli test-docker-py
2014-04-29 22:49:03 +00:00
2016-04-06 20:45:21 +00:00
test-docker-py : build ## run the docker-py tests
2015-11-21 16:31:25 +00:00
$( DOCKER_RUN_DOCKER) hack/make.sh dynbinary test-docker-py
2013-11-14 05:34:25 +00:00
2016-04-06 20:45:21 +00:00
test-integration-cli : build ## run the integration tests
2015-11-06 07:35:47 +00:00
$( DOCKER_RUN_DOCKER) hack/make.sh dynbinary test-integration-cli
2014-02-25 16:17:48 +00:00
2016-04-06 20:45:21 +00:00
test-unit : build ## run the unit tests
2015-11-21 16:31:25 +00:00
$( DOCKER_RUN_DOCKER) hack/make.sh test-unit
2014-12-19 07:20:59 +00:00
2016-04-06 20:45:21 +00:00
validate : build ## validate DCO, Seccomp profile generation, gofmt,\n./pkg/ isolation, golint, tests, tomls, go vet and vendor
2016-02-08 18:52:53 +00:00
$( DOCKER_RUN_DOCKER) hack/make.sh validate-dco validate-default-seccomp validate-gofmt validate-pkg validate-lint validate-test validate-toml validate-vet validate-vendor
2016-04-06 20:45:21 +00:00
help : ## this help
@awk 'BEGIN {FS = ":.*?## "} /^[a-zA-Z_-]+:.*?## / {sub("\\\\n",sprintf("\n%22c"," "), $$2);printf "\033[36m%-20s\033[0m %s\n", $$1, $$2}' $( MAKEFILE_LIST)