summaryrefslogtreecommitdiffstats
path: root/ansible_collections/sensu/sensu_go/Makefile
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-28 16:03:42 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-28 16:03:42 +0000
commit66cec45960ce1d9c794e9399de15c138acb18aed (patch)
tree59cd19d69e9d56b7989b080da7c20ef1a3fe2a5a /ansible_collections/sensu/sensu_go/Makefile
parentInitial commit. (diff)
downloadansible-upstream.tar.xz
ansible-upstream.zip
Adding upstream version 7.3.0+dfsg.upstream/7.3.0+dfsgupstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'ansible_collections/sensu/sensu_go/Makefile')
-rw-r--r--ansible_collections/sensu/sensu_go/Makefile83
1 files changed, 83 insertions, 0 deletions
diff --git a/ansible_collections/sensu/sensu_go/Makefile b/ansible_collections/sensu/sensu_go/Makefile
new file mode 100644
index 00000000..abadb048
--- /dev/null
+++ b/ansible_collections/sensu/sensu_go/Makefile
@@ -0,0 +1,83 @@
+# Make sure we have ansible_collections/sensu/sensu_go as a prefix. This is
+# ugly as heck, but it works. I suggest all future developer to treat next few
+# lines as an opportunity to learn a thing or two about GNU make ;)
+collection := $(notdir $(realpath $(CURDIR) ))
+namespace := $(notdir $(realpath $(CURDIR)/.. ))
+toplevel := $(notdir $(realpath $(CURDIR)/../..))
+
+err_msg := Place collection at <WHATEVER>/ansible_collections/sensu/sensu_go
+ifeq (true,$(CI))
+ $(info Running in CI setting, skipping directory checks.)
+else ifneq (sensu_go,$(collection))
+ $(error $(err_msg))
+else ifneq (sensu,$(namespace))
+ $(error $(err_msg))
+else ifneq (ansible_collections,$(toplevel))
+ $(error $(err_msg))
+endif
+
+python_version := $(shell \
+ python -c 'import sys; print(".".join(map(str, sys.version_info[:2])))' \
+)
+
+molecule_scenarios := $(wildcard tests/integration/molecule/*)
+
+
+.PHONY: help
+help:
+ @echo Available targets:
+ @fgrep "##" $(MAKEFILE_LIST) | fgrep -v fgrep | sort
+
+.PHONY: sanity
+sanity: ## Run sanity tests
+ pip3 install -r sanity.requirements -r collection.requirements
+ pip install pyyaml
+ flake8
+ if which ansible-lint 2> /dev/null; then ansible-lint -p roles/*; fi
+ ansible-test sanity --docker
+ python3 ./tests/sanity/validate-role-metadata.py roles/*
+
+.PHONY: units
+units: ## Run unit tests
+ pip3 install -r collection.requirements
+ -ansible-test coverage erase # On first run, there is nothing to erase.
+ ansible-test units --docker --coverage
+ ansible-test coverage html --requirements
+ ansible-test coverage report --omit 'tests/*' --show-missing
+
+.PHONY: integration
+integration: ## Run integration tests
+ pip3 install -r integration.requirements -r collection.requirements
+ pytest -s --molecule-base-config=base.yml tests/integration/molecule
+
+.PHONY: $(molecule_scenarios)
+$(molecule_scenarios):
+ pytest -s --molecule-base-config=base.yml $@
+
+.PHONY: integration_ci
+integration_ci: ## Run integration tests on CircleCI
+ pip3 install -r integration.requirements -r collection.requirements
+ mkdir -p test_results/integration
+ pytest -s \
+ --junitxml=test_results/integration/junit.xml \
+ --molecule-base-config=base.yml \
+ $$(circleci tests glob "tests/integration/molecule/*/molecule.yml" \
+ | circleci tests split --split-by=timings)
+
+.PHONY: docs
+docs: ## Build collection documentation
+ pip3 install -r docs.requirements
+ $(MAKE) -C docs -f Makefile.custom docs
+
+.PHONY: clean
+clean: ## Remove all auto-generated files
+ $(MAKE) -C docs -f Makefile.custom clean
+ rm -rf tests/output test_results
+
+.PHONY: check_windows_versions
+check_windows_versions: ## Check if our and upstream versions drifed apart
+ tools/windows-versions.py check roles/install/vars/Windows.yml
+
+.PHONY: update_windows_versions
+update_windows_versions: ## Update Windows versions in variable file
+ tools/windows-versions.py update roles/install/vars/Windows.yml