X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=tox.ini;h=7cae5c70e9e8cf5f9b8b8dd8ddb30037f3d47ad3;hb=f2d880c000de212be9868dbdaf9c8beab7a81045;hp=92b8b4fed6a610cb0f05a6a817c9450d4c70f219;hpb=bb9f540b1796f6ab7a82c03511ca30abbd3326fb;p=transportpce.git diff --git a/tox.ini b/tox.ini index 92b8b4fed..7cae5c70e 100644 --- a/tox.ini +++ b/tox.ini @@ -1,18 +1,27 @@ [tox] minversion = 3.7.0 -envlist = buildcontroller,testsPCE,sims121,tests121,sims221,tests221,sims71,tests71,tests_hybrid - docs - docs-linkcheck - checkbashisms - pre-commit - gitlint +envlist = buildcontroller +  testsPCE, + sims121,build_karaf_tests121,tests121, + sims221,build_karaf_tests221,tests_tapi,tests221, +  sims71,build_karaf_tests71,tests71, + build_karaf_tests_hybrid,tests_hybrid, + buildlighty, + docs +  docs-linkcheck +  checkbashisms +  pre-commit +  pylint skipsdist = true setupdir = tests/ [testenv] -passenv = USE_LIGHTY http_proxy HTTP_PROXY https_proxy HTTPS_PROXY no_proxy NO_PROXY +passenv = USE_LIGHTY, NO_ODL_STARTUP, http_proxy, HTTP_PROXY, https_proxy, HTTPS_PROXY, no_proxy, NO_PROXY, OLM_TIMER1, OLM_TIMER2 setenv = - USE_LIGHTY = True +# USE_LIGHTY=True, + OLM_TIMER1=3000 + OLM_TIMER2=2000 + usedevelop = true basepython = python3 deps = @@ -23,132 +32,220 @@ changedir = {toxinidir}/tests parallel_show_output = true [testenv:buildcontroller] -whitelist_externals = sh - sudo +allowlist_externals = build_controller.sh +commands = + ./build_controller.sh + +[testenv:buildlighty] +allowlist_externals = build.sh +depends = buildcontroller,tests_hybrid +changedir = {toxinidir}/lighty commands = -#install maven and JDK11 on the Gate since they are not there by default - sh -c "which mvn >/dev/null || ./installMavenCentOS.sh" -#install honeynode 1.2.1 simulators -#patch OLM constant to speed up tests, unnecessary for PCE tests - sh -c "sed -i'_' 's@=.*//#FUNCTESTVAL=@=@g' ../olm/src/main/java/org/opendaylight/transportpce/olm/util/OlmUtils.java" -#build controller, source JDK_JAVA_OPTIONS to remove illegal reflective acces warnings introduced by Java11 - sh -c ". $PWD/reflectwarn.sh && cd .. && mvn clean install -B -q -s tests/odl_settings.xml -DskipTests -Dmaven.javadoc.skip=true -Dodlparent.spotbugs.skip -Dodlparent.checkstyle.skip" - sh -c "mv ../olm/src/main/java/org/opendaylight/transportpce/olm/util/OlmUtils.java_ ../olm/src/main/java/org/opendaylight/transportpce/olm/util/OlmUtils.java" -#patch Karaf exec for the same reason at runtime - sh -c "sed -i'_' 's@!/bin/sh@!/bin/sh\'$'\n. $(dirname $0)/../../../../tests/reflectwarn.sh@' ../karaf/target/assembly/bin/karaf" - # the following command would be the straight and right way to support both BSD and GNU sed versions - # sh -c "sed -i'_' '1 a\'$'\n. \$(dirname \$0)/\.\./\.\./\.\./\.\./tests/reflectwarn.sh\n' ../karaf/target/assembly/bin/karaf" - # but tox reinterprets the quotes as - # sh -c 'sed -i'"'"'_'"'"' '"'"'1 a\'"'"'$'"'"'\n. \$(dirname \$0)/\.\./\.\./\.\./\.\./tests/reflectwarn.sh\n'"'"' ../karaf/target/assembly/bin/karaf' - # ,what results in an unexpected different formating (with a $ on the second line and the dot on the third) -#build Lighty if needed - sh -c 'if [ "$USE_LIGHTY" = "True" ]; then (cd ../lighty && ./build.sh); fi' + ./build.sh [testenv:sims121] -whitelist_externals = sh +allowlist_externals = install_honeynode.sh depends = buildcontroller # sims profiles does not strictly depends on buildcontroller # but this dependency avoids race condition in the gate commands = - - sh -c "./install_honeynode.sh 1.2.1" + ./install_honeynode.sh 1.2.1 [testenv:sims221] -whitelist_externals = sh +allowlist_externals = install_honeynode.sh depends = buildcontroller commands = - - sh -c "./install_honeynode.sh 2.2.1" + ./install_honeynode.sh 2.2.1 [testenv:sims71] -whitelist_externals = sh +allowlist_externals = install_honeynode.sh depends = buildcontroller commands = - - sh -c "./install_honeynode.sh 7.1" + ./install_honeynode.sh 7.1 [testenv:testsPCE] depends = buildcontroller +#the following lines retrieve unofficial package of GNPy with REST support from Orange opensource Gitlab repo +setenv = + PIP_EXTRA_INDEX_URL = https://gitlab.com/api/v4/projects/33090323/packages/pypi/simple +# USE_LIGHTY=True +# USE_ODL_RESTCONF_VERSION=draft-bierman02 +deps = + -r{toxinidir}/tests/requirements.txt + -r{toxinidir}/tests/test-requirements.txt + setuptools>=7.0 + gnpy4tpce==2.4.7 +allowlist_externals = launch_tests.sh +passenv = LAUNCHER, USE_LIGHTY, NO_ODL_STARTUP, USE_ODL_RESTCONF_VERSION +basepython = python3 +commands = + ./launch_tests.sh pce {posargs:} + +[testenv:build_karaf_tests121] +depends = buildcontroller +# testsPCE dependency is only here to chain tests in the gate and avoid resources starvation +allowlist_externals = launch_tests.sh +passenv = LAUNCHER, USE_LIGHTY +setenv = +# USE_LIGHTY=True + USE_ODL_ALT_KARAF_ENV=./karaf121.env + USE_ODL_ALT_KARAF_INSTALL_DIR=karaf121 commands = - nosetests --with-xunit transportpce_tests/pce/test_pce.py - nosetests --with-xunit transportpce_tests/pce/test_pce_400G.py + ./build_karaf_for_tests.sh [testenv:tests121] -depends = buildcontroller,sims121,testsPCE -#the last dependency is to avoid temporarily concurrent ressources problem to fix in parallel mode +depends = buildcontroller,build_karaf_tests121,sims121,testsPCE +# testsPCE dependency is only here to chain tests in the gate and avoid resources starvation +allowlist_externals = launch_tests.sh +passenv = LAUNCHER, USE_LIGHTY, NO_ODL_STARTUP, USE_ODL_RESTCONF_VERSION +setenv = +# USE_LIGHTY=True +# USE_ODL_RESTCONF_VERSION=draft-bierman02 + USE_ODL_ALT_KARAF_ENV=./karaf121.env + USE_ODL_ALT_KARAF_INSTALL_DIR=karaf121 commands = - nosetests --with-xunit transportpce_tests/1.2.1/test_portmapping.py - nosetests --with-xunit transportpce_tests/1.2.1/test_topo_portmapping.py - nosetests --with-xunit transportpce_tests/1.2.1/test_topology.py - nosetests --with-xunit transportpce_tests/1.2.1/test_renderer_service_path_nominal.py - nosetests --with-xunit transportpce_tests/1.2.1/test_olm.py - nosetests --with-xunit transportpce_tests/1.2.1/test_end2end.py + ./launch_tests.sh 1.2.1 {posargs:} +# By default, all tests in the folder transportpce_tests/1.2.1/ are run. +# Though, a restricted list of tests can be passed as argument to 'tox -e tests121'. +# For example, 'tox -e tests121 portmapping' will run only the portmapping test. +# and 'tox -e tests121 "portmapping pce"' will run the portmapping and pce tests. +# Additionnally, a different launcher command than 'nosetests --with-xunit' can be +# used by exporting the variable LAUNCHER. For example 'export LAUNCHER="python3"' +# which is more verbose than nose or 'export LAUNCHER="ls -l"' to only list script +# files attributes. + +[testenv:build_karaf_tests221] +depends = buildcontroller +# testsPCE dependency is only here to chain tests in the gate and avoid resources starvation +allowlist_externals = launch_tests.sh +passenv = LAUNCHER, USE_LIGHTY +setenv = +# USE_LIGHTY=True + USE_ODL_ALT_KARAF_ENV=./karaf221.env + USE_ODL_ALT_KARAF_INSTALL_DIR=karaf221 +commands = + ./build_karaf_for_tests.sh [testenv:tests221] -depends = buildcontroller,sims221,tests121 -#the last dependency is to avoid temporarily concurrent ressources problem to fix in parallel mode -commands = - nosetests --with-xunit transportpce_tests/2.2.1/test_portmapping.py - nosetests --with-xunit transportpce_tests/2.2.1/test_topology.py - nosetests --with-xunit transportpce_tests/2.2.1/test_otn_topology.py - nosetests --with-xunit transportpce_tests/2.2.1/test_flex_grid.py - nosetests --with-xunit transportpce_tests/2.2.1/test_renderer_service_path_nominal.py - nosetests --with-xunit transportpce_tests/2.2.1/test_otn_renderer.py - nosetests --with-xunit transportpce_tests/2.2.1/test_otn_sh_renderer.py - nosetests --with-xunit transportpce_tests/2.2.1/test_olm.py - nosetests --with-xunit transportpce_tests/2.2.1/test_tapi.py - nosetests --with-xunit transportpce_tests/2.2.1/test_otn_end2end.py - nosetests --with-xunit transportpce_tests/2.2.1/test_end2end.py +depends = buildcontroller,build_karaf_tests221,sims221,tests71 +# tests71 dependency is only here to chain tests in the gate and avoid ressources starvation +allowlist_externals = launch_tests.sh +passenv = LAUNCHER, USE_LIGHTY, NO_ODL_STARTUP, USE_ODL_RESTCONF_VERSION +setenv = +# USE_LIGHTY=True +# USE_ODL_RESTCONF_VERSION=draft-bierman02 + USE_ODL_ALT_KARAF_ENV=./karaf221.env + USE_ODL_ALT_KARAF_INSTALL_DIR=karaf221 +commands = + ./launch_tests.sh 2.2.1 {posargs:} + +[testenv:build_karaf_tests71] +depends = buildcontroller +# testsPCE dependency is only here to chain tests in the gate and avoid resources starvation +allowlist_externals = launch_tests.sh +passenv = LAUNCHER, USE_LIGHTY +setenv = +# USE_LIGHTY=True + USE_ODL_ALT_KARAF_ENV=./karaf71.env + USE_ODL_ALT_KARAF_INSTALL_DIR=karaf71 +commands = + ./build_karaf_for_tests.sh [testenv:tests71] -depends = buildcontroller,sims71,tests221 -#the last dependency is to avoid temporarily concurrent ressources problem to fix in parallel mode +depends = buildcontroller,build_karaf_tests71,sims71,tests_tapi +allowlist_externals = launch_tests.sh +passenv = LAUNCHER, USE_LIGHTY, NO_ODL_STARTUP, USE_ODL_RESTCONF_VERSION +setenv = +# USE_LIGHTY=True +# USE_ODL_RESTCONF_VERSION=draft-bierman02 + USE_ODL_ALT_KARAF_ENV=./karaf71.env + USE_ODL_ALT_KARAF_INSTALL_DIR=karaf71 commands = - nosetests --with-xunit transportpce_tests/7.1/test_portmapping.py + ./launch_tests.sh 7.1 {posargs:} + +[testenv:build_karaf_tests_hybrid] +depends = buildcontroller +allowlist_externals = launch_tests.sh +passenv = LAUNCHER, USE_LIGHTY +setenv = +# USE_LIGHTY=True + USE_ODL_ALT_KARAF_ENV=./karaf121.env + USE_ODL_ALT_KARAF_INSTALL_DIR=karaf_hybrid +commands = + ./build_karaf_for_tests.sh [testenv:tests_hybrid] -depends = buildcontroller,sims121,sims221,sims71,tests71 -#the last dependency is to avoid temporarily concurrent ressources problem to fix in parallel mode +depends = buildcontroller,build_karaf_tests_hybrid,sims121,sims221,sims71,tests121,tests221,tests71 +#the last dependency is to avoid temporarily concurrent ressources problem in parallel mode +allowlist_externals = launch_tests.sh +passenv = LAUNCHER, USE_LIGHTY, NO_ODL_STARTUP, USE_ODL_RESTCONF_VERSION +setenv = +# USE_LIGHTY=True +# USE_ODL_RESTCONF_VERSION=draft-bierman02 + USE_ODL_ALT_KARAF_ENV=./karaf121.env + USE_ODL_ALT_KARAF_INSTALL_DIR=karaf_hybrid commands = - nosetests --with-xunit transportpce_tests/hybrid/test_device_change_notifications.py +# nosetests --with-xunit transportpce_tests/hybrid/test01_device_change_notifications.py + ./launch_tests.sh hybrid {posargs:} + +[testenv:tests_tapi] +depends = buildcontroller,build_karaf_tests221,sims221 +allowlist_externals = launch_tests.sh add_tapi_feature_to_tests221.sh +passenv = LAUNCHER, USE_LIGHTY, NO_ODL_STARTUP, OLM_TIMER1, OLM_TIMER2, USE_ODL_RESTCONF_VERSION +setenv = +# USE_LIGHTY=True +# USE_ODL_RESTCONF_VERSION=draft-bierman02 + USE_ODL_ALT_KARAF_ENV=./karaf221.env + USE_ODL_ALT_KARAF_INSTALL_DIR=karaf221 + INSTALL_TAPI=True + OLM_TIMER1=3000 + OLM_TIMER2=2000 -[testenv:gnpy] -depends = buildcontroller -whitelist_externals = sh - sudo commands = - #sudo docker pull atriki/gnpyrest:v1.2 - sudo docker run -d -p 8008:5000 --name gnpy_tpce_rest1 atriki/gnpyrest:v1.2 - nosetests --with-xunit transportpce_tests/with_docker/test_gnpy.py - sudo docker container rm -f gnpy_tpce_rest1 +# ./add_tapi_feature_to_tests221.sh + ./launch_tests.sh tapi {posargs:} -[testenv:nbinotifications] +[testenv:with_docker] depends = buildcontroller,sims221 -whitelist_externals = sh - sudo +allowlist_externals = launch_tests.sh + dockercmd.sh +passenv = LAUNCHER, USE_LIGHTY, NO_ODL_STARTUP, USE_ODL_RESTCONF_VERSION, OLM_TIMER1 OLM_TIMER2 +setenv = + OLM_TIMER1=3000 + OLM_TIMER2=2000 + INSTALL_TAPI=True + INSTALL_NBINOTIFICATIONS=True +# USE_ODL_RESTCONF_VERSION=draft-bierman02 + commands = - sudo docker-compose -f ./nbinotifications/docker-compose.yml up -d - nosetests --with-xunit transportpce_tests/with_docker/test_nbinotifications.py - sudo docker-compose -f ./nbinotifications/docker-compose.yml down --rmi all + ./dockercmd.sh run -d -p 2181:2181 -p 9092:9092 --env ADVERTISED_LISTENERS=PLAINTEXT://localhost:9092 --name tpce_kafka1 teivah/kafka:2.0.0 + ./launch_tests.sh with_docker {posargs:} + ./dockercmd.sh container rm -f tpce_kafka1 [testenv:docs] -passenv = http_proxy HTTP_PROXY https_proxy HTTPS_PROXY no_proxy NO_PROXY +passenv = http_proxy, HTTP_PROXY, https_proxy, HTTPS_PROXY, no_proxy, NO_PROXY basepython = python3 deps = -rdocs/requirements.txt commands = - sphinx-build -q -W -b html -n -d {envtmpdir}/doctrees ../docs/ {toxinidir}/docs/_build/html + sphinx-build -q -W --keep-going -b html -n -d {envtmpdir}/doctrees ../docs/ {toxinidir}/docs/_build/html [testenv:docs-linkcheck] -passenv = http_proxy HTTP_PROXY https_proxy HTTPS_PROXY no_proxy NO_PROXY +passenv = http_proxy, HTTP_PROXY, https_proxy, HTTPS_PROXY, no_proxy, NO_PROXY basepython = python3 deps = -rdocs/requirements.txt commands = sphinx-build -q -b linkcheck -d {envtmpdir}/doctrees ../docs/ {toxinidir}/docs/_build/linkcheck [testenv:checkbashisms] deps = -whitelist_externals = sh +allowlist_externals = sh checkbashisms sudo find commands = - sh -c 'command checkbashisms>/dev/null || sudo yum install devscripts-minimal || (echo "checkbashisms command not found - please install it (e.g. sudo apt-get install devscripts | yum install devscripts-minimal )" >&2 && exit 1)' + sh -c 'command checkbashisms>/dev/null || sudo yum install -y devscripts-checkbashisms || sudo yum install -y devscripts-minimal || sudo yum install -y devscripts \ + || sudo yum install -y https://archives.fedoraproject.org/pub/archive/fedora/linux/releases/31/Everything/x86_64/os/Packages/d/devscripts-checkbashisms-2.19.6-2.fc31.x86_64.rpm \ + || (echo "checkbashisms command not found - please install it \ + (e.g. sudo apt-get install devscripts | yum install devscripts-minimal )" >&2 && exit 1)' find . -not -path '*/\.*' -name *.sh -exec checkbashisms -f \{\} + [testenv:spelling] @@ -157,7 +254,7 @@ deps = -rdocs/requirements.txt sphinxcontrib-spelling PyEnchant -commands = sphinx-build -b spelling -d {envtmpdir}/doctrees ../docs/ {toxinidir}/docs/_build/spelling +commands = sphinx-build -b spelling -d {envtmpdir}/doctrees ../docs/ {toxinidir}/docs/_build/spelling [testenv:autopep8] basepython = python3 @@ -165,17 +262,24 @@ deps = autopep8 commands = autopep8 --max-line-length 120 --in-place --recursive transportpce_tests/ +[testenv:pylint_full] +basepython = python3 +deps = pylint>=2.6.0 +allowlist_externals = find +commands = + find transportpce_tests/ -name *.py -exec pylint --fail-under=9.22 --max-line-length=120 --disable=missing-docstring --module-rgx="([a-z0-9_]+$)|([0-9.]{1,30}$)" --method-rgx="(([a-z_][a-zA-Z0-9_]{2,})|(_[a-z0-9_]*)|(__[a-zA-Z][a-zA-Z0-9_]+__))$" --variable-rgx="[a-zA-Z_][a-zA-Z0-9_]{1,30}$" --reports=y --score=y --output-format=colorized \{\} + + [testenv:pylint] basepython = python3 -deps = pylint -whitelist_externals = find +deps = pylint>=2.6.0 +allowlist_externals = find commands = - find transportpce_tests/ -name *.py -exec pylint --max-line-length=120 --disable=missing-docstring --method-rgx="(([a-z_][a-zA-Z0-9_]{2,})|(_[a-z0-9_]*)|(__[a-zA-Z][a-zA-Z0-9_]+__))$" --variable-rgx="[a-zA-Z_][a-zA-Z0-9_]{1,30}$" --reports=y --score=y --output-format=colorized \{\} + + find transportpce_tests/ -name *.py -exec pylint --fail-under=10 --max-line-length=120 --disable=missing-docstring,import-error --disable=fixme --disable=duplicate-code --module-rgx="([a-z0-9_]+$)|([0-9.]{1,30}$)" --method-rgx="(([a-z_][a-zA-Z0-9_]{2,})|(_[a-z0-9_]*)|(__[a-zA-Z][a-zA-Z0-9_]+__))$" --variable-rgx="[a-zA-Z_][a-zA-Z0-9_]{1,30}$" \{\} + [testenv:pyang] basepython = python3 deps = pyang -whitelist_externals = find +allowlist_externals = find commands = pyang --version find ../api/ -name target -prune -o -name *.yang -exec pyang --lint --canonical --max-line-length=120 -p../api/src/main/yang/:../ordmodels/common/src/main/yang/:../ordmodels/service/src/main/yang/:../tapimodels/src/main/yang/ \{\} + @@ -184,7 +288,7 @@ commands = [testenv:pyangformat] basepython = python3 deps = pyang -whitelist_externals = sh +allowlist_externals = sh commands = pyang --version sh -c 'find ../api/ -name target -prune -o -name *.yang -print | while read -r fname; do pyang -f yang --yang-canonical --yang-remove-unused-imports --max-line-length=120 --keep-comments -p../api/src/main/yang/:../ordmodels/common/src/main/yang/:../ordmodels/service/src/main/yang/:../tapimodels/src/main/yang/ "$fname" -o /tmp/tmpfile.$$ && mv /tmp/tmpfile.$$ "$fname";done' @@ -203,22 +307,42 @@ commands = pre-commit uninstall pre-commit uninstall --hook-type commit-msg +[testenv:pre-commit-autoupdate] +basepython = python3 +deps = pre-commit +commands = + pre-commit autoupdate + [testenv:pre-commit] basepython = python3 deps = pre-commit passenv = HOME commands = pre-commit run --all-files --show-diff-on-failure - pre-commit run gitlint --hook-stage commit-msg --commit-msg-filename .git/COMMIT_EDITMSG - # Gitlint only proposes a pre-commit configuration for the commit-msg stage but none for the commit stage. - # Its default arguments --passed and --msg-filename are different from CI recommandations. - # As a result, the line above is always skipped in jenkins CI since there cannot be a .git/COMMIT_EDITMSG file. - # A dedicated gitlint profile for CI is proposed below. Also to behave fine locally, this profile must have access - # to the HOME variable so that Gitlint can retrieve Git user settings. + pre-commit run gitlint-ci --hook-stage manual [testenv:gitlint] basepython = python3 deps = gitlint commands = - gitlint + gitlint --config ../.gitlint + +[testenv:allure-report-init] +basepython = python3 +deps = allure-pytest>=2.10.0 +# allure is under Apache License 2.0 +allowlist_externals = + mkdir + sed +commands = + mkdir -p allure-report + sed -i_ '$a\allure-pytest # Apache License 2.0' ./test-requirements.txt + + +[testenv:allure-report-serve] +basepython = python3 +allowlist_externals = + allure +commands = + allure serve "allure-report"