Makefile 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154
  1. # Copyright 2020 Docker Compose CLI authors
  2. # Licensed under the Apache License, Version 2.0 (the "License");
  3. # you may not use this file except in compliance with the License.
  4. # You may obtain a copy of the License at
  5. # http://www.apache.org/licenses/LICENSE-2.0
  6. # Unless required by applicable law or agreed to in writing, software
  7. # distributed under the License is distributed on an "AS IS" BASIS,
  8. # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  9. # See the License for the specific language governing permissions and
  10. # limitations under the License.
  11. PKG := github.com/docker/compose/v2
  12. export COMPOSE_MENU = FALSE
  13. VERSION ?= $(shell git describe --match 'v[0-9]*' --dirty='.m' --always --tags)
  14. GO_LDFLAGS ?= -w -X ${PKG}/internal.Version=${VERSION}
  15. GO_BUILDTAGS ?= e2e
  16. DRIVE_PREFIX?=
  17. ifeq ($(OS),Windows_NT)
  18. DETECTED_OS = Windows
  19. DRIVE_PREFIX=C:
  20. else
  21. DETECTED_OS = $(shell uname -s)
  22. endif
  23. ifeq ($(DETECTED_OS),Windows)
  24. BINARY_EXT=.exe
  25. endif
  26. BUILD_FLAGS?=
  27. TEST_FLAGS?=
  28. E2E_TEST?=
  29. ifneq ($(E2E_TEST),)
  30. TEST_FLAGS:=$(TEST_FLAGS) -run '$(E2E_TEST)'
  31. endif
  32. EXCLUDE_E2E_TESTS?=
  33. ifneq ($(EXCLUDE_E2E_TESTS),)
  34. TEST_FLAGS:=$(TEST_FLAGS) -skip '$(EXCLUDE_E2E_TESTS)'
  35. endif
  36. BUILDX_CMD ?= docker buildx
  37. # DESTDIR overrides the output path for binaries and other artifacts
  38. # this is used by docker/docker-ce-packaging for the apt/rpm builds,
  39. # so it's important that the resulting binary ends up EXACTLY at the
  40. # path $DESTDIR/docker-compose when specified.
  41. #
  42. # See https://github.com/docker/docker-ce-packaging/blob/e43fbd37e48fde49d907b9195f23b13537521b94/rpm/SPECS/docker-compose-plugin.spec#L47
  43. #
  44. # By default, all artifacts go to subdirectories under ./bin/ in the
  45. # repo root, e.g. ./bin/build, ./bin/coverage, ./bin/release.
  46. DESTDIR ?=
  47. all: build
  48. .PHONY: build ## Build the compose cli-plugin
  49. build:
  50. GO111MODULE=on go build $(BUILD_FLAGS) -trimpath -tags "$(GO_BUILDTAGS)" -ldflags "$(GO_LDFLAGS)" -o "$(or $(DESTDIR),./bin/build)/docker-compose$(BINARY_EXT)" ./cmd
  51. .PHONY: binary
  52. binary:
  53. $(BUILDX_CMD) bake binary
  54. .PHONY: binary-with-coverage
  55. binary-with-coverage:
  56. $(BUILDX_CMD) bake binary-with-coverage
  57. .PHONY: install
  58. install: binary
  59. mkdir -p ~/.docker/cli-plugins
  60. install $(or $(DESTDIR),./bin/build)/docker-compose ~/.docker/cli-plugins/docker-compose
  61. .PHONY: e2e-compose
  62. e2e-compose: ## Run end to end local tests in plugin mode. Set E2E_TEST=TestName to run a single test
  63. go run gotest.tools/gotestsum@latest --format testname --junitfile "/tmp/report/report.xml" -- -v $(TEST_FLAGS) -count=1 ./pkg/e2e
  64. .PHONY: e2e-compose-standalone
  65. e2e-compose-standalone: ## Run End to end local tests in standalone mode. Set E2E_TEST=TestName to run a single test
  66. go run gotest.tools/gotestsum@latest --format testname --junitfile "/tmp/report/report.xml" -- $(TEST_FLAGS) -v -count=1 -parallel=1 --tags=standalone ./pkg/e2e
  67. .PHONY: build-and-e2e-compose
  68. build-and-e2e-compose: build e2e-compose ## Compile the compose cli-plugin and run end to end local tests in plugin mode. Set E2E_TEST=TestName to run a single test
  69. .PHONY: build-and-e2e-compose-standalone
  70. build-and-e2e-compose-standalone: build e2e-compose-standalone ## Compile the compose cli-plugin and run End to end local tests in standalone mode. Set E2E_TEST=TestName to run a single test
  71. .PHONY: mocks
  72. mocks:
  73. mockgen --version >/dev/null 2>&1 || go install go.uber.org/mock/[email protected]
  74. mockgen -destination pkg/mocks/mock_docker_cli.go -package mocks github.com/docker/cli/cli/command Cli
  75. mockgen -destination pkg/mocks/mock_docker_api.go -package mocks github.com/docker/docker/client APIClient
  76. mockgen -destination pkg/mocks/mock_docker_compose_api.go -package mocks -source=./pkg/api/api.go Service
  77. .PHONY: e2e
  78. e2e: e2e-compose e2e-compose-standalone ## Run end to end local tests in both modes. Set E2E_TEST=TestName to run a single test
  79. .PHONY: build-and-e2e
  80. build-and-e2e: build e2e-compose e2e-compose-standalone ## Compile the compose cli-plugin and run end to end local tests in both modes. Set E2E_TEST=TestName to run a single test
  81. .PHONY: cross
  82. cross: ## Compile the CLI for linux, darwin and windows
  83. $(BUILDX_CMD) bake binary-cross
  84. .PHONY: test
  85. test: ## Run unit tests
  86. $(BUILDX_CMD) bake test
  87. .PHONY: cache-clear
  88. cache-clear: ## Clear the builder cache
  89. $(BUILDX_CMD) prune --force --filter type=exec.cachemount --filter=unused-for=24h
  90. .PHONY: lint
  91. lint: ## run linter(s)
  92. $(BUILDX_CMD) bake lint
  93. .PHONY: docs
  94. docs: ## generate documentation
  95. $(eval $@_TMP_OUT := $(shell mktemp -d -t compose-output.XXXXXXXXXX))
  96. $(BUILDX_CMD) bake --set "*.output=type=local,dest=$($@_TMP_OUT)" docs-update
  97. rm -rf ./docs/internal
  98. cp -R "$(DRIVE_PREFIX)$($@_TMP_OUT)"/out/* ./docs/
  99. rm -rf "$(DRIVE_PREFIX)$($@_TMP_OUT)"/*
  100. .PHONY: validate-docs
  101. validate-docs: ## validate the doc does not change
  102. $(BUILDX_CMD) bake docs-validate
  103. .PHONY: check-dependencies
  104. check-dependencies: ## check dependency updates
  105. go list -u -m -f '{{if not .Indirect}}{{if .Update}}{{.}}{{end}}{{end}}' all
  106. .PHONY: validate-headers
  107. validate-headers: ## Check license header for all files
  108. $(BUILDX_CMD) bake license-validate
  109. .PHONY: go-mod-tidy
  110. go-mod-tidy: ## Run go mod tidy in a container and output resulting go.mod and go.sum
  111. $(BUILDX_CMD) bake vendor-update
  112. .PHONY: validate-go-mod
  113. validate-go-mod: ## Validate go.mod and go.sum are up-to-date
  114. $(BUILDX_CMD) bake vendor-validate
  115. validate: validate-go-mod validate-headers validate-docs ## Validate sources
  116. pre-commit: validate check-dependencies lint build test e2e-compose
  117. help: ## Show help
  118. @echo Please specify a build target. The choices are:
  119. @grep -E '^[0-9a-zA-Z_-]+:.*?## .*$$' $(MAKEFILE_LIST) | awk 'BEGIN {FS = ":.*?## "}; {printf "\033[36m%-30s\033[0m %s\n", $$1, $$2}'