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
2016-02-19 22:42:51 +00:00
# to allow things like `make KEEPBUNDLE=1 binary` easily
2016-07-01 09:18:42 +00:00
# `project/PACKAGERS.md` have some limited documentation of some of these
2014-11-13 23:04:13 +00:00
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 \
2015-05-07 12:22:44 +00:00
-e DOCKER_DEBUG \
2015-05-19 22:09:58 +00:00
-e DOCKER_EXPERIMENTAL \
2016-04-14 09:37:42 +00:00
-e DOCKER_GITCOMMIT \
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 \
2016-07-07 20:01:44 +00:00
-e DOCKER_PORT \
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 \
2016-07-09 03:52:33 +00:00
-e TIMEOUT \
-e HTTP_PROXY \
-e HTTPS_PROXY \
-e NO_PROXY \
-e http_proxy \
-e https_proxy \
-e no_proxy
2014-11-13 23:04:13 +00:00
# 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-06-27 09:19:48 +00:00
# enable .go-pkg-cache if DOCKER_INCREMENTAL_BINARY and DOCKER_MOUNT (i.e.DOCKER_HOST) are set
PKGCACHE_DIR := $( if $( PKGCACHE_DIR) ,$( PKGCACHE_DIR) ,.go-pkg-cache)
PKGCACHE_MAP := gopath:/go/pkg vendor:/go/src/github.com/docker/docker/vendor/pkg goroot-linux_amd64_netgo:/usr/local/go/pkg/linux_amd64_netgo
DOCKER_MOUNT := $( if $( DOCKER_INCREMENTAL_BINARY) ,$( DOCKER_MOUNT) $( shell echo $( PKGCACHE_MAP) | sed -E 's@([^ ]*)@-v "$(CURDIR)/$(PKGCACHE_DIR)/\1"@g' ) ,$( DOCKER_MOUNT) )
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)
2016-05-08 09:52:38 +00: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) )
2016-07-07 20:01:44 +00:00
DOCKER_PORT_FORWARD := $( if $( DOCKER_PORT) ,-p " $( DOCKER_PORT) " ,)
2014-03-29 01:40:16 +00:00
2016-07-07 20:01:44 +00:00
DOCKER_FLAGS := docker run --rm -i --privileged $( DOCKER_ENVS) $( DOCKER_MOUNT) $( DOCKER_PORT_FORWARD)
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
2016-06-27 09:19:48 +00:00
build : bundles init -go -pkg -cache
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-06-27 09:19:48 +00:00
build-gccgo : bundles init -go -pkg -cache
2016-03-31 17:35:56 +00:00
docker build ${ DOCKER_BUILD_ARGS } -t " $( DOCKER_IMAGE) -gccgo " -f Dockerfile.gccgo .
2015-11-21 16:31:25 +00:00
bundles :
mkdir bundles
2016-06-27 09:19:48 +00:00
init-go-pkg-cache :
mkdir -p $( shell echo $( PKGCACHE_MAP) | sed -E 's@([^: ]*):[^ ]*@$(PKGCACHE_DIR)/\1@g' )
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-05-24 01:44:43 +00:00
install : ## install the linux binaries
KEEPBUNDLE = 1 hack/make.sh install-binary
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-07-07 20:01:44 +00:00
run : build ## run the docker daemon in a container
$( DOCKER_RUN_DOCKER) sh -c "KEEPBUNDLE=1 hack/make.sh install-binary run"
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-07 14:10:09 +00:00
test : build ## run 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
2016-06-09 15:33:28 +00:00
manpages : ## Generate man pages from go source and markdown
docker build -t docker-manpage-dev -f man/Dockerfile .
docker run \
-v $( PWD) :/go/src/github.com/docker/docker/ \
docker-manpage-dev
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)