From 9431383abc926ca4513928c56924e942ea250cc8 Mon Sep 17 00:00:00 2001 From: DmitriyEshenko Date: Fri, 25 Jun 2021 15:00:37 +0000 Subject: T3649: bonding: Add additional hash policies --- interface-definitions/interfaces-bonding.xml.in | 14 +++++++++++--- smoketest/scripts/cli/test_interfaces_bonding.py | 17 +++++++++++++++++ 2 files changed, 28 insertions(+), 3 deletions(-) diff --git a/interface-definitions/interfaces-bonding.xml.in b/interface-definitions/interfaces-bonding.xml.in index 2efdaea3d..4bfc6e730 100644 --- a/interface-definitions/interfaces-bonding.xml.in +++ b/interface-definitions/interfaces-bonding.xml.in @@ -60,7 +60,7 @@ Bonding transmit hash policy - layer2 layer2+3 layer3+4 + layer2 layer2+3 layer3+4 encap2+3 encap3+4 layer2 @@ -74,10 +74,18 @@ layer3+4 combine IP address and port to make hash + + encap2+3 + combine encapsulated MAC address and IP address to make hash + + + encap3+4 + combine encapsulated IP address and port to make hash + - ^(layer2\+3|layer3\+4|layer2)$ + ^(layer2\+3|layer3\+4|layer2|encap2\+3|encap3\+4)$ - hash-policy must be layer2 layer2+3 or layer3+4 + hash-policy must be layer2 layer2+3 layer3+4 encap2+3 or encap3+4 layer2 diff --git a/smoketest/scripts/cli/test_interfaces_bonding.py b/smoketest/scripts/cli/test_interfaces_bonding.py index cf147fe58..43f661f6b 100755 --- a/smoketest/scripts/cli/test_interfaces_bonding.py +++ b/smoketest/scripts/cli/test_interfaces_bonding.py @@ -133,5 +133,22 @@ class BondingInterfaceTest(BasicInterfaceTest.TestCase): self.assertEqual(0, tmp['linkinfo']['info_data']['min_links']) self.assertEqual(lacp_rate, tmp['linkinfo']['info_data']['ad_lacp_rate']) + def test_bonding_hast_policy(self): + # Define available bonding hash policies + hash_policies = ['layer2', 'layer2+3', 'layer2+3', 'encap2+3', 'encap3+4'] + for hash_policy in hash_policies: + for interface in self._interfaces: + for option in self._options.get(interface, []): + self.cli_set(self._base_path + [interface] + option.split()) + + self.cli_set(self._base_path + [interface, 'hash-policy', hash_policy]) + + self.cli_commit() + + # verify config + for interface in self._interfaces: + defined_policy = read_file(f'/sys/class/net/{interface}/bonding/xmit_hash_policy').split() + self.assertEqual(defined_policy[0], hash_policy) + if __name__ == '__main__': unittest.main(verbosity=2) -- cgit v1.2.3