2016-04-06 23:45:21 +03: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 09:34:25 +04:00
2016-03-24 19:12:40 +03:00
# set the graph driver as the current graphdriver if not set
2016-04-07 00:45:32 +03:00
DOCKER_GRAPHDRIVER := $( if $( DOCKER_GRAPHDRIVER) ,$( DOCKER_GRAPHDRIVER) ,$( shell docker info 2>& 1 | grep "Storage Driver" | sed 's/.*: //' ) )
2016-03-24 19:12:40 +03:00
2015-11-05 17:38:41 +03:00
# get OS/Arch of docker engine
2016-03-11 06:19:33 +03: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 17:38:41 +03:00
2014-11-14 02:04:13 +03:00
# env vars passed through directly to Docker's build scripts
2016-02-20 01:42:51 +03:00
# to allow things like `make KEEPBUNDLE=1 binary` easily
2014-11-14 02:04:13 +03:00
# `docs/sources/contributing/devenvironment.md ` and `project/PACKAGERS.md` have some limited documentation of some of these
DOCKER_ENVS := \
-e BUILDFLAGS \
2016-02-04 17:41:48 +03:00
-e KEEPBUNDLE \
2016-01-27 00:17:05 +03:00
-e DOCKER_BUILD_GOGC \
2016-01-16 02:37:46 +03:00
-e DOCKER_BUILD_PKGS \
2015-05-07 15:22:44 +03:00
-e DOCKER_DEBUG \
2015-05-20 01:09:58 +03:00
-e DOCKER_EXPERIMENTAL \
2016-04-14 12:37:42 +03:00
-e DOCKER_GITCOMMIT \
2016-03-24 19:12:40 +03:00
-e DOCKER_GRAPHDRIVER = $( DOCKER_GRAPHDRIVER) \
2016-01-27 00:17:05 +03:00
-e DOCKER_INCREMENTAL_BINARY \
2015-11-21 19:31:25 +03:00
-e DOCKER_REMAP_ROOT \
2015-04-15 09:39:15 +03:00
-e DOCKER_STORAGE_OPTS \
2015-05-07 01:39:29 +03:00
-e DOCKER_USERLANDPROXY \
2014-11-14 02:04:13 +03: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-14 01:50:42 +03:00
# to allow `make BIND_DIR=. shell` or `make BIND_DIR= test`
2014-07-07 20:50:48 +04:00
# (default to no bind mount if DOCKER_HOST is set)
2015-02-14 01:50:42 +03: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-14 02:04:13 +03:00
2016-02-27 19:12:12 +03: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 05:40:16 +04:00
2014-04-02 08:43:38 +04:00
GIT_BRANCH := $( shell git rev-parse --abbrev-ref HEAD 2>/dev/null)
2016-05-08 12:52:38 +03:00
GIT_BRANCH_CLEAN := $( shell echo $( GIT_BRANCH) | sed -e "s/[^[:alnum:]]/-/g" )
DOCKER_IMAGE := docker-dev$( if $( GIT_BRANCH_CLEAN) ,:$( GIT_BRANCH_CLEAN) )
DOCKER_DOCS_IMAGE := docker-docs$( if $( GIT_BRANCH_CLEAN) ,:$( GIT_BRANCH_CLEAN) )
2014-03-29 05:40:16 +04:00
2015-10-21 06:10:49 +03:00
DOCKER_FLAGS := docker run --rm -i --privileged $( DOCKER_ENVS) $( DOCKER_MOUNT)
2014-11-14 02:04:13 +03:00
2015-10-21 06:10:49 +03: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-14 02:04:13 +03:00
2015-10-21 06:10:49 +03:00
DOCKER_RUN_DOCKER := $( DOCKER_FLAGS) " $( DOCKER_IMAGE) "
2015-02-25 03:37:36 +03:00
2013-12-04 02:51:43 +04:00
default : binary
2016-04-06 23:45:21 +03:00
all : build ## validate all checks, build linux binaries, run all tests\ncross build non-linux binaries and generate archives
2013-12-04 02:51:43 +04:00
$( DOCKER_RUN_DOCKER) hack/make.sh
2016-04-06 23:45:21 +03:00
binary : build ## build the linux binaries
2013-12-04 02:51:43 +04:00
$( DOCKER_RUN_DOCKER) hack/make.sh binary
2013-11-14 09:34:25 +04:00
2015-11-21 19:31:25 +03:00
build : bundles
2016-01-12 10:15:17 +03:00
docker build ${ DOCKER_BUILD_ARGS } -t " $( DOCKER_IMAGE) " -f " $( DOCKERFILE) " .
2015-11-21 19:31:25 +03:00
2016-03-31 20:35:56 +03:00
build-gccgo : bundles
docker build ${ DOCKER_BUILD_ARGS } -t " $( DOCKER_IMAGE) -gccgo " -f Dockerfile.gccgo .
2015-11-21 19:31:25 +03:00
bundles :
mkdir bundles
2016-04-06 23:45:21 +03:00
cross : build ## cross build the binaries for darwin, freebsd and\nwindows
2015-11-06 10:35:47 +03:00
$( DOCKER_RUN_DOCKER) hack/make.sh dynbinary binary cross
2016-03-11 09:55:07 +03:00
2016-04-06 23:45:21 +03:00
win : build ## cross build the binary for windows
2016-03-10 07:33:21 +03:00
$( DOCKER_RUN_DOCKER) hack/make.sh win
2016-04-06 23:45:21 +03:00
tgz : build ## build the archives (.zip on windows and .tgz\notherwise) containing the binaries
2016-03-31 19:27:50 +03:00
$( DOCKER_RUN_DOCKER) hack/make.sh dynbinary binary cross tgz
2013-12-19 10:06:14 +04:00
2016-04-06 23:45:21 +03:00
deb : build ## build the deb packages
2015-11-06 10:35:47 +03:00
$( DOCKER_RUN_DOCKER) hack/make.sh dynbinary build-deb
2015-07-10 00:51:02 +03:00
2016-04-06 23:45:21 +03:00
docs : ## build the docs
2015-11-21 19:31:25 +03:00
$( MAKE) -C docs docs
2016-04-06 23:45:21 +03:00
gccgo : build -gccgo ## build the gcc-go linux binaries
2016-03-31 20:35:56 +03:00
$( DOCKER_FLAGS) " $( DOCKER_IMAGE) -gccgo " hack/make.sh gccgo
2016-01-18 18:33:12 +03:00
2016-04-06 23:45:21 +03:00
rpm : build ## build the rpm packages
2015-11-06 10:35:47 +03:00
$( DOCKER_RUN_DOCKER) hack/make.sh dynbinary build-rpm
2014-12-16 07:25:37 +03:00
2016-04-06 23:45:21 +03:00
shell : build ## start a shell inside the build env
2015-11-21 19:31:25 +03:00
$( DOCKER_RUN_DOCKER) bash
2016-04-07 17:10:09 +03:00
test : build ## run the unit, integration and docker-py tests
2015-11-06 10:35:47 +03:00
$( DOCKER_RUN_DOCKER) hack/make.sh dynbinary cross test-unit test-integration-cli test-docker-py
2014-04-30 02:49:03 +04:00
2016-04-06 23:45:21 +03:00
test-docker-py : build ## run the docker-py tests
2015-11-21 19:31:25 +03:00
$( DOCKER_RUN_DOCKER) hack/make.sh dynbinary test-docker-py
2013-11-14 09:34:25 +04:00
2016-04-06 23:45:21 +03:00
test-integration-cli : build ## run the integration tests
2015-11-06 10:35:47 +03:00
$( DOCKER_RUN_DOCKER) hack/make.sh dynbinary test-integration-cli
2014-02-25 20:17:48 +04:00
2016-04-06 23:45:21 +03:00
test-unit : build ## run the unit tests
2015-11-21 19:31:25 +03:00
$( DOCKER_RUN_DOCKER) hack/make.sh test-unit
2014-12-19 10:20:59 +03:00
2016-04-06 23:45:21 +03:00
validate : build ## validate DCO, Seccomp profile generation, gofmt,\n./pkg/ isolation, golint, tests, tomls, go vet and vendor
2016-02-08 21:52:53 +03: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 23:45:21 +03: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)