Makefile 6.0 KB

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