Klement Sekera | 277b89c | 2016-10-28 13:20:27 +0200 | [diff] [blame] | 1 | .PHONY: verify-python-path |
Damjan Marion | f56b77a | 2016-10-03 19:44:57 +0200 | [diff] [blame] | 2 | |
Klement Sekera | 277b89c | 2016-10-28 13:20:27 +0200 | [diff] [blame] | 3 | verify-python-path: |
| 4 | ifndef VPP_PYTHON_PREFIX |
| 5 | $(error VPP_PYTHON_PREFIX is not set) |
| 6 | endif |
| 7 | |
Klement Sekera | b93d142 | 2017-03-02 08:16:20 +0100 | [diff] [blame] | 8 | .PHONY: verify-no-running-vpp |
| 9 | |
| 10 | ifdef VPP_ZOMBIE_NOCHECK |
| 11 | VPP_PIDS= |
| 12 | else |
| 13 | VPP_PIDS=$(shell pgrep -d, -x vpp_main) |
| 14 | endif |
| 15 | |
| 16 | verify-no-running-vpp: |
| 17 | @if [ "$(VPP_PIDS)" != "" ]; then \ |
| 18 | echo; \ |
| 19 | echo "*** Existing vpp processes detected (PID(s): $(VPP_PIDS)). Running tests under these conditions is not supported. ***"; \ |
| 20 | echo; \ |
| 21 | ps -fp $(VPP_PIDS);\ |
| 22 | echo; \ |
| 23 | false; \ |
| 24 | fi |
| 25 | |
Klement Sekera | 993e0ed | 2017-03-16 09:14:59 +0100 | [diff] [blame] | 26 | UNITTEST_EXTRA_OPTS= |
| 27 | UNITTEST_FAILFAST_OPTS= |
Klement Sekera | acb9b8e | 2017-02-14 02:55:31 +0100 | [diff] [blame] | 28 | |
| 29 | ifeq ($(FAILFAST),1) |
Klement Sekera | 993e0ed | 2017-03-16 09:14:59 +0100 | [diff] [blame] | 30 | UNITTEST_EXTRA_OPTS=-f |
| 31 | endif |
| 32 | |
| 33 | ifneq ($(EXTERN_TESTS),) |
| 34 | UNITTEST_EXTRA_OPTS=$(UNITTEST_FAILFAST_OPTS) -d $(EXTERN_TESTS) |
Klement Sekera | acb9b8e | 2017-02-14 02:55:31 +0100 | [diff] [blame] | 35 | endif |
| 36 | |
Klement Sekera | 277b89c | 2016-10-28 13:20:27 +0200 | [diff] [blame] | 37 | PYTHON_VENV_PATH=$(VPP_PYTHON_PREFIX)/virtualenv |
Klement Sekera | 3658adc | 2017-06-07 08:19:47 +0200 | [diff] [blame] | 38 | PYTHON_DEPENDS=faulthandler six scapy==2.3.3 pexpect subprocess32 cffi git+https://github.com/klement/py-lispnetworking@setup |
vagrant | 937bf30 | 2017-04-07 01:48:47 +0000 | [diff] [blame] | 39 | SCAPY_SOURCE=$(shell find $(PYTHON_VENV_PATH) -name site-packages) |
| 40 | BUILD_COV_DIR=$(BR)/test-cov |
Klement Sekera | 277b89c | 2016-10-28 13:20:27 +0200 | [diff] [blame] | 41 | |
vagrant | 937bf30 | 2017-04-07 01:48:47 +0000 | [diff] [blame] | 42 | GET_PIP_SCRIPT=$(VPP_PYTHON_PREFIX)/get-pip.py |
Klement Sekera | 9f9d07b | 2016-12-12 09:20:50 +0100 | [diff] [blame] | 43 | PIP_INSTALL_DONE=$(VPP_PYTHON_PREFIX)/pip-install.done |
| 44 | PIP_PATCH_DONE=$(VPP_PYTHON_PREFIX)/pip-patch.done |
| 45 | PAPI_INSTALL_DONE=$(VPP_PYTHON_PREFIX)/papi-install.done |
Neale Ranns | 177bbdc | 2016-11-15 09:46:51 +0000 | [diff] [blame] | 46 | |
Klement Sekera | 9f9d07b | 2016-12-12 09:20:50 +0100 | [diff] [blame] | 47 | PAPI_INSTALL_FLAGS=$(PIP_INSTALL_DONE) $(PIP_PATCH_DONE) $(PAPI_INSTALL_DONE) |
| 48 | |
vagrant | 937bf30 | 2017-04-07 01:48:47 +0000 | [diff] [blame] | 49 | ifeq ($(PYTHON),) |
| 50 | PYTHON_INTERP=python2.7 |
| 51 | else |
| 52 | PYTHON_INTERP=$(PYTHON) |
| 53 | endif |
| 54 | |
| 55 | $(GET_PIP_SCRIPT): |
| 56 | @mkdir -p $(VPP_PYTHON_PREFIX) |
| 57 | @bash -c "cd $(VPP_PYTHON_PREFIX) && curl -O https://bootstrap.pypa.io/get-pip.py" |
| 58 | |
| 59 | $(PIP_INSTALL_DONE): $(GET_PIP_SCRIPT) |
| 60 | @virtualenv $(PYTHON_VENV_PATH) -p $(PYTHON_INTERP) |
| 61 | @bash -c "source $(PYTHON_VENV_PATH)/bin/activate && python $(GET_PIP_SCRIPT)" |
Klement Sekera | 778c276 | 2016-11-08 02:00:28 +0100 | [diff] [blame] | 62 | @bash -c "source $(PYTHON_VENV_PATH)/bin/activate && pip install $(PYTHON_DEPENDS)" |
Neale Ranns | 177bbdc | 2016-11-15 09:46:51 +0000 | [diff] [blame] | 63 | @touch $@ |
| 64 | |
Klement Sekera | 9f9d07b | 2016-12-12 09:20:50 +0100 | [diff] [blame] | 65 | $(PIP_PATCH_DONE): $(PIP_INSTALL_DONE) |
Neale Ranns | 177bbdc | 2016-11-15 09:46:51 +0000 | [diff] [blame] | 66 | @echo --- patching --- |
Dave Wallace | 6f692d6 | 2017-01-26 21:07:10 -0500 | [diff] [blame] | 67 | @sleep 1 # Ensure python recompiles patched *.py files -> *.pyc |
Neale Ranns | 177bbdc | 2016-11-15 09:46:51 +0000 | [diff] [blame] | 68 | for f in $(CURDIR)/patches/scapy-2.3.3/*.patch ; do \ |
| 69 | echo Applying patch: $$(basename $$f) ; \ |
| 70 | patch -p1 -d $(SCAPY_SOURCE) < $$f ; \ |
| 71 | done |
| 72 | @touch $@ |
| 73 | |
Klement Sekera | 9f9d07b | 2016-12-12 09:20:50 +0100 | [diff] [blame] | 74 | $(PAPI_INSTALL_DONE): $(PIP_PATCH_DONE) |
Damjan Marion | 37d77e9 | 2016-12-28 15:14:46 +0100 | [diff] [blame] | 75 | @bash -c "source $(PYTHON_VENV_PATH)/bin/activate && cd $(WS_ROOT)/src/vpp-api/python && python setup.py install" |
Neale Ranns | 177bbdc | 2016-11-15 09:46:51 +0000 | [diff] [blame] | 76 | @touch $@ |
| 77 | |
Juraj Sloboda | 0279b29 | 2016-11-16 19:50:24 +0100 | [diff] [blame] | 78 | define retest-func |
Klement Sekera | 94384e4 | 2017-07-11 07:29:37 +0200 | [diff] [blame] | 79 | @bash -c "source $(PYTHON_VENV_PATH)/bin/activate && setsid scripts/run_with_cleanup.sh python run_tests.py -d $(TEST_DIR) $(UNITTEST_EXTRA_OPTS)" |
Juraj Sloboda | 0279b29 | 2016-11-16 19:50:24 +0100 | [diff] [blame] | 80 | endef |
| 81 | |
Klement Sekera | c160ae0 | 2017-03-09 08:20:13 +0100 | [diff] [blame] | 82 | .PHONY: sanity |
| 83 | |
| 84 | sanity: verify-no-running-vpp |
| 85 | @bash -c "source $(PYTHON_VENV_PATH)/bin/activate && python sanity_import_vpp_papi.py ||\ |
| 86 | (echo \"*******************************************************************\" &&\ |
| 87 | echo \"* Sanity check failed, cannot import vpp_papi\" &&\ |
| 88 | echo \"* to debug: \" &&\ |
| 89 | echo \"* 1. enter test shell: make test-shell\" &&\ |
| 90 | echo \"* 2. execute debugger: gdb python -ex 'run sanity_import_vpp_papi.py'\" &&\ |
| 91 | echo \"*******************************************************************\" &&\ |
| 92 | false)" |
Klement Sekera | 3747c75 | 2017-04-10 06:30:17 +0200 | [diff] [blame] | 93 | @bash -c "source $(PYTHON_VENV_PATH)/bin/activate && python sanity_run_vpp.py ||\ |
| 94 | (echo \"*******************************************************************\" &&\ |
| 95 | echo \"* Sanity check failed, cannot run vpp\" &&\ |
| 96 | echo \"*******************************************************************\" &&\ |
| 97 | false)" |
Klement Sekera | c160ae0 | 2017-03-09 08:20:13 +0100 | [diff] [blame] | 98 | |
| 99 | test: verify-python-path $(PAPI_INSTALL_DONE) sanity reset |
Juraj Sloboda | 0279b29 | 2016-11-16 19:50:24 +0100 | [diff] [blame] | 100 | $(call retest-func) |
Klement Sekera | f62ae12 | 2016-10-11 11:47:09 +0200 | [diff] [blame] | 101 | |
Klement Sekera | c160ae0 | 2017-03-09 08:20:13 +0100 | [diff] [blame] | 102 | retest: verify-python-path sanity reset |
Juraj Sloboda | 0279b29 | 2016-11-16 19:50:24 +0100 | [diff] [blame] | 103 | $(call retest-func) |
Klement Sekera | f62ae12 | 2016-10-11 11:47:09 +0200 | [diff] [blame] | 104 | |
Klement Sekera | a86e289 | 2017-03-09 08:01:52 +0100 | [diff] [blame] | 105 | shell: verify-python-path $(PAPI_INSTALL_DONE) |
| 106 | @echo "source $(PYTHON_VENV_PATH)/bin/activate;\ |
| 107 | echo '***';\ |
| 108 | echo VPP_TEST_BUILD_DIR=$(VPP_TEST_BUILD_DIR);\ |
| 109 | echo VPP_TEST_BIN=$(VPP_TEST_BIN);\ |
| 110 | echo VPP_TEST_PLUGIN_PATH=$(VPP_TEST_PLUGIN_PATH);\ |
| 111 | echo VPP_TEST_INSTALL_PATH=$(VPP_TEST_INSTALL_PATH);\ |
Klement Sekera | 47e275b | 2017-03-21 08:21:25 +0100 | [diff] [blame] | 112 | echo EXTERN_TESTS=$(EXTERN_TESTS);\ |
| 113 | echo EXTERN_PLUGINS=$(EXTERN_PLUGINS);\ |
Klement Sekera | cd6cb98 | 2017-05-11 06:55:32 +0200 | [diff] [blame] | 114 | echo EXTERN_COV_DIR=$(EXTERN_COV_DIR);\ |
Klement Sekera | a86e289 | 2017-03-09 08:01:52 +0100 | [diff] [blame] | 115 | echo LD_LIBRARY_PATH=$(LD_LIBRARY_PATH);\ |
| 116 | echo '***';\ |
| 117 | exec </dev/tty" | bash -i |
| 118 | |
Klement Sekera | 277b89c | 2016-10-28 13:20:27 +0200 | [diff] [blame] | 119 | .PHONY: wipe doc |
Klement Sekera | f62ae12 | 2016-10-11 11:47:09 +0200 | [diff] [blame] | 120 | |
Neale Ranns | 177bbdc | 2016-11-15 09:46:51 +0000 | [diff] [blame] | 121 | reset: |
Klement Sekera | f62ae12 | 2016-10-11 11:47:09 +0200 | [diff] [blame] | 122 | @rm -f /dev/shm/vpp-unittest-* |
| 123 | @rm -rf /tmp/vpp-unittest-* |
| 124 | |
Neale Ranns | 177bbdc | 2016-11-15 09:46:51 +0000 | [diff] [blame] | 125 | wipe: reset |
Klement Sekera | 9f9d07b | 2016-12-12 09:20:50 +0100 | [diff] [blame] | 126 | @rm -rf $(PYTHON_VENV_PATH) |
| 127 | @rm -f $(PAPI_INSTALL_FLAGS) |
Neale Ranns | 177bbdc | 2016-11-15 09:46:51 +0000 | [diff] [blame] | 128 | |
Klement Sekera | 6320514 | 2017-02-03 08:18:53 +0100 | [diff] [blame] | 129 | doc: verify-python-path $(PIP_PATCH_DONE) |
vagrant | 937bf30 | 2017-04-07 01:48:47 +0000 | [diff] [blame] | 130 | @virtualenv $(PYTHON_VENV_PATH) -p $(PYTHON_INTERP) |
Klement Sekera | 6320514 | 2017-02-03 08:18:53 +0100 | [diff] [blame] | 131 | @bash -c "source $(PYTHON_VENV_PATH)/bin/activate && pip install sphinx sphinx-rtd-theme" |
Klement Sekera | 277b89c | 2016-10-28 13:20:27 +0200 | [diff] [blame] | 132 | @bash -c "source $(PYTHON_VENV_PATH)/bin/activate && make -C doc WS_ROOT=$(WS_ROOT) BR=$(BR) NO_VPP_PAPI=1 html" |
| 133 | |
Klement Sekera | 9f9d07b | 2016-12-12 09:20:50 +0100 | [diff] [blame] | 134 | .PHONY: wipe-doc |
| 135 | |
Klement Sekera | 277b89c | 2016-10-28 13:20:27 +0200 | [diff] [blame] | 136 | wipe-doc: |
| 137 | @make -C doc wipe BR=$(BR) |
| 138 | |
Klement Sekera | 9f9d07b | 2016-12-12 09:20:50 +0100 | [diff] [blame] | 139 | cov: wipe-cov reset verify-python-path $(PAPI_INSTALL_DONE) |
Juraj Sloboda | 0279b29 | 2016-11-16 19:50:24 +0100 | [diff] [blame] | 140 | @lcov --zerocounters --directory $(VPP_TEST_BUILD_DIR) |
Klement Sekera | cd6cb98 | 2017-05-11 06:55:32 +0200 | [diff] [blame] | 141 | @test -z "$(EXTERN_COV_DIR)" || lcov --zerocounters --directory $(EXTERN_COV_DIR) |
Juraj Sloboda | 0279b29 | 2016-11-16 19:50:24 +0100 | [diff] [blame] | 142 | $(call retest-func) |
| 143 | @mkdir $(BUILD_COV_DIR) |
| 144 | @lcov --capture --directory $(VPP_TEST_BUILD_DIR) --output-file $(BUILD_COV_DIR)/coverage.info |
Klement Sekera | cd6cb98 | 2017-05-11 06:55:32 +0200 | [diff] [blame] | 145 | @test -z "$(EXTERN_COV_DIR)" || lcov --capture --directory $(EXTERN_COV_DIR) --output-file $(BUILD_COV_DIR)/extern-coverage.info |
Juraj Sloboda | 0279b29 | 2016-11-16 19:50:24 +0100 | [diff] [blame] | 146 | @genhtml $(BUILD_COV_DIR)/coverage.info --output-directory $(BUILD_COV_DIR)/html |
Klement Sekera | cd6cb98 | 2017-05-11 06:55:32 +0200 | [diff] [blame] | 147 | @test -z "$(EXTERN_COV_DIR)" || genhtml $(BUILD_COV_DIR)/extern-coverage.info --output-directory $(BUILD_COV_DIR)/extern-html |
Juraj Sloboda | 0279b29 | 2016-11-16 19:50:24 +0100 | [diff] [blame] | 148 | @echo |
| 149 | @echo "Build finished. Code coverage report is in $(BUILD_COV_DIR)/html/index.html" |
Klement Sekera | cd6cb98 | 2017-05-11 06:55:32 +0200 | [diff] [blame] | 150 | @test -z "$(EXTERN_COV_DIR)" || echo "Code coverage report for out-of-tree objects is in $(BUILD_COV_DIR)/extern-html/index.html" |
Juraj Sloboda | 0279b29 | 2016-11-16 19:50:24 +0100 | [diff] [blame] | 151 | |
Klement Sekera | 9f9d07b | 2016-12-12 09:20:50 +0100 | [diff] [blame] | 152 | .PHONY: wipe-cov |
| 153 | |
Juraj Sloboda | 0279b29 | 2016-11-16 19:50:24 +0100 | [diff] [blame] | 154 | wipe-cov: wipe |
| 155 | @rm -rf $(BUILD_COV_DIR) |
| 156 | |
Klement Sekera | 72715ee | 2017-01-17 10:37:05 +0100 | [diff] [blame] | 157 | .PHONY: checkstyle |
| 158 | checkstyle: verify-python-path |
vagrant | 937bf30 | 2017-04-07 01:48:47 +0000 | [diff] [blame] | 159 | @virtualenv $(PYTHON_VENV_PATH) -p $(PYTHON_INTERP) |
Neale Ranns | aaa396a | 2017-02-05 09:12:02 -0800 | [diff] [blame] | 160 | @bash -c "source $(PYTHON_VENV_PATH)/bin/activate && pip install pep8" |
Klement Sekera | 72715ee | 2017-01-17 10:37:05 +0100 | [diff] [blame] | 161 | @bash -c "source $(PYTHON_VENV_PATH)/bin/activate &&\ |
| 162 | pep8 --show-source -v $(WS_ROOT)/test/*.py ||\ |
| 163 | (echo \"*******************************************************************\" &&\ |
| 164 | echo \"* Test framework PEP8 compliance check FAILED \" &&\ |
| 165 | echo \"*******************************************************************\" &&\ |
| 166 | false)" |
| 167 | @echo "*******************************************************************" |
| 168 | @echo "* Test framework PEP8 compliance check passed" |
| 169 | @echo "*******************************************************************" |
| 170 | |
Klement Sekera | 277b89c | 2016-10-28 13:20:27 +0200 | [diff] [blame] | 171 | help: |
| 172 | @echo "Running tests:" |
| 173 | @echo "" |
Klement Sekera | 8713493 | 2017-03-07 11:39:27 +0100 | [diff] [blame] | 174 | @echo " test - build and run (basic) functional tests" |
| 175 | @echo " test-debug - build and run (basic) functional tests (debug build)" |
| 176 | @echo " test-all - build and run (all) functional tests" |
| 177 | @echo " test-all-debug - build and run (all) functional tests (debug build)" |
Klement Sekera | 277b89c | 2016-10-28 13:20:27 +0200 | [diff] [blame] | 178 | @echo " retest - run functional tests" |
| 179 | @echo " retest-debug - run functional tests (debug build)" |
Juraj Sloboda | 0279b29 | 2016-11-16 19:50:24 +0100 | [diff] [blame] | 180 | @echo " test-wipe - wipe (temporary) files generated by unit tests" |
Klement Sekera | a86e289 | 2017-03-09 08:01:52 +0100 | [diff] [blame] | 181 | @echo " test-shell - enter shell with test environment" |
| 182 | @echo " test-shell-debug - enter shell with test environment (debug build)" |
Klement Sekera | 277b89c | 2016-10-28 13:20:27 +0200 | [diff] [blame] | 183 | @echo "" |
| 184 | @echo "Arguments controlling test runs:" |
| 185 | @echo " V=[0|1|2] - set test verbosity level" |
Klement Sekera | acb9b8e | 2017-02-14 02:55:31 +0100 | [diff] [blame] | 186 | @echo " FAILFAST=[0|1] - fail fast if 1, complete all tests if 0" |
Klement Sekera | 909a6a1 | 2017-08-08 04:33:53 +0200 | [diff] [blame^] | 187 | @echo " TIMEOUT=<timeout> - fail test suite if any single test takes longer than <timeout> to finish" |
Klement Sekera | 277b89c | 2016-10-28 13:20:27 +0200 | [diff] [blame] | 188 | @echo " DEBUG=<type> - set VPP debugging kind" |
| 189 | @echo " DEBUG=core - detect coredump and load it in gdb on crash" |
| 190 | @echo " DEBUG=gdb - allow easy debugging by printing VPP PID " |
| 191 | @echo " and waiting for user input before running " |
| 192 | @echo " and tearing down a testcase" |
| 193 | @echo " DEBUG=gdbserver - run gdb inside a gdb server, otherwise " |
| 194 | @echo " same as above" |
| 195 | @echo " STEP=[yes|no] - ease debugging by stepping through a testcase " |
Klement Sekera | 104543f | 2017-02-03 07:29:43 +0100 | [diff] [blame] | 196 | @echo " TEST=<filter> - filter the set of tests:" |
| 197 | @echo " by file-name - only run tests from specified file, e.g. TEST=test_bfd selects all tests from test_bfd.py" |
| 198 | @echo " by file-suffix - same as file-name, but 'test_' is omitted e.g. TEST=bfd selects all tests from test_bfd.py" |
| 199 | @echo " by wildcard - wildcard filter is <file>.<class>.<test function>, each can be replaced by '*'" |
| 200 | @echo " e.g. TEST='test_bfd.*.*' is equivalent to above example of filter by file-name" |
| 201 | @echo " TEST='bfd.*.*' is equivalent to above example of filter by file-suffix" |
| 202 | @echo " TEST='bfd.BFDAPITestCase.*' selects all tests from test_bfd.py which are part of BFDAPITestCase class" |
| 203 | @echo " TEST='bfd.BFDAPITestCase.test_add_bfd' selects a single test named test_add_bfd from test_bfd.py/BFDAPITestCase" |
| 204 | @echo " TEST='*.*.test_add_bfd' selects all test functions named test_add_bfd from all files/classes" |
Klement Sekera | 277b89c | 2016-10-28 13:20:27 +0200 | [diff] [blame] | 205 | @echo "" |
Klement Sekera | b93d142 | 2017-03-02 08:16:20 +0100 | [diff] [blame] | 206 | @echo " VPP_ZOMBIE_NOCHECK=1 - skip checking for vpp (zombie) processes (CAUTION)" |
Klement Sekera | 80a7f0a | 2017-03-02 11:27:11 +0100 | [diff] [blame] | 207 | @echo " COREDUMP_SIZE=<size> - pass <size> as unix { coredump-size <size> } argument to vpp" |
| 208 | @echo " e.g. COREDUMP_SIZE=4g" |
| 209 | @echo " COREDUMP_SIZE=unlimited" |
Klement Sekera | 47e275b | 2017-03-21 08:21:25 +0100 | [diff] [blame] | 210 | @echo " EXTERN_TESTS=<path> - path to out-of-tree test_<name>.py files containing test cases" |
| 211 | @echo " EXTERN_PLUGINS=<path>- path to out-of-tree plugins to be loaded by vpp under test" |
Klement Sekera | cd6cb98 | 2017-05-11 06:55:32 +0200 | [diff] [blame] | 212 | @echo " EXTERN_COV_DIR=<path>- path to out-of-tree prefix, where source, object and .gcda files can be found for coverage report" |
Klement Sekera | b93d142 | 2017-03-02 08:16:20 +0100 | [diff] [blame] | 213 | @echo "" |
Klement Sekera | 277b89c | 2016-10-28 13:20:27 +0200 | [diff] [blame] | 214 | @echo "Creating test documentation" |
| 215 | @echo " test-doc - generate documentation for test framework" |
Juraj Sloboda | 0279b29 | 2016-11-16 19:50:24 +0100 | [diff] [blame] | 216 | @echo " test-wipe-doc - wipe documentation for test framework" |
| 217 | @echo "" |
| 218 | @echo "Creating test code coverage report" |
| 219 | @echo " test-cov - generate code coverage report for test framework" |
| 220 | @echo " test-wipe-cov - wipe code coverage report for test framework" |
Klement Sekera | 277b89c | 2016-10-28 13:20:27 +0200 | [diff] [blame] | 221 | @echo "" |
Klement Sekera | 72715ee | 2017-01-17 10:37:05 +0100 | [diff] [blame] | 222 | @echo "Verifying code-style" |
| 223 | @echo " test-checkstyle - check PEP8 compliance" |
| 224 | @echo "" |