forked from aristanetworks/avd
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMakefile
155 lines (131 loc) · 6.07 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
CURRENT_DIR = $(shell pwd)
# ansible-test path
ANSIBLE_TEST ?= $(shell which ansible-test)
# option to run ansible-test sanity: must be either venv or docker (default is docker)
ANSIBLE_TEST_MODE ?= docker
# Root path for MKDOCS content
WEBDOC_BUILD = ansible_collections/arista/avd/docs/_build
COMPOSE_FILE ?= development/docker-compose.yml
MUFFET_TIMEOUT ?= 60
SED_OPT ?= -i '.original'
.PHONY: help
help: ## Display help message
@grep -E '^[0-9a-zA-Z_-]+\.*[0-9a-zA-Z_-]+:.*?## .*$$' $(MAKEFILE_LIST) | sort | awk 'BEGIN {FS = ":.*?## "}; {printf "\033[36m%-30s\033[0m %s\n", $$1, $$2}'
#########################################
# Ansible Collection actions #
#########################################
.PHONY: collection-build
collection-build: ## Build arista.cvp collection locally
ansible-galaxy collection build --force ansible_collections/arista/avd
.PHONY: collection-install
collection-install: ## Install arista.cvp collection to default location (~/.ansible/collections/ansible_collections)
for collection in *.tar.gz; do \
ansible-galaxy collection install $$collection ;\
done
#########################################
# Code Validation using ansible-test #
#########################################
.PHONY: sanity
sanity: sanity-info sanity-lint sanity-import ## Run ansible-test sanity validation.
.PHONY: sanity-info
sanity-info: ## Show information about ansible-test
cd ansible_collections/arista/avd/ ; ansible-test env
.PHONY: sanity-lint
sanity-lint: ## Run ansible-test sanity for code sanity
cd ansible_collections/arista/avd/ ; \
mkdir tests ; \
ansible-test sanity --requirements --$(ANSIBLE_TEST_MODE) --skip-test import --skip-test yamllint
.PHONY: sanity-import
sanity-import: ## Run ansible-test sanity for code import
cd ansible_collections/arista/avd/ ; \
mkdir tests ; \
ansible-test sanity --requirements --$(ANSIBLE_TEST_MODE) --test import
#########################################
# Code Validation & CI Actions #
#########################################
.PHONY: linting
linting: ## Run pre-commit script for python code linting using pylint
sh .github/lint-yaml
sh .github/lint-python
.PHONY: pre-commit
pre-commit: ## Execute pre-commit validation for staged files
pre-commit run
.PHONY: pre-commit-all
pre-commit-all: ## Execute pre-commit validation for all files
pre-commit run --all-files
.PHONY: playbook-validation
playbook-validation: ## Run script to validate playbooks defined under testing/ folder
sh .github/run-test-playbooks
#########################################
# Documentation actions #
#########################################
.PHONY: webdoc
webdoc: ## Build documentation to publish static content
( cd $(WEBDOC_BUILD) ; \
python ansible2rst.py ; \
mkdir ../modules/ ; \
find . -name '*.rst' -exec pandoc {} --from rst --to gfm -o ../modules/{}.md \;)
cp $(CURRENT_DIR)/contributing.md $(WEBDOC_BUILD)/.. ;\
cp -r $(CURRENT_DIR)/media $(WEBDOC_BUILD)/../ ;\
cd $(CURRENT_DIR)
mkdocs build -f mkdocs.yml
.PHONY: check-avd-404
check-avd-404: ## Check local 404 links for AVD documentation
docker run --rm --network container:webdoc_avd raviqqe/muffet:1.5.7 http://127.0.0.1:8000 -e ".*fonts.gstatic.com.*" -e ".*edit.*" -f --limit-redirections=3 --timeout=$(MUFFET_TIMEOUT)
#########################################
# Misc Actions (configure CI runner) #
#########################################
.PHONY: github-configure-ci
github-configure-ci: github-configure-ci-python3 github-configure-ci-ansible ## Configure CI environment to run GA (Ubuntu:latest LTS)
.PHONY: github-configure-ci-ansible
github-configure-ci-ansible: ## Install Ansible Test 2.9 on GA (Ubuntu:latest LTS)
sudo apt-get update
sudo apt-get install -y gnupg2
sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 93C4A3FD7BB9C367
sudo echo "deb http://ppa.launchpad.net/ansible/ansible-2.9/ubuntu bionic main" | sudo tee /etc/apt/sources.list.d/ansible.list
sudo echo "deb-src http://ppa.launchpad.net/ansible/ansible-2.9/ubuntu bionic main" | sudo tee -a /etc/apt/sources.list.d/ansible.list
sudo apt-get update
sudo DEBIAN_FRONTEND=noninteractive apt-get install -q -y ansible-test
.PHONY: github-configure-ci-python3
github-configure-ci-python3: ## Configure Python3 environment to run GA (Ubuntu:latest LTS)
sudo apt-get update
sudo apt-get upgrade -y
sudo apt-get install -y python3 python3-pip git python3-setuptools
sudo update-alternatives --install /usr/bin/python python /usr/bin/python3 10
.PHONY: install-requirements
install-requirements: ## Install python requirements for generic purpose
pip3 install --upgrade wheel
pip3 install -r development/requirements.txt
pip3 install -r development/requirements-dev.txt
.PHONY: install-docker
install-docker: ## Install docker
sudo apt install -q -y apt-transport-https ca-certificates curl software-properties-common
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add -
sudo add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/ubuntu bionic stable"
sudo apt update
sudo apt install -q -y docker-ce
.PHONY: ci-check-links-avd
ci-check-links-avd: ## CI workflow to test HTTP link
@echo "--------------------------"
@echo "Starting docker stack for testing"
@echo "--------------------------"
cp development/docker-compose.yml . \
&& sed $(SED_OPT) -e 's/ansible-avd\///g' docker-compose.yml \
&& docker-compose -f docker-compose.yml up -d webdoc_avd \
&& docker-compose -f docker-compose.yml ps
@echo ""
@echo "--------------------------"
@echo "Checking if web server is started"
@echo "--------------------------"
until docker exec webdoc_avd curl -s -I http://localhost:8000/ ; do sleep 2; done
@echo ""
@echo "--------------------------"
@echo "Check HTTP link"
@echo "--------------------------"
docker run --network container:webdoc_avd raviqqe/muffet:1.5.7 http://127.0.0.1:8000/ -e ".*fonts.gstatic.com.*" -e ".*tools.ietf.org.*" -e ".*edit.*" -f --limit-redirections=3 --timeout=30
@echo ""
@echo "--------------------------"
@echo "Shutting down docker stack"
@echo "--------------------------"
docker-compose -f docker-compose.yml down \
&& rm -f docker-compose.*