diff --git a/SOURCES/openvswitch-3.3.0.patch b/SOURCES/openvswitch-3.3.0.patch index 32f74e2..8142b55 100644 --- a/SOURCES/openvswitch-3.3.0.patch +++ b/SOURCES/openvswitch-3.3.0.patch @@ -6406,6 +6406,22 @@ index 7d9b165d46..a8f8c067a9 100644 } @staticmethod +diff --git a/python/ovs/stream.py b/python/ovs/stream.py +index 82fbb0d688..935f63bbdc 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/python/ovs/tests/test_odp.py b/python/ovs/tests/test_odp.py index f19ec386e8..d514e9be32 100644 --- a/python/ovs/tests/test_odp.py @@ -7636,7 +7652,7 @@ index 481afc08b3..9d8b4d06a4 100644 OVS_START_SHELL_HELPERS diff --git a/tests/ovsdb-idl.at b/tests/ovsdb-idl.at -index fb568dd823..2c7c53f296 100644 +index fb568dd823..12b2c4fffc 100644 --- a/tests/ovsdb-idl.at +++ b/tests/ovsdb-idl.at @@ -167,8 +167,17 @@ m4_define([OVSDB_CHECK_IDL_REGISTER_COLUMNS_PY], @@ -7771,7 +7787,64 @@ index fb568dd823..2c7c53f296 100644 dnl This test creates database with weak references and checks that orphan dnl rows created for weak references are not available for iteration via dnl list of tracked changes. -@@ -1806,7 +1890,10 @@ OVSDB_CHECK_IDL_PARTIAL_UPDATE_MAP_COLUMN([map, simple2 idl-partial-update-map-c +@@ -1492,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", +@@ -1504,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 +@@ -1687,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], +@@ -1806,7 +1894,10 @@ OVSDB_CHECK_IDL_PARTIAL_UPDATE_MAP_COLUMN([map, simple2 idl-partial-update-map-c 007: name=String2 smap=[[key2 : value2]] imap=[[3 : myids2]] 008: After trying to delete a deleted element 009: name=String2 smap=[[key2 : value2]] imap=[[3 : myids2]] @@ -7783,7 +7856,7 @@ index fb568dd823..2c7c53f296 100644 ]]) OVSDB_CHECK_IDL_PY([partial-map idl], -@@ -1869,7 +1956,9 @@ OVSDB_CHECK_IDL_PARTIAL_UPDATE_SET_COLUMN([set, simple3 idl-partial-update-set-c +@@ -1869,7 +1960,9 @@ OVSDB_CHECK_IDL_PARTIAL_UPDATE_SET_COLUMN([set, simple3 idl-partial-update-set-c 009: table simple3: name=String2 uset=[<0>,<1>,<4>] uref=[] uuid=<2> 010: After add to other table + set of strong ref 011: table simple3: name=String2 uset=[<0>,<1>,<4>] uref=[<5>] uuid=<2> @@ -7794,7 +7867,7 @@ index fb568dd823..2c7c53f296 100644 ]]) OVSDB_CHECK_IDL_PY([partial-set idl], -@@ -2022,6 +2111,36 @@ OVSDB_CHECK_IDL_NOTIFY([simple idl verify notify], +@@ -2022,6 +2115,36 @@ OVSDB_CHECK_IDL_NOTIFY([simple idl verify notify], 015: done ]]) @@ -7831,7 +7904,75 @@ index fb568dd823..2c7c53f296 100644 # Tests to verify the functionality of the one column compound index. # It tests index for one column string and integer indexes. # The run of test-ovsdb generates the output of the display of data using the different indexes defined in -@@ -2707,7 +2826,7 @@ m4_define([OVSDB_CHECK_IDL_PERS_UUID_INSERT_C], +@@ -2636,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", +@@ -2645,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], + [], +@@ -2679,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", +@@ -2688,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], +@@ -2707,7 +2834,7 @@ m4_define([OVSDB_CHECK_IDL_PERS_UUID_INSERT_C], [0], [stdout], [stderr]) AT_CHECK([sort stdout], [0], [$3]) @@ -7840,7 +7981,7 @@ index fb568dd823..2c7c53f296 100644 OVSDB_SERVER_SHUTDOWN AT_CLEANUP]) -@@ -2719,7 +2838,7 @@ m4_define([OVSDB_CHECK_IDL_PERS_UUID_INSERT_PY], +@@ -2719,7 +2846,7 @@ m4_define([OVSDB_CHECK_IDL_PERS_UUID_INSERT_PY], [0], [stdout], [stderr]) AT_CHECK([sort stdout], [0], [$3]) @@ -7849,7 +7990,7 @@ index fb568dd823..2c7c53f296 100644 OVSDB_SERVER_SHUTDOWN AT_CLEANUP]) -@@ -2757,6 +2876,14 @@ OVSDB_CHECK_IDL_PERS_UUID_INSERT([simple idl, persistent uuid insert], +@@ -2757,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']]) @@ -10495,7 +10636,7 @@ index 08d2cbaebf..4e9a3ab5c2 100644 mp.max_link = n - 1; multipath_execute(&mp, &flow, &wc); diff --git a/tests/test-ovsdb.c b/tests/test-ovsdb.c -index c4ab899d45..8011850fdf 100644 +index c4ab899d45..6a0e0d8341 100644 --- a/tests/test-ovsdb.c +++ b/tests/test-ovsdb.c @@ -2023,6 +2023,24 @@ print_idl_row_updated_link2(const struct idltest_link2 *l2, int step) @@ -10641,7 +10782,17 @@ index c4ab899d45..8011850fdf 100644 } status = ovsdb_idl_txn_commit_block(txn); -@@ -2977,6 +3048,29 @@ do_idl_partial_update_map_column(struct ovs_cmdl_context *ctx) +@@ -2813,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++, +@@ -2977,6 +3051,29 @@ do_idl_partial_update_map_column(struct ovs_cmdl_context *ctx) printf("%03d: After trying to delete a deleted element\n", step++); dump_simple2(idl, myRow, step++); @@ -10671,7 +10822,7 @@ index c4ab899d45..8011850fdf 100644 ovsdb_idl_destroy(idl); printf("%03d: End test\n", step); } -@@ -3075,6 +3169,21 @@ do_idl_partial_update_set_column(struct ovs_cmdl_context *ctx) +@@ -3075,6 +3172,21 @@ do_idl_partial_update_set_column(struct ovs_cmdl_context *ctx) ovsdb_idl_get_initial_snapshot(idl); printf("%03d: After add to other table + set of strong ref\n", step++); dump_simple3(idl, myRow, step++); diff --git a/SPECS/openvswitch3.3.spec b/SPECS/openvswitch3.3.spec index 15d42c5..569d5d0 100644 --- a/SPECS/openvswitch3.3.spec +++ b/SPECS/openvswitch3.3.spec @@ -59,7 +59,7 @@ Summary: Open vSwitch Group: System Environment/Daemons daemon/database/utilities URL: http://www.openvswitch.org/ Version: 3.3.4 -Release: 104%{?dist} +Release: 105%{?dist} # Nearly all of openvswitch is ASL 2.0. The bugtool is LGPLv2+, and the # lib/sflow*.[ch] files are SISSL @@ -794,6 +794,13 @@ exit 0 %endif %changelog +* Wed Mar 26 2025 Open vSwitch CI - 3.3.0-105 +- Merging upstream branch-3.3 [RH git: bac0388826] + Commit list: + 90b5b99bc9 tests: ovsdb-idl: Fix flaky insert and delete tests. + 5e1162300f python: stream: Fix unlink attempt for ptcp IP address. + + * Fri Mar 21 2025 Open vSwitch CI - 3.3.0-104 - Merging upstream branch-3.3 [RH git: 96844ab3e5] Commit list: