This caused ovn-controller restart to sometimes fail due with an error:
"already running as pid xxx, aborting".

Signed-off-by: Xavier Simonart <xsimo...@redhat.com>
---
 tests/ovn-controller.at | 12 +++++++++---
 tests/ovn-macros.at     |  5 +++--
 tests/system-ovn.at     | 10 ++++------
 3 files changed, 16 insertions(+), 11 deletions(-)

diff --git a/tests/ovn-controller.at b/tests/ovn-controller.at
index 6007a7454..28189b049 100644
--- a/tests/ovn-controller.at
+++ b/tests/ovn-controller.at
@@ -3729,12 +3729,14 @@ start_controller() {
 }
 
 # Stop ovn-controller, without any argument it will cleanup resources.
+TMPPID=$(cat hv1/ovn-controller.pid)
 check ovn-appctl -t ovn-controller exit
 check grep -q "Exiting ovn-controller, resource cleanup: True" 
hv1/ovn-controller.log
+OVS_WAIT_WHILE([kill -0 $TMPPID 2>/dev/null])
 
 # Stop ovn-controller without cleanup.
 start_controller
-check ovn-appctl -t ovn-controller exit --restart
+OVN_CONTROLLER_EXIT([hv1])
 check grep -q "Exiting ovn-controller, resource cleanup: False (--restart)" 
hv1/ovn-controller.log
 
 # Set cleanup on exit.
@@ -3742,12 +3744,14 @@ check ovs-vsctl set open . 
external-ids:ovn-cleanup-on_exit=true
 
 # Stop ovn-controller, without any argument it will cleanup resources.
 start_controller
+TMPPID=$(cat hv1/ovn-controller.pid)
 check ovn-appctl -t ovn-controller exit
 check grep -q "Exiting ovn-controller, resource cleanup: True" 
hv1/ovn-controller.log
+OVS_WAIT_WHILE([kill -0 $TMPPID 2>/dev/null])
 
 # Stop ovn-controller, --restart flag has priority over external-ids, no 
cleanup.
 start_controller
-check ovn-appctl -t ovn-controller exit --restart
+OVN_CONTROLLER_EXIT([hv1])
 check grep -q "Exiting ovn-controller, resource cleanup: False (--restart)" 
hv1/ovn-controller.log
 
 # Set cleanup on exit to false.
@@ -3755,12 +3759,14 @@ check ovs-vsctl set open . 
external-ids:ovn-cleanup-on-exit=false
 
 # Stop ovn-controller, without any argument it won't cleanup due to the 
external-ids.
 start_controller
+TMPPID=$(cat hv1/ovn-controller.pid)
 check ovn-appctl -t ovn-controller exit
 check grep -q "Exiting ovn-controller, resource cleanup: False (--restart)" 
hv1/ovn-controller.log
+OVS_WAIT_WHILE([kill -0 $TMPPID 2>/dev/null])
 
 # Stop ovn-controller without cleanup.
 start_controller
-check ovn-appctl -t ovn-controller exit --restart
+OVN_CONTROLLER_EXIT([hv1])
 check grep -q "Exiting ovn-controller, resource cleanup: False (--restart)" 
hv1/ovn-controller.log
 
 # Start the controller so the test cleanup routing doesn't get stuck.
diff --git a/tests/ovn-macros.at b/tests/ovn-macros.at
index 13cff5c38..20755942b 100644
--- a/tests/ovn-macros.at
+++ b/tests/ovn-macros.at
@@ -1460,8 +1460,9 @@ m4_define([OVN_CHECK_SCAPY_EDNS_CLIENT_SUBNET_SUPPORT],
 ])
 
 m4_define([OVN_CONTROLLER_EXIT],
-  [TMPPID=$(cat $1/ovn-controller.pid)
-   AT_CHECK([as $1 ovn-appctl -t ovn-controller exit --restart])
+  [TMPPID=$(cat ./$1/ovn-controller.pid)
+   AT_CHECK([as $1
+check ovn-appctl -t ovn-controller exit --restart])
    # Make sure ovn-controller stopped so that a future restart will not fail.
    # Checking debug/status is running is not enough as there might be a small 
race condition.
    echo "Waiting for pid $TMPPID"
diff --git a/tests/system-ovn.at b/tests/system-ovn.at
index c2b70d3a1..d0888badf 100644
--- a/tests/system-ovn.at
+++ b/tests/system-ovn.at
@@ -16266,9 +16266,8 @@ blackhole 198.51.100.0/24 proto ovn metric 1000
 233.252.0.0/24 via 192.168.10.10 dev lo onlink
 233.253.0.0/24 via 192.168.20.20 dev hv1-mll onlink])
 
-# Stoping with --restart will not touch the routes.
-check ovn-appctl -t ovn-controller exit --restart
-OVS_WAIT_UNTIL([test "$(ovn-appctl -t ovn-controller debug/status)" != 
"running"])
+# Stopping with --restart will not touch the routes.
+OVN_CONTROLLER_EXIT([])
 OVN_ROUTE_EQUAL([ovnvrf1338], [dnl
 blackhole 192.0.2.1 proto ovn metric 1000
 blackhole 192.0.2.2 proto ovn metric 100
@@ -16610,9 +16609,8 @@ blackhole 198.51.100.0/24 proto ovn metric 1000
 233.252.0.0/24 via 192.168.10.10 dev lo onlink
 233.253.0.0/24 via 192.168.20.20 dev hv1-mll onlink])
 
-# Stoping with --restart will not touch the routes.
-check ovn-appctl -t ovn-controller exit --restart
-OVS_WAIT_UNTIL([test "$(ovn-appctl -t ovn-controller debug/status)" != 
"running"])
+# Stopping with --restart will not touch the routes.
+OVN_CONTROLLER_EXIT([])
 OVN_ROUTE_EQUAL([ovnvrf1337], [dnl
 blackhole 192.0.2.1 proto ovn metric 100
 blackhole 192.0.2.2 proto ovn metric 100
-- 
2.47.1

_______________________________________________
dev mailing list
d...@openvswitch.org
https://mail.openvswitch.org/mailman/listinfo/ovs-dev

Reply via email to