Allow Karaf to use altern. RESTCONF and akka ports
[transportpce.git] / tox.ini
diff --git a/tox.ini b/tox.ini
index 9cd2a744e4f195e04baf3540faca985df88ee116..ae74a2681a08463ecb19b3a9b20d7c0e01a48375 100644 (file)
--- a/tox.ini
+++ b/tox.ini
@@ -1,6 +1,6 @@
 [tox]
 minversion = 3.7.0
-envlist = buildcontroller,sims121,tests121,sims221,tests221,sims71,tests71,tests_hybrid
+envlist = buildcontroller,testsPCE,sims121,tests121,sims221,tests221,sims71,tests71,tests_hybrid
     docs
     docs-linkcheck
     checkbashisms
@@ -12,7 +12,7 @@ setupdir = tests/
 [testenv]
 passenv = USE_LIGHTY http_proxy HTTP_PROXY https_proxy HTTPS_PROXY no_proxy NO_PROXY
 setenv =
-    USE_LIGHTY = True
+    USE_LIGHTY = False
 usedevelop = true
 basepython = python3
 deps =
@@ -34,13 +34,8 @@ commands =
 #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)
+#patch Karaf exec for the same reason at runtime and also to have the possibility to use alternative ports
+  sh -c "../karaf/target/assembly/ressources/post_install_for_tests.sh"
 #build Lighty if needed
   sh -c 'if [ "$USE_LIGHTY" = "True" ]; then (cd ../lighty && ./build.sh); fi'
 
@@ -64,46 +59,76 @@ depends = buildcontroller
 commands =
   - sh -c "./install_honeynode.sh 7.1"
 
-[testenv:tests121]
-depends = buildcontroller,sims121
+[testenv:testsPCE]
+depends = buildcontroller
+whitelist_externals = launch_tests.sh
+passenv = LAUNCHER USE_LIGHTY
 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_pce.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 pce {posargs:}
+
+[testenv:tests121]
+depends = buildcontroller,sims121,testsPCE
+# testsPCE dependency is only here to chain tests in the gate and avoid resources starvation
+whitelist_externals = launch_tests.sh
+passenv = LAUNCHER
+setenv =
+    USE_LIGHTY=False
+    USE_ODL_ALT_WEBSOCKET_PORT=8186
+    USE_ODL_ALT_AKKA_PORT=2551
+    USE_ODL_ALT_AKKA_MGT_PORT=8559
+    USE_ODL_ALT_RESTCONF_PORT=8182
+commands =
+  ./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: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
+# tests71 dependency is only here to chain tests in the gate and avoid ressources starvation
+whitelist_externals = launch_tests.sh
+passenv = LAUNCHER
+setenv =
+    USE_LIGHTY=False
+    USE_ODL_ALT_WEBSOCKET_PORT=8187
+    USE_ODL_ALT_AKKA_PORT=2552
+    USE_ODL_ALT_AKKA_MGT_PORT=8560
+    USE_ODL_ALT_RESTCONF_PORT=8183
+commands =
+  ./launch_tests.sh 2.2.1 {posargs:}
 
 [testenv:tests71]
 depends = buildcontroller,sims71,tests221
-#the last dependency is to avoid temporarily concurrent ressources problem to fix in parallel mode
+whitelist_externals = launch_tests.sh
+passenv = LAUNCHER
+setenv =
+    USE_LIGHTY=False
+    USE_ODL_ALT_WEBSOCKET_PORT=8188
+    USE_ODL_ALT_AKKA_PORT=2553
+    USE_ODL_ALT_AKKA_MGT_PORT=8561
+    USE_ODL_ALT_RESTCONF_PORT=8184
 commands =
-  nosetests --with-xunit transportpce_tests/7.1/test_pce_400G.py
-  #NB: test pce_400G above does not depend on sims71
-  nosetests --with-xunit transportpce_tests/7.1/test_portmapping.py
+  ./launch_tests.sh 7.1 {posargs:}
 
 [testenv:tests_hybrid]
-depends = buildcontroller,sims121,sims221,sims71,tests71
-#the last dependency is to avoid temporarily concurrent ressources problem to fix in parallel mode
-commands =
-  nosetests --with-xunit transportpce_tests/hybrid/test_device_change_notifications.py
+depends = buildcontroller,sims121,sims221,sims71,tests121,tests221,tests71
+#the last dependency is to avoid temporarily concurrent ressources problem in parallel mode
+whitelist_externals = launch_tests.sh
+passenv = LAUNCHER
+setenv =
+    USE_LIGHTY=False
+    USE_ODL_ALT_WEBSOCKET_PORT=8186
+    USE_ODL_ALT_AKKA_PORT=2551
+    USE_ODL_ALT_AKKA_MGT_PORT=8559
+    USE_ODL_ALT_RESTCONF_PORT=8182
+commands =
+#  nosetests --with-xunit transportpce_tests/hybrid/test01_device_change_notifications.py
+  ./launch_tests.sh hybrid {posargs:}
 
 [testenv:gnpy]
 depends = buildcontroller