Merge pull request #62 from poolakiran/of1.3_oxm_actions
Added OpenFlow 1.3 tests for testing IPv6 specific cases.
diff --git a/tests-1.3/actions.py b/tests-1.3/actions.py
index 3361659..e5b1e3a 100644
--- a/tests-1.3/actions.py
+++ b/tests-1.3/actions.py
@@ -130,6 +130,40 @@
exp_pkt = simple_tcp_packet(dl_vlan_enable=True, pktlen=104)
self.verify_modify(actions, pkt, exp_pkt)
+class PushVlanVid(BaseModifyPacketTest):
+ """
+ Push a vlan tag (vid=2, pcp=0)
+ """
+ def runTest(self):
+ actions = [ofp.action.push_vlan(ethertype=0x8100),
+ ofp.action.set_field(ofp.oxm.vlan_vid(2))]
+ pkt = simple_tcp_packet()
+ exp_pkt = simple_tcp_packet(dl_vlan_enable=True, vlan_vid=2, pktlen=104)
+ self.verify_modify(actions, pkt, exp_pkt)
+
+class PushVlanVidPcp(BaseModifyPacketTest):
+ """
+ Push a vlan tag (vid=2, pcp=3)
+ """
+ def runTest(self):
+ actions = [ofp.action.push_vlan(ethertype=0x8100),
+ ofp.action.set_field(ofp.oxm.vlan_vid(2)),
+ ofp.action.set_field(ofp.oxm.vlan_pcp(3))]
+ pkt = simple_tcp_packet()
+ exp_pkt = simple_tcp_packet(dl_vlan_enable=True, vlan_vid=2, vlan_pcp=3, pktlen=104)
+ self.verify_modify(actions, pkt, exp_pkt)
+
+class PushVlanPcp(BaseModifyPacketTest):
+ """
+ Push a vlan tag (vid=0, pcp=3)
+ """
+ def runTest(self):
+ actions = [ofp.action.push_vlan(ethertype=0x8100),
+ ofp.action.set_field(ofp.oxm.vlan_pcp(3))]
+ pkt = simple_tcp_packet()
+ exp_pkt = simple_tcp_packet(dl_vlan_enable=True, vlan_vid=0, vlan_pcp=3, pktlen=104)
+ self.verify_modify(actions, pkt, exp_pkt)
+
class PopVlan(BaseModifyPacketTest):
"""
Pop a vlan tag
@@ -180,9 +214,9 @@
exp_pkt = simple_tcp_packet(eth_src="00:A1:CD:53:C6:55")
self.verify_modify(actions, pkt, exp_pkt)
-class SetIpDscp(BaseModifyPacketTest):
+class SetIpv4Dscp(BaseModifyPacketTest):
"""
- Set IP DSCP
+ Set IPv4 DSCP
"""
def runTest(self):
actions = [ofp.action.set_field(ofp.oxm.ip_dscp(0x01))]
@@ -190,9 +224,9 @@
exp_pkt = simple_tcp_packet(ip_tos=0x04)
self.verify_modify(actions, pkt, exp_pkt)
-class SetIpECN(BaseModifyPacketTest):
+class SetIpv4ECN(BaseModifyPacketTest):
"""
- Set IP ECN
+ Set IPv4 ECN
"""
def runTest(self):
actions = [ofp.action.set_field(ofp.oxm.ip_ecn(0x01))]
@@ -200,9 +234,9 @@
exp_pkt = simple_tcp_packet(ip_tos=0x01)
self.verify_modify(actions, pkt, exp_pkt)
-class SetIpDSCP_NonZeroECN(BaseModifyPacketTest):
+class SetIpv4DSCP_NonZeroECN(BaseModifyPacketTest):
"""
- Set IP DSCP and make sure ECN is not modified
+ Set IPv4 DSCP and make sure ECN is not modified
"""
def runTest(self):
actions = [ofp.action.set_field(ofp.oxm.ip_dscp(0x01))]
@@ -210,9 +244,9 @@
exp_pkt = simple_tcp_packet(ip_tos=0x05)
self.verify_modify(actions, pkt, exp_pkt)
-class SetIpECN_NonZeroDSCP(BaseModifyPacketTest):
+class SetIpv4ECN_NonZeroDSCP(BaseModifyPacketTest):
"""
- Set IP ECN and make sure DSCP is not modified
+ Set IPv4 ECN and make sure DSCP is not modified
"""
def runTest(self):
actions = [ofp.action.set_field(ofp.oxm.ip_ecn(0x02))]
@@ -300,6 +334,26 @@
exp_pkt = simple_tcpv6_packet(ipv6_dst="2001:abb1:3456:bccb:0000:0000:0370:7336")
self.verify_modify(actions, pkt, exp_pkt)
+class SetIpv6Dscp(BaseModifyPacketTest):
+ """
+ Set IPv6 DSCP
+ """
+ def runTest(self):
+ actions = [ofp.action.set_field(ofp.oxm.ip_dscp(0x01))]
+ pkt = simple_tcpv6_packet()
+ exp_pkt = simple_tcpv6_packet(ipv6_tc=0x04)
+ self.verify_modify(actions, pkt, exp_pkt)
+
+class SetIpv6ECN(BaseModifyPacketTest):
+ """
+ Set IPv6 ECN
+ """
+ def runTest(self):
+ actions = [ofp.action.set_field(ofp.oxm.ip_ecn(0x01))]
+ pkt = simple_tcpv6_packet()
+ exp_pkt = simple_tcpv6_packet(ipv6_tc=0x01)
+ self.verify_modify(actions, pkt, exp_pkt)
+
class SetIPv6Flabel(BaseModifyPacketTest):
"""
Set IPv6 Flabel
@@ -310,9 +364,39 @@
exp_pkt = simple_tcpv6_packet(ipv6_fl=10)
self.verify_modify(actions, pkt, exp_pkt)
-class SetNwTTL(BaseModifyPacketTest):
+class SetIpv6DSCP_NonZeroECNandFlabel(BaseModifyPacketTest):
"""
- Set Nw TTL
+ Set IPv6 DSCP and make sure ECN is not modified
+ """
+ def runTest(self):
+ actions = [ofp.action.set_field(ofp.oxm.ip_dscp(0x01))]
+ pkt = simple_tcpv6_packet(ipv6_tc=0x11, ipv6_fl=10)
+ exp_pkt = simple_tcpv6_packet(ipv6_tc=0x05, ipv6_fl=10)
+ self.verify_modify(actions, pkt, exp_pkt)
+
+class SetIpv6ECN_NonZeroDSCPandFlabel(BaseModifyPacketTest):
+ """
+ Set IPv6 ECN and make sure DSCP is not modified
+ """
+ def runTest(self):
+ actions = [ofp.action.set_field(ofp.oxm.ip_ecn(0x02))]
+ pkt = simple_tcpv6_packet(ipv6_tc=0x11, ipv6_fl=10)
+ exp_pkt = simple_tcpv6_packet(ipv6_tc=0x12, ipv6_fl=10)
+ self.verify_modify(actions, pkt, exp_pkt)
+
+class SetIPv6Flabel_NonZeroDSCPandECN(BaseModifyPacketTest):
+ """
+ Set IPv6 Flabel
+ """
+ def runTest(self):
+ actions = [ofp.action.set_field(ofp.oxm.ipv6_flabel(10))]
+ pkt = simple_tcpv6_packet(ipv6_tc=0x11, ipv6_fl=9)
+ exp_pkt = simple_tcpv6_packet(ipv6_tc=0x11, ipv6_fl=10)
+ self.verify_modify(actions, pkt, exp_pkt)
+
+class SetIpv4TTL(BaseModifyPacketTest):
+ """
+ Set IPv4 TTL
"""
def runTest(self):
actions = [ofp.action.set_nw_ttl(10)]
@@ -320,12 +404,32 @@
exp_pkt = simple_tcp_packet(ip_ttl=10)
self.verify_modify(actions, pkt, exp_pkt)
-class DecNwTTL(BaseModifyPacketTest):
+class SetIpv6HopLimit(BaseModifyPacketTest):
"""
- Decrement Nw TTL
+ Set Ipv6 Hop Limit
+ """
+ def runTest(self):
+ actions = [ofp.action.set_nw_ttl(10)]
+ pkt = simple_tcpv6_packet()
+ exp_pkt = simple_tcpv6_packet(ipv6_hlim=10)
+ self.verify_modify(actions, pkt, exp_pkt)
+
+class DecIpv4TTL(BaseModifyPacketTest):
+ """
+ Decrement Ipv4 TTL
"""
def runTest(self):
actions = [ofp.action.dec_nw_ttl()]
pkt = simple_tcp_packet(ip_ttl=10)
exp_pkt = simple_tcp_packet(ip_ttl=9)
self.verify_modify(actions, pkt, exp_pkt)
+
+class DecIpv6HopLimit(BaseModifyPacketTest):
+ """
+ Decrement Ipv6 Hop Limit
+ """
+ def runTest(self):
+ actions = [ofp.action.dec_nw_ttl()]
+ pkt = simple_tcpv6_packet(ipv6_hlim=10)
+ exp_pkt = simple_tcpv6_packet(ipv6_hlim=9)
+ self.verify_modify(actions, pkt, exp_pkt)