2015-04-29 07:56:45 -04:00
.PHONY : all binary build cross default docs docs -build docs -shell shell test test -unit test -integration -cli test -docker -py validate
2013-11-14 00:34:25 -05:00
2014-11-13 18:04:13 -05: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 \
-e DOCKER_CLIENTONLY \
2015-05-07 08:22:44 -04:00
-e DOCKER_DEBUG \
2015-05-19 18:09:58 -04:00
-e DOCKER_EXPERIMENTAL \
2015-09-18 13:41:12 -04:00
-e DOCKER_REMAP_ROOT \
2014-11-13 18:04:13 -05:00
-e DOCKER_GRAPHDRIVER \
2015-04-15 02:39:15 -04:00
-e DOCKER_STORAGE_OPTS \
2015-05-06 18:39:29 -04:00
-e DOCKER_USERLANDPROXY \
2014-11-13 18:04:13 -05: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 17:50:42 -05:00
# to allow `make BIND_DIR=. shell` or `make BIND_DIR= test`
2014-07-07 12:50:48 -04:00
# (default to no bind mount if DOCKER_HOST is set)
2015-02-13 17:50:42 -05: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 18:04:13 -05:00
2014-03-28 21:40:16 -04:00
2014-04-02 00:43:38 -04:00
GIT_BRANCH := $( shell git rev-parse --abbrev-ref HEAD 2>/dev/null)
2015-05-01 20:28:08 -04:00
DOCKER_IMAGE := docker-dev$( if $( GIT_BRANCH) ,:$( GIT_BRANCH) )
2014-04-02 00:43:38 -04:00
DOCKER_DOCS_IMAGE := docker-docs$( if $( GIT_BRANCH) ,:$( GIT_BRANCH) )
2014-03-28 21:40:16 -04:00
2015-10-20 23:10:49 -04:00
DOCKER_FLAGS := docker run --rm -i --privileged $( DOCKER_ENVS) $( DOCKER_MOUNT)
2014-11-13 18:04:13 -05:00
2015-10-20 23:10:49 -04: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 18:04:13 -05:00
2015-10-20 23:10:49 -04:00
DOCKER_RUN_DOCKER := $( DOCKER_FLAGS) " $( DOCKER_IMAGE) "
2015-02-24 19:37:36 -05:00
2013-12-03 17:51:43 -05:00
default : binary
all : build
$( DOCKER_RUN_DOCKER) hack/make.sh
binary : build
$( DOCKER_RUN_DOCKER) hack/make.sh binary
2013-11-14 00:34:25 -05:00
2013-12-19 01:06:14 -05:00
cross : build
2013-12-24 01:31:53 -05:00
$( DOCKER_RUN_DOCKER) hack/make.sh binary cross
2013-12-19 01:06:14 -05:00
2015-07-09 17:51:02 -04:00
deb : build
$( DOCKER_RUN_DOCKER) hack/make.sh binary build-deb
rpm : build
$( DOCKER_RUN_DOCKER) hack/make.sh binary build-rpm
2014-12-15 23:25:37 -05:00
2013-12-03 17:51:43 -05:00
test : build
2015-04-29 07:56:45 -04:00
$( DOCKER_RUN_DOCKER) hack/make.sh binary cross test-unit test-integration-cli test-docker-py
2014-04-29 18:49:03 -04:00
test-unit : build
$( DOCKER_RUN_DOCKER) hack/make.sh test-unit
2013-11-14 00:34:25 -05:00
2014-02-25 11:17:48 -05:00
test-integration-cli : build
$( DOCKER_RUN_DOCKER) hack/make.sh binary test-integration-cli
2014-12-19 02:20:59 -05:00
test-docker-py : build
$( DOCKER_RUN_DOCKER) hack/make.sh binary test-docker-py
2014-04-16 20:56:02 -04:00
validate : build
2015-07-20 21:32:55 -04:00
$( DOCKER_RUN_DOCKER) hack/make.sh validate-dco validate-gofmt validate-pkg validate-lint validate-test validate-toml validate-vet
2014-04-16 20:56:02 -04:00
2013-12-03 17:51:43 -05:00
shell : build
$( DOCKER_RUN_DOCKER) bash
build : bundles
2014-02-23 11:32:12 -05:00
docker build -t " $( DOCKER_IMAGE) " .
2013-11-30 03:07:53 -05:00
bundles :
mkdir bundles
2015-06-19 11:48:14 -04:00
docs :
$( MAKE) -C docs docs