-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMakefile
164 lines (140 loc) · 5.59 KB
/
Makefile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
# Copyright 2018 Google LLC
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# https://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
# Make will use bash instead of sh
SHELL := /usr/bin/env bash
# Docker build config variables
CREDENTIALS_PATH ?= /cft/workdir/credentials.json
DOCKER_ORG := gcr.io/cloud-foundation-cicd
DOCKER_TAG_BASE_KITCHEN_TERRAFORM ?= 2.3.0
DOCKER_REPO_BASE_KITCHEN_TERRAFORM := ${DOCKER_ORG}/cft/kitchen-terraform:${DOCKER_TAG_BASE_KITCHEN_TERRAFORM}
# Use commit ID's because BATS upstream does not tag releases correctly.
BUILD_BATS_VERSION ?= 03608115df2071fff4eaaff1605768c275e5f81f
BUILD_BATS_ASSERT_VERSION ?= 8200039faf9790c05d9865490c97a0e101b9c80f
BUILD_BATS_ASSERT_URI ?= https://github.com/jasonkarns/bats-assert-1.git
BUILD_BATS_MOCK_VERSION ?= 2f9811faf43593ad7b59a0f245d8807b776e5072
BUILD_BATS_SUPPORT_VERSION ?= 004e707638eedd62e0481e8cdc9223ad471f12ee
DOCKER_IMAGE_BATS := cftk/bats
# DOCKER_TAG_BATS is the image semver and has no correlation to bats versions
DOCKER_TAG_BATS ?= 0.6.0
# All is the first target in the file so it will get picked up when you just run 'make' on its own
all: check_terraform check_shell check_python check_golang check_docker check_base_files test_check_headers check_headers check_trailing_whitespace generate_docs
# The .PHONY directive tells make that this isn't a real target and so
# the presence of a file named 'check_shell' won't cause this target to stop
# working
.PHONY: check_shell
check_shell:
@source test/make.sh && check_shell
.PHONY: check_python
check_python:
@source test/make.sh && check_python
.PHONY: check_golang
check_golang:
@source test/make.sh && golang
.PHONY: check_terraform
check_terraform:
@source test/make.sh && check_terraform
.PHONY: check_docker
check_docker:
@source test/make.sh && docker
.PHONY: check_base_files
check_base_files:
@source test/make.sh && basefiles
.PHONY: check_trailing_whitespace
check_trailing_whitespace:
@source test/make.sh && check_trailing_whitespace
.PHONY: test_check_headers
test_check_headers:
@echo "Testing the validity of the header check"
@python test/test_verify_boilerplate.py
.PHONY: check_headers
check_headers:
@source test/make.sh && check_headers
.PHONY: generate_docs
generate_docs:
@source test/make.sh && generate_docs
# Versioning
.PHONY: version
version:
@source helpers/version-repo.sh
# Build Docker
.PHONY: docker_build_bats
docker_build_bats:
docker build -f build/docker/bats/Dockerfile \
--build-arg BUILD_BATS_VERSION=${BUILD_BATS_VERSION} \
--build-arg BUILD_BATS_ASSERT_VERSION=${BUILD_BATS_ASSERT_VERSION} \
--build-arg BUILD_BATS_ASSERT_URI=${BUILD_BATS_ASSERT_URI} \
--build-arg BUILD_BATS_MOCK_VERSION=${BUILD_BATS_MOCK_VERSION} \
--build-arg BUILD_BATS_SUPPORT_VERSION=${BUILD_BATS_SUPPORT_VERSION} \
-t ${DOCKER_IMAGE_BATS}:${DOCKER_TAG_BATS} .
# Run docker bats spec tests
.PHONY: docker_bats
docker_bats:
docker run --rm -it \
-v $(CURDIR):/cftk/workdir \
${DOCKER_IMAGE_BATS}:${DOCKER_TAG_BATS} \
/bin/bash -c "bats test/spec/*.bats"
# Run docker bats spec tests in parallel (~30% faster)
.PHONY: docker_bats_parallel
docker_bats_parallel:
docker run --rm -it \
-v $(CURDIR):/cftk/workdir \
${DOCKER_IMAGE_BATS}:${DOCKER_TAG_BATS} \
/bin/bash -c "terraform init && time find test/spec/ -name '*.bats' -print0 | xargs -0 -P4 --no-run-if-empty -n1 bats"
## BEGIN Resources
# Model resources in the CI Pipeline definition. For example,
# integration_test_image models the integration-test-image resource in CI.
# Fetch the image.
.PHONY: integration_test_image
integration_test_image:
docker pull ${DOCKER_IMAGE_INTEGRATION_URI}
## END Resources
# Entry point from inside the container executing the test suite. Modeled
# after project factory Makefile structure and behavior. The pipeline should
# call this make target in a run step.
.PHONY: test_integration
test_integration:
./test/ci_integration.sh
## BEGIN Job Tasks
# Model the CI integration-tests job definition and tasks as a make target.
# The Git repo is placed in the same path the CI pull-request resource will be
# placed inside the image. Params are passed in the same way params are passed
# to the container inside of CI.
#
# Unlike other modules which use a *.tfvars file, this module uses environment
# variables to pass inputs into the integration tests. Pass along the same
# variables set as parameters of the CI Job.
.PHONY: test_integration_docker
test_integration_docker: integration_test_image
docker run --rm -it \
--volume $(CURDIR):/terraform-google-startup-scripts \
--workdir /terraform-google-startup-scripts \
--env SERVICE_ACCOUNT_JSON \
--env PROJECT_ID \
--env REGION \
${DOCKER_IMAGE_INTEGRATION_URI} \
/bin/bash -c make test_integration
# Interactive Shell version of integration_test_run
.PHONY: docker_run
docker_run:
docker run --rm -it \
-e COMPUTE_ENGINE_SERVICE_ACCOUNT \
-e PROJECT_ID \
-e REGION \
-e ZONES \
-e SERVICE_ACCOUNT_JSON \
-e CLOUDSDK_AUTH_CREDENTIAL_FILE_OVERRIDE=${CREDENTIALS_PATH} \
-e GOOGLE_APPLICATION_CREDENTIALS=${CREDENTIALS_PATH} \
-v "$(CURDIR)":/cft/workdir \
${DOCKER_REPO_BASE_KITCHEN_TERRAFORM} \
/bin/bash -c "source test/ci_integration.sh && setup_environment && exec /bin/bash"