X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=tests%2Fofp-actions.at;h=452bdbfe234da8597a93f2493d1df3be79d72847;hb=HEAD;hp=6f702136119442cdead5d094007a2e419cf6fc80;hpb=f25d0cf3c366d92042269a4f787f19c741c2530c;p=sliver-openvswitch.git diff --git a/tests/ofp-actions.at b/tests/ofp-actions.at index 6f7021361..452bdbfe2 100644 --- a/tests/ofp-actions.at +++ b/tests/ofp-actions.at @@ -1,7 +1,7 @@ AT_BANNER([OpenFlow actions]) AT_SETUP([OpenFlow 1.0 action translation]) -AT_KEYWORDS([OF1.0]) +AT_KEYWORDS([ofp-actions OF1.0]) AT_DATA([test-data], [dnl # actions=LOCAL 0000 0008 fffe 04d2 @@ -39,7 +39,7 @@ AT_DATA([test-data], [dnl # actions=mod_tp_dst:443 000a 0008 01bb 0000 -# actions=enqueue:10q55 +# actions=enqueue:10:55 000b 0010 000a 000000000000 00000037 # actions=resubmit:5 @@ -69,12 +69,15 @@ ffff 0018 00002320 0009 000000000000 c426384d49c53d60 # actions=set_tunnel64:0x885f3298 ffff 0018 00002320 0009 000000000000 00000000885f3298 +# actions=write_metadata:0xfedcba9876543210 +ffff 0020 00002320 0016 000000000000 fedcba9876543210 ffffffffffffffff + +# actions=write_metadata:0xfedcba9876543210/0xffff0000ffff0000 +ffff 0020 00002320 0016 000000000000 fedcba9876543210 ffff0000ffff0000 + # actions=multipath(eth_src,50,modulo_n,1,0,NXM_NX_REG0[]) ffff 0020 00002320 000a 0000 0032 0000 0000 0000 0000 0000 0000 001f 00010004 -# actions=autopath(2,NXM_NX_REG0[2..30]) -ffff 0018 00002320 000b 009c 00010004 00000002 00000000 - # actions=bundle(eth_src,0,hrw,ofport,slaves:4,8) ffff 0028 00002320 000c 0001 0000 0000 00000002 0002 0000 00000000 00000000 dnl 0004 0008 00000000 @@ -108,6 +111,12 @@ ffff 0010 00002320 0013 000a 0014 0000 # actions=controller(reason=invalid_ttl,max_len=1234,id=5678) ffff 0010 00002320 0014 04d2 162e 02 00 +# actions=dec_ttl(32768,12345,90,765,1024) +ffff 0020 00002320 0015 000500000000 80003039005A02fd 0400000000000000 + +# actions=sample(probability=12345,collector_set_id=23456,obs_domain_id=34567,obs_point_id=45678) +ffff 0018 00002320 001d 3039 00005BA0 00008707 0000B26E + ]) sed '/^[[#&]]/d' < test-data > input.txt sed -n 's/^# //p; /^$/p' < test-data > expout @@ -119,3 +128,364 @@ AT_CHECK( [ovs-ofctl '-vPATTERN:console:%c|%p|%m' parse-ofp10-actions < input.txt], [0], [expout], [experr]) AT_CLEANUP + +AT_SETUP([OpenFlow 1.1 action translation]) +AT_KEYWORDS([ofp-actions OF1.1]) +AT_DATA([test-data], [dnl +# actions=LOCAL +0000 0010 fffffffe 04d2 000000000000 + +# actions=CONTROLLER:1234 +0000 0010 fffffffd 04d2 000000000000 + +# actions=set_vlan_vid:9 +0001 0008 0009 0000 + +# actions=set_vlan_pcp:6 +0002 0008 06 000000 + +# actions=mod_dl_src:00:11:22:33:44:55 +0003 0010 001122334455 000000000000 + +# actions=mod_dl_dst:10:20:30:40:50:60 +0004 0010 102030405060 000000000000 + +# actions=mod_nw_src:1.2.3.4 +0005 0008 01020304 + +# actions=mod_nw_dst:192.168.0.1 +0006 0008 c0a80001 + +# actions=mod_nw_tos:48 +0007 0008 30 000000 + +# actions=mod_tp_src:80 +0009 0008 0050 0000 + +# actions=mod_tp_dst:443 +000a 0008 01bb 0000 + +# actions=pop_vlan +0012 0008 00000000 + +# actions=set_queue:2309737729 +0015 0008 89abcd01 + +dnl 802.1ad isn't supported at the moment +dnl # actions=push_vlan:0x88a8 +dnl 0011 0008 88a8 0000 +# actions=push_vlan:0x8100 +0011 0008 8100 0000 + +# actions=resubmit:5 +ffff 0010 00002320 0001 0005 00000000 + +# actions=set_tunnel:0x12345678 +ffff 0010 00002320 0002 0000 12345678 + +# actions=pop_queue +ffff 0010 00002320 0005 000000000000 + +# actions=move:NXM_OF_IN_PORT[]->NXM_OF_VLAN_TCI[] +ffff 0018 00002320 0006 0010 0000 0000 00000002 00000802 + +# actions=load:0xf009->NXM_OF_VLAN_TCI[] +ffff 0018 00002320 0007 000f 00000802 000000000000f009 + +# actions=note:11.e9.9a.ad.67.f3 +ffff 0010 00002320 0008 11e99aad67f3 + +# actions=set_tunnel64:0xc426384d49c53d60 +ffff 0018 00002320 0009 000000000000 c426384d49c53d60 + +# actions=set_tunnel64:0x885f3298 +ffff 0018 00002320 0009 000000000000 00000000885f3298 + +dnl OpenFlow 1.1 uses OFPIT_WRITE_METADATA to express the NXAST_WRITE_METADATA +dnl action instead, so parse-ofp11-actions will recognise and drop this action. +# actions=write_metadata:0xfedcba9876543210 +# 0: ff -> (none) +# 1: ff -> (none) +# 2: 00 -> (none) +# 3: 20 -> (none) +# 4: 00 -> (none) +# 5: 00 -> (none) +# 6: 23 -> (none) +# 7: 20 -> (none) +# 8: 00 -> (none) +# 9: 16 -> (none) +# 10: 00 -> (none) +# 11: 00 -> (none) +# 12: 00 -> (none) +# 13: 00 -> (none) +# 14: 00 -> (none) +# 15: 00 -> (none) +# 16: fe -> (none) +# 17: dc -> (none) +# 18: ba -> (none) +# 19: 98 -> (none) +# 20: 76 -> (none) +# 21: 54 -> (none) +# 22: 32 -> (none) +# 23: 10 -> (none) +# 24: ff -> (none) +# 25: ff -> (none) +# 26: ff -> (none) +# 27: ff -> (none) +# 28: ff -> (none) +# 29: ff -> (none) +# 30: ff -> (none) +# 31: ff -> (none) +ffff 0020 00002320 0016 000000000000 fedcba9876543210 ffffffffffffffff + +dnl Write-Metadata duplicated. +& ofp_actions|WARN|duplicate write_metadata instruction not allowed, for OpenFlow 1.1+ compatibility +# bad OF1.1 actions: OFPBAC_UNSUPPORTED_ORDER +ffff 0020 00002320 0016 000000000000 fedcba9876543210 ffffffffffffffff ffff 0020 00002320 0016 000000000000 fedcba9876543210 ffffffffffffffff + +dnl Write-Metadata in wrong position. +& ofp_actions|WARN|invalid instruction ordering: apply_actions must appear before write_metadata, for OpenFlow 1.1+ compatibility +# bad OF1.1 actions: OFPBAC_UNSUPPORTED_ORDER +ffff 0020 00002320 0016 000000000000 fedcba9876543210 ffffffffffffffff ffff 0010 00002320 0002 0000 12345678 + +# actions=multipath(eth_src,50,modulo_n,1,0,NXM_NX_REG0[]) +ffff 0020 00002320 000a 0000 0032 0000 0000 0000 0000 0000 0000 001f 00010004 + +# actions=bundle(eth_src,0,hrw,ofport,slaves:4,8) +ffff 0028 00002320 000c 0001 0000 0000 00000002 0002 0000 00000000 00000000 dnl +0004 0008 00000000 + +# actions=bundle_load(eth_src,0,hrw,ofport,NXM_NX_REG0[],slaves:4,8) +ffff 0028 00002320 000d 0001 0000 0000 00000002 0002 001f 00010004 00000000 dnl +0004 0008 00000000 + +# actions=resubmit(10,5) +ffff 0010 00002320 000e 000a 05 000000 + +# actions=output:NXM_NX_REG1[5..10] +ffff 0018 00002320 000f 0145 00010204 ffff 000000000000 + +# actions=learn(table=2,idle_timeout=10,hard_timeout=20,fin_idle_timeout=2,fin_hard_timeout=4,priority=80,cookie=0x123456789abcdef0,NXM_OF_VLAN_TCI[0..11],NXM_OF_ETH_DST[]=NXM_OF_ETH_SRC[],output:NXM_OF_IN_PORT[]) +ffff 0048 00002320 0010 000a 0014 0050 123456789abcdef0 0000 02 00 0002 0004 dnl +000c 00000802 0000 00000802 0000 dnl +0030 00000406 0000 00000206 0000 dnl +1010 00000002 0000 dnl +00000000 + +# actions=exit +ffff 0010 00002320 0011 000000000000 + +dnl NXAST_DEC_TTL +# actions=dec_ttl +ffff 0010 00002320 0012 000000000000 + +dnl OpenFlow 1.1 OFPAT_DEC_TTL +# actions=dec_ttl +0018 0008 00000000 + +# actions=fin_timeout(idle_timeout=10,hard_timeout=20) +ffff 0010 00002320 0013 000a 0014 0000 + +# actions=controller(reason=invalid_ttl,max_len=1234,id=5678) +ffff 0010 00002320 0014 04d2 162e 02 00 + +# actions=dec_ttl(32768,12345,90,765,1024) +ffff 0020 00002320 0015 000500000000 80003039005A02fd 0400000000000000 + +# actions=sample(probability=12345,collector_set_id=23456,obs_domain_id=34567,obs_point_id=45678) +ffff 0018 00002320 001d 3039 00005BA0 00008707 0000B26E + +]) +sed '/^[[#&]]/d' < test-data > input.txt +sed -n 's/^# //p; /^$/p' < test-data > expout +sed -n 's/^& //p' < test-data > experr +AT_CAPTURE_FILE([input.txt]) +AT_CAPTURE_FILE([expout]) +AT_CAPTURE_FILE([experr]) +AT_CHECK( + [ovs-ofctl '-vPATTERN:console:%c|%p|%m' parse-ofp11-actions < input.txt], + [0], [expout], [experr]) +AT_CLEANUP + +AT_SETUP([OpenFlow 1.1 instruction translation]) +AT_KEYWORDS([OF1.1 instruction ofp-actions]) +AT_DATA([test-data], [dnl +# actions=LOCAL +0004 0018 00000000 dnl +0000 0010 fffffffe 04d2 000000000000 + +dnl Apply-Actions non-zero padding +# actions=drop +# 0: 00 -> (none) +# 1: 04 -> (none) +# 2: 00 -> (none) +# 3: 08 -> (none) +# 4: 00 -> (none) +# 5: 00 -> (none) +# 6: 00 -> (none) +# 7: 01 -> (none) +0004 0008 00000001 + +dnl Check that an empty Apply-Actions instruction gets dropped. +# actions=drop +# 0: 00 -> (none) +# 1: 04 -> (none) +# 2: 00 -> (none) +# 3: 08 -> (none) +# 4: 00 -> (none) +# 5: 00 -> (none) +# 6: 00 -> (none) +# 7: 00 -> (none) +0004 0008 00000000 + +dnl Duplicate instruction type: +# bad OF1.1 instructions: ONFBIC_DUP_INSTRUCTION +0004 0008 00000000 0004 0008 00000000 + +dnl Instructions not multiple of 8 in length. +& ofp_actions|WARN|OpenFlow message instructions length 9 is not a multiple of 8 +# bad OF1.1 instructions: OFPBIC_BAD_LEN +0004 0009 01 00000000 + +dnl Goto-Table instruction too long. +# bad OF1.1 instructions: OFPBIC_BAD_LEN +0001 0010 01 000000 0000000000000000 + +dnl Goto-Table 1 instruction non-zero padding +# actions=goto_table:1 +# 7: 01 -> 00 +0001 0008 01 000001 + +dnl Goto-Table 1 instruction go back to the previous table. +# bad OF1.1 instructions: OFPBRC_BAD_TABLE_ID +2,0001 0008 01 000000 + +dnl Goto-Table 1 +# actions=goto_table:1 +0001 0008 01 000000 + +dnl Write-Metadata. +# actions=write_metadata:0xfedcba9876543210 +0002 0018 00000000 fedcba9876543210 ffffffffffffffff + +dnl Write-Metadata with mask. +# actions=write_metadata:0xfedcba9876543210/0xff00ff00ff00ff00 +0002 0018 00000000 fedcba9876543210 ff00ff00ff00ff00 + +dnl Write-Metadata too short. +# bad OF1.1 instructions: OFPBIC_BAD_LEN +0002 0010 00000000 fedcba9876543210 + +dnl Write-Metadata too long. +# bad OF1.1 instructions: OFPBIC_BAD_LEN +0002 0020 00000000 fedcba9876543210 ffffffffffffffff 0000000000000000 + +dnl Write-Metadata duplicated. +# bad OF1.1 instructions: ONFBIC_DUP_INSTRUCTION +0002 0018 00000000 fedcba9876543210 ff00ff00ff00ff00 0002 0018 00000000 fedcba9876543210 ff00ff00ff00ff00 + +dnl Write-Metadata in wrong position (OpenFlow 1.1+ disregards the order +dnl and OVS reorders it to the canonical order) +# actions=write_metadata:0xfedcba9876543210,goto_table:1 +# 1: 01 -> 02 +# 3: 08 -> 18 +# 4: 01 -> 00 +# 8: 00 -> fe +# 9: 02 -> dc +# 10: 00 -> ba +# 11: 18 -> 98 +# 12: 00 -> 76 +# 13: 00 -> 54 +# 14: 00 -> 32 +# 15: 00 -> 10 +# 16: fe -> ff +# 17: dc -> ff +# 18: ba -> ff +# 19: 98 -> ff +# 20: 76 -> ff +# 21: 54 -> ff +# 22: 32 -> ff +# 23: 10 -> ff +# 24: ff -> 00 +# 25: ff -> 01 +# 26: ff -> 00 +# 27: ff -> 08 +# 28: ff -> 01 +# 29: ff -> 00 +# 30: ff -> 00 +# 31: ff -> 00 +0001 0008 01 000000 0002 0018 00000000 fedcba9876543210 ffffffffffffffff + +dnl empty Write-Actions non-zero padding +# actions=write_actions(drop) +# 0: 00 -> (none) +# 1: 03 -> (none) +# 2: 00 -> (none) +# 3: 08 -> (none) +# 4: 00 -> (none) +# 5: 00 -> (none) +# 6: 00 -> (none) +# 7: 01 -> (none) +0003 0008 00000001 + +dnl Check that an empty Write-Actions instruction gets dropped. +# actions=write_actions(drop) +# 0: 00 -> (none) +# 1: 03 -> (none) +# 2: 00 -> (none) +# 3: 08 -> (none) +# 4: 00 -> (none) +# 5: 00 -> (none) +# 6: 00 -> (none) +# 7: 00 -> (none) +0003 0008 00000000 + +dnl Clear-Actions too-long +# bad OF1.1 instructions: OFPBIC_BAD_LEN +0005 0010 00000000 0000000000000000 + +dnl Clear-Actions non-zero padding +# actions=clear_actions +# 7: 01 -> 00 +0005 0008 00000001 + +dnl Clear-Actions non-zero padding +# actions=clear_actions +# 4: 01 -> 00 +0005 0008 01 000000 + +dnl Clear-Actions +# actions=clear_actions +0005 0008 00000000 + +dnl Experimenter actions not supported yet. +# bad OF1.1 instructions: OFPBIC_BAD_EXPERIMENTER +ffff 0008 01 000000 + +dnl Bad instruction number (0 not assigned). +# bad OF1.1 instructions: OFPBIC_UNKNOWN_INST +0000 0008 01 000000 + +]) +sed '/^[[#&]]/d' < test-data > input.txt +sed -n 's/^# //p; /^$/p' < test-data > expout +sed -n 's/^& //p' < test-data > experr +AT_CAPTURE_FILE([input.txt]) +AT_CAPTURE_FILE([expout]) +AT_CAPTURE_FILE([experr]) +AT_CHECK( + [ovs-ofctl '-vPATTERN:console:%c|%p|%m' parse-ofp11-instructions < input.txt], + [0], [expout], [experr]) +AT_CLEANUP + +AT_SETUP([ofp-actions - inconsistent MPLS actions]) +OVS_VSWITCHD_START +dnl OK: Use fin_timeout action on TCP flow +AT_CHECK([ovs-ofctl -O OpenFlow11 -vwarn add-flow br0 'tcp actions=fin_timeout(idle_timeout=1)']) +dnl Bad: Use fin_timeout action on TCP flow that has been converted to MPLS +AT_CHECK([ovs-ofctl -O OpenFlow11 -vwarn add-flow br0 'tcp actions=push_mpls:0x8847,fin_timeout(idle_timeout=1)'], + [1], [], [dnl +ovs-ofctl: none of the usable flow formats (OpenFlow10,NXM) is among the allowed flow formats (OpenFlow11) +]) +OVS_VSWITCHD_STOP +AT_CLEANUP