-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathMakefile
359 lines (298 loc) · 13.6 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
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
.PHONY: clean clean-build clean-pyc clean-test coverage dist docs help install lint lint/flake8 lint/black pip
.DEFAULT_GOAL := help
define BROWSER_PYSCRIPT
import os, webbrowser, sys
from urllib.request import pathname2url
webbrowser.open("file://" + pathname2url(os.path.abspath(sys.argv[1])))
endef
export BROWSER_PYSCRIPT
define PRINT_HELP_PYSCRIPT
import re, sys
for line in sys.stdin:
match = re.match(r'^([a-zA-Z_-]+):.*?## (.*)$$', line)
if match:
target, help = match.groups()
print("%-20s %s" % (target, help))
endef
export PRINT_HELP_PYSCRIPT
BROWSER := python3 -c "$$BROWSER_PYSCRIPT"
help:
@python3 -c "$$PRINT_HELP_PYSCRIPT" < $(MAKEFILE_LIST)
clean: clean-build clean-pyc clean-test ## remove all build, test, coverage and Python artifacts
down:
kind delete kubify
clean-build: ## remove build artifacts
rm -fr build/
rm -fr dist/
rm -fr .eggs/
find . -name '*.egg-info' -exec rm -fr {} +
find . -name '*.egg' -exec rm -f {} +
clean-pyc: ## remove Python file artifacts
find . -name '*.pyc' -exec rm -f {} +
find . -name '*.pyo' -exec rm -f {} +
find . -name '*~' -exec rm -f {} +
find . -name '__pycache__' -exec rm -fr {} +
clean-test: ## remove test and coverage artifacts
rm -f .coverage
rm -fr htmlcov/
rm -fr .pytest_cache
lint/flake8: ## check style with flake8
flake8 --max-line-length=200 --ignore E722,W503 --exclude=".tox,kubify/ops,tests,docs,build,kubify/._kubify_work,kubify.egg-*,kubify-*" ./
lint/black: ## check style with black
black --check ./
lint: lint/flake8 lint/black ## check style
format: ## format code with black
find . -type f -print0 | xargs -0 dos2unix
black ./
which conda || export PATH=$$PATH:/opt/conda/bin
which conda || alias conda=/opt/conda/bin/conda
bash -c 'conda env update --file environment.yml --prune'
test: ## run tests quickly with the default Python
pytest
coverage: ## check code coverage quickly with the default Python
coverage run --source ./kubify -m pytest || true
coverage report -m || true
coverage html || true
$(BROWSER) htmlcov/index.html || true
docs: ## generate Sphinx HTML documentation, including API docs
rm -f docs/kubify.rst
rm -f docs/modules.rst
sphinx-apidoc -o docs/ kubify
$(MAKE) -C docs clean
$(MAKE) -C docs html
$(BROWSER) docs/_build/html/index.html
servedocs: docs ## compile the docs watching for changes
watchmedo shell-command -p '*.rst' -c '$(MAKE) -C docs html' -R -D .
release: dist ## package and upload a release
twine upload dist/*
dist: clean ## builds source and wheel package
python3 setup.py sdist
python3 setup.py bdist_wheel
ls -l dist
install: clean ## install the package to the active Python's site-packages
python3 setup.py install
submodules:
mkdir -p ./submodules
git submodule update --init --recursive
debug-up:
.pytest-kind/kind/kind-v0.15.0 create cluster --name=kind --kubeconfig=.pytest-kind/kind/kubeconfig --config $$HOME/.kubify/kind.yaml
mac:
brew bundle || true
node:
export NVM_DIR=$${NVM_DIR:-$$HOME/.kubify_nvm}
mkdir -p $$NVM_DIR
export NODE_VERSION=$${NODE_VERSION:-18.13.0}
stat $$NVM_DIR/nvm.sh || curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.1/install.sh | bash
. $$NVM_DIR/nvm.sh && nvm install $${NODE_VERSION} && . $$NVM_DIR/bash_completion && \
nvm alias kubify "$$NODE_VERSION" && nvm use kubify
tfsec:
which tfsec || mkdir -p ~/._kubify_tools
which tfsec || echo $$OSTYPE | grep darwin && make mac || \
curl -o ~/._kubify_tools/tfsec "https://github.com/aquasecurity/tfsec/releases/download/v1.28.0/tfsec-linux-amd64"
chmod +x ~/._kubify_tools/tfsec || true
which tfsec || stat ~/._kubify_tools/tfsec
echo $$PATH
tfsec --version
pip:
pip install -e .[develop]
ansible --version || pip install -U ansible
install_grpcio: pip3 install --upgrade pip
python3 -m pip install --upgrade setuptools
pip3 install --no-cache-dir --force-reinstall -Iv grpcio
kind:
export uname_found=`uname` && uname -m | grep arm && export arch_found="arm64" || export arch_found="amd64" && which kind || brew install kind 2>/dev/null || `curl -Lo ./kind "https://kind.sigs.k8s.io/dl/v0.14.0/kind-$$uname_found-$$arch_found" && chmod +x ./kind && mv ./kind /usr/local/bin/kind`
kubectl:
export PATH=$$PATH:~/._kubify_tools
mkdir -p ~/._kubify_tools/src
which skaffold || uname -m | grep amd && export arch_found="amd64" || export arch_found="arm64" && wget -O ~/._kubify_tools/skaffold "https://storage.googleapis.com/skaffold/releases/latest/skaffold-linux-$$arch_found"
chmod +x ~/._kubify_tools/skaffold
which kubectl || uname -m | grep amd && export arch_found="amd64" || export arch_found="arm64" && wget -O ~/._kubify_tools/kubectl "https://dl.k8s.io/release/`curl -L -s https://dl.k8s.io/release/stable.txt`/bin/linux/$$arch_found/kubectl"
chmod +x ~/._kubify_tools/kubectl
which kubesec || wget -O ~/._kubify_tools/kubesec "https://github.com/shyiko/kubesec/releases/download/0.9.2/kubesec-0.9.2-linux-amd64"
chmod +x ~/._kubify_tools/kubesec
git clone https://github.com/ahmetb/kubectx ~/._kubify_tools/src/kubectx
ln -sf ~/._kubify_tools/src/kubectx/kubectx ~/._kubify_tools/kubectx
chmod +x ~/._kubify_tools/kubectx
rm -rf ~/._kubify_tools/src/kubectx
apt:
apt update && xargs apt -y install <apt.lock
tfenv:
which tfenv || brew install tfenv 2>/dev/null || anyenv install tfenv 2>/dev/null || `git clone https://github.com/tfutils/tfenv $$HOME/.tfenv && ln -sf $$HOME/.tfenv/bin/* /usr/local/bin`
tfenv install 1.3.0
tfenv use 1.3.0
format:
find . -type f -print0 -not -path "./.git/*" >/dev/null | xargs -0 dos2unix >/dev/null
black ./
terraform fmt --recursive --write=true
version:
bump2version patch
git push
git push --tags
make pip
python-rapid: # run git add first
check-manifest --no-build-isolation
make format
make lint
make docker
git commit -m "kubify python migration"
git push
bump2version patch && git push && git push --tags
open "https://github.com/willyguggenheim/kubify/compare/main...python"
push:
make rapid
latest:
make rapid
stable:
bump2version major
git push
git push --tags
git commit -m "stable release"
make latest
rapid_test:
stat services/internal-facing/example-lambda-python-svc || echo "run this in kubify dir"
docker ps | grep kubify-kubify-1 && kubify --down || kubify
kubify --up
kubify --start-all
cd services/internal-facing/example-lambda-python-svc
kubify --start
kubify --down
checks:
#!/bin/bash
make security
make tfsec
make develop
make docs
make format
make lint
make test
echo $$DEBIAN_FRONTEND | grep noninteractive && make rapid_test || echo "use devcontainer or docker-compose to run rapid_test"
wait
rapid:
make checks
echo "git add and git commit your files, then press enter to push"
bash -c "read"
git push
make version
echo $$DEBIAN_FRONTEND | grep noninteractive || open "https://github.com/willyguggenheim/kubify/compare/main...python"
full:
check-manifest -u -v
make docker
make conda-build
make rapid
aws_account_id_for_state := $(shell aws sts get-caller-identity --query "Account" --output text 2>/dev/null)
# clouds deploy now
clouds:
make cloud-create env=dev
clouds-delete:
make cloud-delete env=dev
clouds-auth: # make cloud-auth env=dev
aws eks-update-kubeconfig --name "kubify-$$env" --region us-west-2
kubectl cluster-info
aws eks-update-kubeconfig --name "kubify-$$env" --region us-east-1
kubectl cluster-info
gcloud container clusters get-credentials "kubify-$$env" --region us-west2 --project "kubify-os"
kubectl cluster-info
gcloud container clusters get-credentials "kubify-$$env" --region us-east1 --project "kubify-os"
kubectl cluster-info
az aks get-credentials --resource-group "kubify-$$env" --name "kubify-$$env" --admin --region "westus"
kubectl cluster-info
az aks get-credentials --resource-group "kubify-$$env" --name "kubify-$$env" --admin --region "eastus"
kubectl cluster-info
cloud-delete: #clouds reset nonprod envs
echo "deleting cloud env $$env"
gcloud config set project kubify-os || gcloud auth application-default login
gcloud config set project kubify-os
aws sts get-caller-identity >/dev/null || aws configure
az ad signed-in-user list-owned-objects >/dev/null || az login
az ad signed-in-user list-owned-objects >/dev/null || az login
tfenv install v1.3.0 >/dev/null
tfenv use v1.3.0
export state_name="kubify-$$env-tf-state-$(aws_account_id_for_state)" && \
cd ./kubify/ops/terraform && \
terraform init --reconfigure --backend-config="bucket=$$state_name" --backend-config="dynamodb_table=$$state_name" --backend-config="region=us-west-1" && \
terraform destroy --var="cluster_name=kubify-$$env"
cloud-create: #aws azure or gcp (make cloud cloud=[aws|azure|gcp] env=[dev|test|prod])
echo "creating cloud env $$env"
tfsec
gcloud config set project kubify-os || gcloud auth application-default login
gcloud config set project kubify-os
aws sts get-caller-identity >/dev/null || aws configure
az ad signed-in-user list-owned-objects >/dev/null || az login
az ad signed-in-user list-owned-objects >/dev/null || az login
tfenv install v1.3.0 >/dev/null
tfenv use v1.3.0
export state_name="kubify-$$env-tf-state-$(aws_account_id_for_state)" && \
aws s3 ls s3://$$state_name || aws s3api create-bucket --bucket $$state_name --region us-west-1 --create-bucket-configuration LocationConstraint=us-west-1 && \
aws s3api put-bucket-encryption --bucket $$state_name --server-side-encryption-configuration "{\"Rules\": [{\"ApplyServerSideEncryptionByDefault\":{\"SSEAlgorithm\": \"AES256\"}}]}" && \
aws dynamodb describe-table --table-name $$state_name >/dev/null || aws dynamodb create-table --table-name $$state_name --attribute-definitions AttributeName=LockID,AttributeType=S --key-schema AttributeName=LockID,KeyType=HASH --provisioned-throughput ReadCapacityUnits=5,WriteCapacityUnits=5 --region us-west-1 && \
cd ./kubify/ops/terraform && \
terraform init --reconfigure --backend-config="bucket=$$state_name" --backend-config="dynamodb_table=$$state_name" --backend-config="region=us-west-1" && \
terraform apply --var="cluster_name=kubify-$$env" || terraform state rm module.aws.module.eks-dr-us-east-1.module.eks.kubernetes_config_map_v1_data.aws_auth
docker:
make security
make format
make lint
docker build . -t kubify:latest
docker tag kubify:latest docker.io/willy0912/kubify:latest
docker-test-all-pythons:
docker build . -t kubify:latest -f Dockerfile.pythons
docker tag kubify:latest docker.io/willy0912/kubify:latest
security:
bandit -r . -c .bandit.yml --exclude ./.tox
package:
python3 setup.py sdist bdist_wheel
clean:
rm -rf ./._* ./.aws ./build ./venv ./kubify/ops/terraform/.terra* docs/*build docs/build *.pyc *.pyo .*cache .pytest_* .pytest-*
# test every version of python enabled
tox:
echo $$DEBIAN_FRONTEND | grep noninteractive && tox -e py38,py310 -p all || \
tox -e py37,py38,py39,py310,py311,py312 -p all
pythons-cache:
echo $$DEBIAN_FRONTEND | grep noninteractive && tox -e py38,py310 -p all --notest || \
tox -e py37,py38,py39,py310,py311,py312 -p all --notest
pythons:
make conda-build
make tox
# mac intel, m1, m2 and other darwin-based (in case you want to install outside container while contributing) ..
mac-direct-install:
ansible-playbook --connection=local "ansible/install_kubify_on_mac.yaml" --ask-become-pass -e ansible_python_interpreter=`which python3`
# ubuntu, debian and other debian-based ..
deb-direct-install:
ansible-playbook --connection=local "ansible/install_kubify_on_debian_ubuntu_and_wsl2.yaml" --ask-become-pass -e ansible_python_interpreter=`which python3`
# rhel, centos and other epel-based ..
epel-direct-install:
ansible-playbook --connection=local "ansible/install_kubify_on_amzn2_centos_fedora_oracle_and_rhel.yaml" --ask-become-pass -e ansible_python_interpreter=`which python3`
aws-list:
aws eks list-clusters --output json
# cloud deploy now
argo-create-services:
argocd cluster add --name kubify-aws-west2-eks --server https://api.argoproj.io --token $$(cat $$HOME/.argocd/token)
argocd app patch app-of-apps --patch '{"spec": { "source": { "repoURL": "https://github.com/willyguggenheim/kubify.git" } }}' --type merge
argocd cluster add --name kubify-aws-east1-eks-dr --server https://api.argoproj.io --token $$(cat $$HOME/.argocd/token)
argocd app patch app-of-apps --patch '{"spec": { "source": { "repoURL": "https://github.com/willyguggenheim/kubify.git" } }}' --type merge
argo-delete-services:
argocd cluster add --name kubify-aws-west2-eks --server https://api.argoproj.io --token $$(cat $$HOME/.argocd/token)
argocd app delete app-of-apps --patch '{"spec": { "source": { "repoURL": "https://github.com/willyguggenheim/kubify.git" } }}' --type merge
argocd cluster add --name kubify-aws-east1-eks-dr --server https://api.argoproj.io --token $$(cat $$HOME/.argocd/token)
argocd app delete app-of-apps --patch '{"spec": { "source": { "repoURL": "https://github.com/willyguggenheim/kubify.git" } }}' --type merge
conda:
which conda || export PATH=$$PATH:/opt/conda/bin
which conda || alias conda=/opt/conda/bin/conda
conda --version || make conda-install
conda --version || conda init shell
conda info | grep "active environment" | grep kubify || make conda-setup
conda install -y -c conda-forge conda-build
conda-build:
which conda || export PATH=$$PATH:/opt/conda/bin
which conda || alias conda=/opt/conda/bin/conda
echo $$DEBIAN_FRONTEND | grep noninteractive && conda build --python 3.8 --output-folder ./build/conda install . || \
conda build --python 3.7 --python 3.8 --python 3.9 --python 3.10 --python 3.11 --python 3.12 --output-folder ./build/conda .
conda-install:
bash ./kubify/ops/tools/scripts/conda_install.sh
conda-setup:
bash ./kubify/ops/tools/scripts/conda_setup.sh
develop:
echo $$OSTYPE | grep arwin && make mac || make apt
make pip
make security
make coverage