]> git.proxmox.com Git - ovs.git/blob - tests/tunnel-push-pop-ipv6.at
tests: Fix sparse error on test-ovn.c
[ovs.git] / tests / tunnel-push-pop-ipv6.at
1 AT_BANNER([tunnel_push_pop_ipv6])
2
3 AT_SETUP([tunnel_push_pop_ipv6 - action])
4
5 OVS_VSWITCHD_START([add-port br0 p0 -- set Interface p0 type=dummy ofport_request=1 other-config:hwaddr=aa:55:aa:55:00:00])
6 AT_CHECK([ovs-vsctl add-br int-br -- set bridge int-br datapath_type=dummy], [0])
7 AT_CHECK([ovs-vsctl add-port int-br t2 -- set Interface t2 type=vxlan \
8 options:remote_ip=2001:cafe::92 options:key=123 ofport_request=2\
9 -- add-port int-br t1 -- set Interface t1 type=gre \
10 options:remote_ip=2001:cafe::92 options:key=456 ofport_request=3\
11 -- add-port int-br t3 -- set Interface t3 type=vxlan \
12 options:remote_ip=2001:cafe::93 options:out_key=flow options:csum=true ofport_request=4\
13 -- add-port int-br t4 -- set Interface t4 type=geneve \
14 options:remote_ip=flow options:key=123 ofport_request=5\
15 -- add-port int-br t5 -- set Interface t5 type=gre \
16 options:remote_ip=2001:cafe::92 options:key=455 options:packet_type=legacy_l3 ofport_request=6\
17 ], [0])
18
19 AT_CHECK([ovs-appctl dpif/show], [0], [dnl
20 dummy@ovs-dummy: hit:0 missed:0
21 br0:
22 br0 65534/100: (dummy-internal)
23 p0 1/1: (dummy)
24 int-br:
25 int-br 65534/2: (dummy-internal)
26 t1 3/3: (gre: key=456, remote_ip=2001:cafe::92)
27 t2 2/4789: (vxlan: key=123, remote_ip=2001:cafe::92)
28 t3 4/4789: (vxlan: csum=true, out_key=flow, remote_ip=2001:cafe::93)
29 t4 5/6081: (geneve: key=123, remote_ip=flow)
30 t5 6/3: (gre: key=455, packet_type=legacy_l3, remote_ip=2001:cafe::92)
31 ])
32
33 dnl First setup dummy interface IP address, then add the route
34 dnl so that tnl-port table can get valid IP address for the device.
35 AT_CHECK([ovs-appctl netdev-dummy/ip6addr br0 2001:cafe::88/24], [0], [OK
36 ])
37 AT_CHECK([ovs-appctl netdev-dummy/ip4addr br0 1.1.2.88/24], [0], [OK
38 ])
39 AT_CHECK([ovs-appctl ovs/route/add 2001:cafe::92/24 br0], [0], [OK
40 ])
41
42 AT_CHECK([ovs-ofctl add-flow br0 action=normal])
43
44 dnl Check Neighbour discovery.
45 AT_CHECK([ovs-vsctl -- set Interface p0 options:pcap=p0.pcap])
46
47 AT_CHECK([ovs-appctl netdev-dummy/receive int-br 'in_port(2),eth(src=aa:55:aa:55:00:00,dst=f8:bc:12:ff:ff:ff),eth_type(0x0800),ipv4(src=1.1.3.92,dst=1.1.3.88,proto=1,tos=0,ttl=64,frag=no),icmp(type=0,code=0)'])
48 AT_CHECK([ovs-pcap p0.pcap > p0.pcap.txt 2>&1])
49
50 AT_CHECK([cat p0.pcap.txt | grep 92aa55aa55000086dd6000000000203aff2001cafe | uniq], [0], [dnl
51 3333ff000092aa55aa55000086dd6000000000203aff2001cafe000000000000000000000088ff0200000000000000000001ff00009287004d48000000002001cafe0000000000000000000000920101aa55aa550000
52 ])
53 AT_CHECK([cat p0.pcap.txt | grep 93aa55aa55000086dd6000000000203aff2001cafe | uniq], [0], [dnl
54 3333ff000093aa55aa55000086dd6000000000203aff2001cafe000000000000000000000088ff0200000000000000000001ff00009387004d46000000002001cafe0000000000000000000000930101aa55aa550000
55 ])
56
57 dnl Check ARP Snoop
58 AT_CHECK([ovs-appctl netdev-dummy/receive br0 'in_port(100),eth(src=f8:bc:12:44:34:b6,dst=aa:55:aa:55:00:00),eth_type(0x86dd),ipv6(src=2001:cafe::92,dst=2001:cafe::94,label=0,proto=58,tclass=0,hlimit=255,frag=no),icmpv6(type=136,code=0),nd(target=2001:cafe::92,sll=00:00:00:00:00:00,tll=f8:bc:12:44:34:b6)'])
59
60 AT_CHECK([ovs-appctl netdev-dummy/receive br0 'in_port(100),eth(src=f8:bc:12:44:34:b7,dst=aa:55:aa:55:00:00),eth_type(0x86dd),ipv6(src=2001:cafe::93,dst=2001:cafe::94,label=0,proto=58,tclass=0,hlimit=255,frag=no),icmpv6(type=136,code=0),nd(target=2001:cafe::93,sll=00:00:00:00:00:00,tll=f8:bc:12:44:34:b7)'])
61
62 AT_CHECK([ovs-appctl tnl/arp/show | tail -n+3 | sort], [0], [dnl
63 2001:cafe::92 f8:bc:12:44:34:b6 br0
64 2001:cafe::93 f8:bc:12:44:34:b7 br0
65 ])
66
67 AT_CHECK([ovs-appctl tnl/ports/show |sort], [0], [dnl
68 Listening ports:
69 genev_sys_6081 (6081)
70 gre_sys (3)
71 vxlan_sys_4789 (4789)
72 ])
73
74 dnl Check VXLAN tunnel pop
75 AT_CHECK([ovs-appctl ofproto/trace ovs-dummy 'in_port(1),eth(src=f8:bc:12:44:34:b6,dst=aa:55:aa:55:00:00),eth_type(0x86dd),ipv6(src=2001:cafe::92,dst=2001:cafe::88,label=0,proto=17,tclass=0x0,hlimit=64),udp(src=51283,dst=4789)'], [0], [stdout])
76 AT_CHECK([tail -1 stdout], [0],
77 [Datapath actions: tnl_pop(4789)
78 ])
79
80 dnl Check GRE tunnel pop
81 AT_CHECK([ovs-appctl ofproto/trace ovs-dummy 'in_port(1),eth(src=f8:bc:12:44:34:b6,dst=aa:55:aa:55:00:00),eth_type(0x86dd),ipv6(src=2001:cafe::92,dst=2001:cafe::88,label=0,proto=47,tclass=0x0,hlimit=64)'], [0], [stdout])
82 AT_CHECK([tail -1 stdout], [0],
83 [Datapath actions: tnl_pop(3)
84 ])
85
86 dnl Check Geneve tunnel pop
87 AT_CHECK([ovs-appctl ofproto/trace ovs-dummy 'in_port(1),eth(src=f8:bc:12:44:34:b6,dst=aa:55:aa:55:00:00),eth_type(0x86dd),ipv6(src=2001:cafe::92,dst=2001:cafe::88,label=0,proto=17,tclass=0x0,hlimit=64),udp(src=51283,dst=6081)'], [0], [stdout])
88 AT_CHECK([tail -1 stdout], [0],
89 [Datapath actions: tnl_pop(6081)
90 ])
91
92 dnl Check VXLAN tunnel push
93 AT_CHECK([ovs-ofctl add-flow int-br action=2])
94 AT_CHECK([ovs-appctl ofproto/trace ovs-dummy 'in_port(2),eth(src=f8:bc:12:44:34:b6,dst=aa:55:aa:55:00:01),eth_type(0x0800),ipv4(src=1.1.3.88,dst=1.1.3.112,proto=47,tos=0,ttl=64,frag=no)'], [0], [stdout])
95 AT_CHECK([tail -1 stdout], [0],
96 [Datapath actions: tnl_push(tnl_port(4789),header(size=70,type=4,eth(dst=f8:bc:12:44:34:b6,src=aa:55:aa:55:00:00,dl_type=0x86dd),ipv6(src=2001:cafe::88,dst=2001:cafe::92,label=0,proto=17,tclass=0x0,hlimit=64),udp(src=0,dst=4789,csum=0xffff),vxlan(flags=0x8000000,vni=0x7b)),out_port(100))
97 ])
98
99 dnl Check VXLAN tunnel push set tunnel id by flow and checksum
100 AT_CHECK([ovs-ofctl add-flow int-br "actions=set_tunnel:124,4"])
101 AT_CHECK([ovs-appctl ofproto/trace ovs-dummy 'in_port(2),eth(src=f8:bc:12:44:34:b6,dst=aa:55:aa:55:00:01),eth_type(0x0800),ipv4(src=1.1.3.88,dst=1.1.3.112,proto=47,tos=0,ttl=64,frag=no)'], [0], [stdout])
102 AT_CHECK([tail -1 stdout], [0],
103 [Datapath actions: tnl_push(tnl_port(4789),header(size=70,type=4,eth(dst=f8:bc:12:44:34:b7,src=aa:55:aa:55:00:00,dl_type=0x86dd),ipv6(src=2001:cafe::88,dst=2001:cafe::93,label=0,proto=17,tclass=0x0,hlimit=64),udp(src=0,dst=4789,csum=0xffff),vxlan(flags=0x8000000,vni=0x7c)),out_port(100))
104 ])
105
106 dnl Check GRE tunnel push
107 AT_CHECK([ovs-ofctl add-flow int-br action=3])
108 AT_CHECK([ovs-appctl ofproto/trace ovs-dummy 'in_port(2),eth(src=f8:bc:12:44:34:b6,dst=aa:55:aa:55:00:01),eth_type(0x0800),ipv4(src=1.1.3.88,dst=1.1.3.112,proto=47,tos=0,ttl=64,frag=no)'], [0], [stdout])
109 AT_CHECK([tail -1 stdout], [0],
110 [Datapath actions: tnl_push(tnl_port(3),header(size=62,type=3,eth(dst=f8:bc:12:44:34:b6,src=aa:55:aa:55:00:00,dl_type=0x86dd),ipv6(src=2001:cafe::88,dst=2001:cafe::92,label=0,proto=47,tclass=0x0,hlimit=64),gre((flags=0x2000,proto=0x6558),key=0x1c8)),out_port(100))
111 ])
112
113 dnl Check Geneve tunnel push
114 AT_CHECK([ovs-ofctl add-flow int-br "actions=set_field:2001:cafe::92->tun_ipv6_dst,5"])
115 AT_CHECK([ovs-appctl ofproto/trace ovs-dummy 'in_port(2),eth(src=f8:bc:12:44:34:b6,dst=aa:55:aa:55:00:01),eth_type(0x0800),ipv4(src=1.1.3.88,dst=1.1.3.112,proto=47,tos=0,ttl=64,frag=no)'], [0], [stdout])
116 AT_CHECK([tail -1 stdout], [0],
117 [Datapath actions: tnl_push(tnl_port(6081),header(size=70,type=5,eth(dst=f8:bc:12:44:34:b6,src=aa:55:aa:55:00:00,dl_type=0x86dd),ipv6(src=2001:cafe::88,dst=2001:cafe::92,label=0,proto=17,tclass=0x0,hlimit=64),udp(src=0,dst=6081,csum=0xffff),geneve(vni=0x7b)),out_port(100))
118 ])
119
120 dnl Check Geneve tunnel push with options
121 AT_CHECK([ovs-ofctl add-tlv-map int-br "{class=0xffff,type=0x80,len=4}->tun_metadata0"])
122 AT_CHECK([ovs-ofctl add-flow int-br "actions=set_field:2001:cafe::92->tun_ipv6_dst,set_field:0xa->tun_metadata0,5"])
123 AT_CHECK([ovs-appctl ofproto/trace ovs-dummy 'in_port(2),eth(src=f8:bc:12:44:34:b6,dst=aa:55:aa:55:00:01),eth_type(0x0800),ipv4(src=1.1.3.88,dst=1.1.3.112,proto=47,tos=0,ttl=64,frag=no)'], [0], [stdout])
124 AT_CHECK([tail -1 stdout], [0],
125 [Datapath actions: tnl_push(tnl_port(6081),header(size=78,type=5,eth(dst=f8:bc:12:44:34:b6,src=aa:55:aa:55:00:00,dl_type=0x86dd),ipv6(src=2001:cafe::88,dst=2001:cafe::92,label=0,proto=17,tclass=0x0,hlimit=64),udp(src=0,dst=6081,csum=0xffff),geneve(crit,vni=0x7b,options({class=0xffff,type=0x80,len=4,0xa}))),out_port(100))
126 ])
127
128 dnl Check decapsulation of GRE packet
129 AT_CHECK([ovs-appctl netdev-dummy/receive p0 'aa55aa550000001b213cab6486dd60000000006a2f402001cafe0000000000000000000000922001cafe00000000000000000000008820006558000001c8fe71d883724fbeb6f4e1494a080045000054ba200000400184861e0000011e00000200004227e75400030af3195500000000f265010000000000101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f3031323334353637'])
130 AT_CHECK([ovs-appctl netdev-dummy/receive p0 'aa55aa550000001b213cab6486dd60000000006a2f402001cafe0000000000000000000000922001cafe00000000000000000000008820006558000001c8fe71d883724fbeb6f4e1494a080045000054ba200000400184861e0000011e00000200004227e75400030af3195500000000f265010000000000101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f3031323334353637'])
131 ovs-appctl time/warp 1000
132
133 AT_CHECK([ovs-ofctl dump-ports int-br | grep 'port 3'], [0], [dnl
134 port 3: rx pkts=2, bytes=196, drop=?, errs=?, frame=?, over=?, crc=?
135 ])
136
137 dnl Check decapsulation of L3GRE packet
138 AT_CHECK([ovs-appctl netdev-dummy/receive p0 'aa55aa550000001b213cab6486dd60000000005a2f402001cafe0000000000000000000000922001cafe00000000000000000000008820000800000001c745000054ba200000400184861e0000011e00000200004227e75400030af3195500000000f265010000000000101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f3031323334353637'])
139 AT_CHECK([ovs-appctl netdev-dummy/receive p0 'aa55aa550000001b213cab6486dd60000000005a2f402001cafe0000000000000000000000922001cafe00000000000000000000008820000800000001c745000054ba200000400184861e0000011e00000200004227e75400030af3195500000000f265010000000000101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f3031323334353637'])
140 ovs-appctl time/warp 1000
141 ovs-appctl time/warp 1000
142
143 AT_CHECK([ovs-ofctl dump-ports int-br | grep 'port 6'], [0], [dnl
144 port 6: rx pkts=2, bytes=168, drop=?, errs=?, frame=?, over=?, crc=?
145 ])
146
147 dnl Check decapsulation of Geneve packet with options
148 AT_CAPTURE_FILE([ofctl_monitor.log])
149 AT_CHECK([ovs-ofctl monitor int-br 65534 --detach --no-chdir --pidfile 2> ofctl_monitor.log])
150
151 AT_CHECK([ovs-ofctl del-flows int-br])
152 AT_CHECK([ovs-ofctl add-flow int-br "tun_metadata0=0xa/0xf,actions=5,controller"])
153 AT_CHECK([ovs-appctl netdev-dummy/receive p0 'aa55aa550000001b213cab6486dd60000000008211402001cafe0000000000000000000000922001cafe000000000000000000000088308817c1008200000400655800007b00ffff80010000000affff00010000000bfe71d883724fbeb6f4e1494a080045000054ba200000400184861e0000011e00000200004227e75400030af3195500000000f265010000000000101112131415161718191a1b1c1d1e1f202122232425262728292a2b2c2d2e2f3031323334353637'])
154
155 OVS_WAIT_UNTIL([test `wc -l < ofctl_monitor.log` -ge 2])
156 OVS_APP_EXIT_AND_WAIT(ovs-ofctl)
157
158 AT_CHECK([cat ofctl_monitor.log], [0], [dnl
159 NXT_PACKET_IN2 (xid=0x0): cookie=0x0 total_len=98 tun_id=0x7b,tun_ipv6_src=2001:cafe::92,tun_ipv6_dst=2001:cafe::88,tun_metadata0=0xa,in_port=5 (via action) data_len=98 (unbuffered)
160 icmp,vlan_tci=0x0000,dl_src=be:b6:f4:e1:49:4a,dl_dst=fe:71:d8:83:72:4f,nw_src=30.0.0.1,nw_dst=30.0.0.2,nw_tos=0,nw_ecn=0,nw_ttl=64,icmp_type=0,icmp_code=0 icmp_csum:4227
161 ])
162
163 AT_CHECK([ovs-ofctl dump-ports int-br | grep 'port 5'], [0], [dnl
164 port 5: rx pkts=1, bytes=98, drop=?, errs=?, frame=?, over=?, crc=?
165 ])
166 AT_CHECK([ovs-appctl dpif/dump-flows int-br | grep 'in_port(6081)'], [0], [dnl
167 tunnel(tun_id=0x7b,ipv6_src=2001:cafe::92,ipv6_dst=2001:cafe::88,geneve({class=0xffff,type=0x80,len=4,0xa/0xf}{class=0xffff,type=0,len=4}),flags(-df-csum+key)),recirc_id(0),in_port(6081),packet_type(ns=0,id=0),eth_type(0x0800),ipv4(frag=no), packets:0, bytes:0, used:never, actions:userspace(pid=0,slow_path(controller))
168 ])
169
170 OVS_VSWITCHD_STOP
171 AT_CLEANUP