diff --git a/SOURCES/openvswitch-3.5.0.patch b/SOURCES/openvswitch-3.5.0.patch index ee0984a..062fe65 100644 --- a/SOURCES/openvswitch-3.5.0.patch +++ b/SOURCES/openvswitch-3.5.0.patch @@ -164,6 +164,22 @@ index c8cc543465..384428c3fc 100644 op = {"table": row._table.name} if row._data is None: op["op"] = "insert" +diff --git a/python/ovs/stream.py b/python/ovs/stream.py +index 2282905ed6..4b4b07d032 100644 +--- a/python/ovs/stream.py ++++ b/python/ovs/stream.py +@@ -585,9 +585,9 @@ class PassiveStream(object): + if not PassiveStream.is_valid_name(name): + return errno.EAFNOSUPPORT, None + +- bind_path = name[6:] ++ bind_path = None + if name.startswith("punix:"): +- bind_path = ovs.util.abs_file_name(ovs.dirs.RUNDIR, bind_path) ++ bind_path = ovs.util.abs_file_name(ovs.dirs.RUNDIR, name[6:]) + if sys.platform != 'win32': + error, sock = ovs.socket_util.make_unix_socket( + socket.SOCK_STREAM, True, bind_path, None) diff --git a/tests/dpif-netdev.at b/tests/dpif-netdev.at index 60060ee2e0..920bbcac0b 100644 --- a/tests/dpif-netdev.at @@ -297,7 +313,7 @@ index fa5f148b4c..fbc3deb68e 100644 add_${func}of_ports br0 1 2 AT_DATA([flows.txt], [dnl diff --git a/tests/ovsdb-idl.at b/tests/ovsdb-idl.at -index f9f79f1941..bac6bf2764 100644 +index f9f79f1941..a88706982d 100644 --- a/tests/ovsdb-idl.at +++ b/tests/ovsdb-idl.at @@ -494,6 +494,15 @@ OVSDB_CHECK_IDL([simple idl, writing via IDL with unicode], @@ -316,7 +332,132 @@ index f9f79f1941..bac6bf2764 100644 m4_define([OVSDB_CHECK_IDL_PY_WITH_EXPOUT], [AT_SETUP([ovsdb-idl - $1 - Python3]) AT_KEYWORDS([ovsdb server idl positive Python $5]) -@@ -2817,7 +2826,7 @@ m4_define([OVSDB_CHECK_IDL_PERS_UUID_INSERT_C], +@@ -1567,6 +1576,7 @@ OVSDB_CHECK_IDL_TRACK([track, simple idl, initially populated, weak references, + {"op": "delete", + "table": "simple", + "where": [["s", "==", "row1_s"]]}]' \ ++ '+sleep' \ + '["idltest", + {"op": "insert", + "table": "simple", +@@ -1579,16 +1589,17 @@ OVSDB_CHECK_IDL_TRACK([track, simple idl, initially populated, weak references, + 001: table simple: updated columns: s + 002: {"error":null,"result":[{"uuid":["uuid","<3>"]},{"count":1}]} + 003: {"error":null,"result":[{"count":1}]} +-004: table simple6: name=row0_s6 weak_ref=[<0>] uuid=<1> +-004: table simple6: updated columns: weak_ref +-004: table simple: inserted/deleted row: i=0 r=0 b=false s=row1_s u=<2> ia=[] ra=[] ba=[] sa=[] ua=[] uuid=<3> +-004: table simple: updated columns: s +-005: {"error":null,"result":[{"uuid":["uuid","<4>"]}]} +-006: table simple6: name=row0_s6 weak_ref=[<0>] uuid=<1> +-006: table simple: i=0 r=0 b=false s=row0_s u=<2> ia=[] ra=[] ba=[] sa=[] ua=[] uuid=<0> +-006: table simple: inserted row: i=0 r=0 b=false s=row2_s u=<2> ia=[] ra=[] ba=[] sa=[] ua=[] uuid=<4> +-006: table simple: updated columns: s +-007: done ++004: sleep ++005: table simple6: name=row0_s6 weak_ref=[<0>] uuid=<1> ++005: table simple6: updated columns: weak_ref ++005: table simple: inserted/deleted row: i=0 r=0 b=false s=row1_s u=<2> ia=[] ra=[] ba=[] sa=[] ua=[] uuid=<3> ++005: table simple: updated columns: s ++006: {"error":null,"result":[{"uuid":["uuid","<4>"]}]} ++007: table simple6: name=row0_s6 weak_ref=[<0>] uuid=<1> ++007: table simple: i=0 r=0 b=false s=row0_s u=<2> ia=[] ra=[] ba=[] sa=[] ua=[] uuid=<0> ++007: table simple: inserted row: i=0 r=0 b=false s=row2_s u=<2> ia=[] ra=[] ba=[] sa=[] ua=[] uuid=<4> ++007: table simple: updated columns: s ++008: done + ]]) + + dnl This test checks that deleting both the destination and source of the +@@ -1762,14 +1773,16 @@ OVSDB_CHECK_IDL_TRACK([track, simple idl, initially empty, strong references, in + '+["idltest", + {"op": "delete", + "table": "link2", +- "where": [["i", "==", 2]]}]' ++ "where": [["i", "==", 2]]}]' \ ++ '+sleep' + ]], + [[000: empty + 001: {"error":null,"result":[{"uuid":["uuid","<0>"]},{"uuid":["uuid","<1>"]}]} + 002: {"error":null,"result":[{"count":1}]} +-003: table link1: inserted row: i=1 k=1 ka=[] l2= uuid=<0> +-003: table link1: updated columns: i k +-004: done ++003: sleep ++004: table link1: inserted row: i=1 k=1 ka=[] l2= uuid=<0> ++004: table link1: updated columns: i k ++005: done + ]]) + + OVSDB_CHECK_IDL_TRACK([track, simple idl, initially empty, various ops], +@@ -2746,6 +2759,7 @@ OVSDB_CHECK_IDL_TRACK([track, insert and delete, refs to link1], + "table": "link2", + "where": [["i", "==", 2]]} + ]' \ ++ '+sleep' \ + '["idltest", + {"op": "delete", + "table": "link2", +@@ -2755,15 +2769,16 @@ OVSDB_CHECK_IDL_TRACK([track, insert and delete, refs to link1], + [[000: empty + 001: {"error":null,"result":[{"uuid":["uuid","<0>"]},{"uuid":["uuid","<1>"]},{"uuid":["uuid","<2>"]}]} + 002: {"error":null,"result":[{"count":1}]} +-003: table link1: inserted row: i=1 k=1 ka=[] l2= uuid=<1> +-003: table link1: updated columns: i k +-003: table link2: inserted row: i=1 l1=1 uuid=<0> +-003: table link2: inserted/deleted row: i=2 l1=1 uuid=<2> +-003: table link2: updated columns: i l1 +-003: table link2: updated columns: i l1 +-004: {"error":null,"result":[{"count":1}]} +-005: table link1: i=1 k=1 ka=[] l2= uuid=<1> +-006: done ++003: sleep ++004: table link1: inserted row: i=1 k=1 ka=[] l2= uuid=<1> ++004: table link1: updated columns: i k ++004: table link2: inserted row: i=1 l1=1 uuid=<0> ++004: table link2: inserted/deleted row: i=2 l1=1 uuid=<2> ++004: table link2: updated columns: i l1 ++004: table link2: updated columns: i l1 ++005: {"error":null,"result":[{"count":1}]} ++006: table link1: i=1 k=1 ka=[] l2= uuid=<1> ++007: done + ]]) + OVSDB_CHECK_IDL_TRACK([track, insert and delete, refs to link2], + [], +@@ -2789,6 +2804,7 @@ OVSDB_CHECK_IDL_TRACK([track, insert and delete, refs to link2], + "table": "link1", + "where": [["i", "==", 2]]} + ]' \ ++ '+sleep' \ + '["idltest", + {"op": "delete", + "table": "link1", +@@ -2798,15 +2814,16 @@ OVSDB_CHECK_IDL_TRACK([track, insert and delete, refs to link2], + [[000: empty + 001: {"error":null,"result":[{"uuid":["uuid","<0>"]},{"uuid":["uuid","<1>"]},{"uuid":["uuid","<2>"]}]} + 002: {"error":null,"result":[{"count":1}]} +-003: table link1: inserted row: i=1 k=1 ka=[] l2=1 uuid=<0> +-003: table link1: inserted/deleted row: i=2 k=1 ka=[] l2=1 uuid=<2> +-003: table link1: updated columns: i k l2 +-003: table link1: updated columns: i k l2 +-003: table link2: inserted row: i=1 l1= uuid=<1> +-003: table link2: updated columns: i +-004: {"error":null,"result":[{"count":1}]} +-005: table link2: i=1 l1= uuid=<1> +-006: done ++003: sleep ++004: table link1: inserted row: i=1 k=1 ka=[] l2=1 uuid=<0> ++004: table link1: inserted/deleted row: i=2 k=1 ka=[] l2=1 uuid=<2> ++004: table link1: updated columns: i k l2 ++004: table link1: updated columns: i k l2 ++004: table link2: inserted row: i=1 l1= uuid=<1> ++004: table link2: updated columns: i ++005: {"error":null,"result":[{"count":1}]} ++006: table link2: i=1 l1= uuid=<1> ++007: done + ]]) + + m4_define([OVSDB_CHECK_IDL_PERS_UUID_INSERT_C], +@@ -2817,7 +2834,7 @@ m4_define([OVSDB_CHECK_IDL_PERS_UUID_INSERT_C], [0], [stdout], [stderr]) AT_CHECK([sort stdout], [0], [$3]) @@ -325,7 +466,7 @@ index f9f79f1941..bac6bf2764 100644 OVSDB_SERVER_SHUTDOWN AT_CLEANUP]) -@@ -2829,7 +2838,7 @@ m4_define([OVSDB_CHECK_IDL_PERS_UUID_INSERT_PY], +@@ -2829,7 +2846,7 @@ m4_define([OVSDB_CHECK_IDL_PERS_UUID_INSERT_PY], [0], [stdout], [stderr]) AT_CHECK([sort stdout], [0], [$3]) @@ -334,7 +475,7 @@ index f9f79f1941..bac6bf2764 100644 OVSDB_SERVER_SHUTDOWN AT_CLEANUP]) -@@ -2867,6 +2876,14 @@ OVSDB_CHECK_IDL_PERS_UUID_INSERT([simple idl, persistent uuid insert], +@@ -2867,6 +2884,14 @@ OVSDB_CHECK_IDL_PERS_UUID_INSERT([simple idl, persistent uuid insert], ]], [['This UUID would duplicate a UUID already present within the table or deleted within the same transaction']]) @@ -376,7 +517,7 @@ index 0215453230..f2d3552808 100644 OVS_TRAFFIC_VSWITCHD_STOP diff --git a/tests/test-ovsdb.c b/tests/test-ovsdb.c -index 710341b655..8011850fdf 100644 +index 710341b655..6a0e0d8341 100644 --- a/tests/test-ovsdb.c +++ b/tests/test-ovsdb.c @@ -2451,6 +2451,10 @@ idl_set(struct ovsdb_idl *idl, char *commands, int step) @@ -437,6 +578,16 @@ index 710341b655..8011850fdf 100644 } status = ovsdb_idl_txn_commit_block(txn); +@@ -2856,6 +2884,9 @@ do_idl(struct ovs_cmdl_context *ctx) + if (!strcmp(arg, "reconnect")) { + print_and_log("%03d: reconnect", step++); + ovsdb_idl_force_reconnect(idl); ++ } else if (!strcmp(arg, "sleep")) { ++ print_and_log("%03d: sleep", step++); ++ xsleep(1); + } else if (!strncmp(arg, remote_s, strlen(remote_s))) { + ovsdb_idl_set_remote(idl, arg + strlen(remote_s), true); + print_and_log("%03d: new remotes: %s, is connected: %s", step++, diff --git a/tests/test-ovsdb.py b/tests/test-ovsdb.py index 57fc1d4497..b690b4f076 100644 --- a/tests/test-ovsdb.py diff --git a/SPECS/openvswitch3.5.spec b/SPECS/openvswitch3.5.spec index ea1aa59..751da53 100644 --- a/SPECS/openvswitch3.5.spec +++ b/SPECS/openvswitch3.5.spec @@ -59,7 +59,7 @@ Summary: Open vSwitch Group: System Environment/Daemons daemon/database/utilities URL: http://www.openvswitch.org/ Version: 3.5.0 -Release: 13%{?dist} +Release: 14%{?dist} # Nearly all of openvswitch is ASL 2.0. The bugtool is LGPLv2+, and the # lib/sflow*.[ch] files are SISSL @@ -796,6 +796,13 @@ exit 0 %endif %changelog +* Wed Mar 26 2025 Open vSwitch CI - 3.5.0-14 +- Merging upstream branch-3.5 [RH git: 560ba67c02] + Commit list: + c46b1ef166 tests: ovsdb-idl: Fix flaky insert and delete tests. + 42d3148d62 python: stream: Fix unlink attempt for ptcp IP address. + + * Fri Mar 21 2025 Open vSwitch CI - 3.5.0-13 - Merging upstream branch-3.5 [RH git: 280d901003] Commit list: