diff options
author | Yusuke Iwase <iwase.yusuke0@gmail.com> | 2015-03-18 17:19:28 +0900 |
---|---|---|
committer | FUJITA Tomonori <fujita.tomonori@lab.ntt.co.jp> | 2015-03-18 22:27:11 +0900 |
commit | d2993399913b205cea3dc6aebe06f1dd058b1cc5 (patch) | |
tree | bcf976105ee65f106cde33e6aba24f1fa39e1725 | |
parent | 109d2bb2fd53be8b81ff28dc1582ef64406cfe65 (diff) |
test_ofctl: Add unit test for masked ipv6_exthdr match field
Signed-off-by: IWASE Yusuke <iwase.yusuke0@gmail.com>
Signed-off-by: FUJITA Tomonori <fujita.tomonori@lab.ntt.co.jp>
-rw-r--r-- | ryu/tests/unit/lib/test_ofctl.py | 30 |
1 files changed, 16 insertions, 14 deletions
diff --git a/ryu/tests/unit/lib/test_ofctl.py b/ryu/tests/unit/lib/test_ofctl.py index 0c094647..a1af4bf4 100644 --- a/ryu/tests/unit/lib/test_ofctl.py +++ b/ryu/tests/unit/lib/test_ofctl.py @@ -62,8 +62,8 @@ def _to_match_ip(value): return value, None -def _to_match_metadata(value): - if '/' in value: +def _to_match_masked_int(value): + if isinstance(value, str) and '/' in value: value = value.split('/') return _str_to_int(value[0]), _str_to_int(value[1]) else: @@ -270,17 +270,17 @@ class Test_ofctl(unittest.TestCase): elif key == 'vlan_vid': eq_(expected_value['vlan_vid'][value]['to_match'], field_value) return - elif key == 'metadata': - # Metadata - meta, mask = _to_match_metadata(value) + elif key == 'metadata' or key == 'ipv6_exthdr': + # Metadata or IPv6 Extension Header pseudo-field + value, mask = _to_match_masked_int(value) if mask is not None: # with mask - meta &= mask - eq_(meta, field_value[0]) + value &= mask + eq_(value, field_value[0]) eq_(mask, field_value[1]) else: # without mask - eq_(meta, field_value) + eq_(value, field_value) return else: eq_(value, field_value) @@ -348,18 +348,18 @@ class Test_ofctl(unittest.TestCase): elif key == 'dl_vlan': eq_(expected_value['vlan_vid'][value]['to_str'], field_value) return - elif key == 'metadata': - # Metadata - meta, mask = _to_match_metadata(value) + elif key == 'metadata' or key == 'ipv6_exthdr': + # Metadata or IPv6 Extension Header pseudo-field + value, mask = _to_match_masked_int(value) if mask is not None: # with mask field_value = field_value.split('/') - meta &= mask - eq_(str(meta), field_value[0]) + value &= mask + eq_(str(value), field_value[0]) eq_(str(mask), field_value[1]) else: # without mask - eq_(str(meta), field_value) + eq_(str(value), field_value) return else: eq_(value, field_value) @@ -617,6 +617,8 @@ class test_data_v1_3(test_data_v1_2): {'pbb_isid': 5, 'eth_type': 0x88E7}, {'tunnel_id': 7}, {'ipv6_exthdr': 3, 'eth_type': 0x86dd}, + {'ipv6_exthdr': "0x40", 'eth_type': 0x86dd}, + {'ipv6_exthdr': "0x40/0x1F0", 'eth_type': 0x86dd}, ] ) |