FAQ: Correct typo.
[sliver-openvswitch.git] / tests / ofp-actions.at
1 AT_BANNER([OpenFlow actions])
2
3 AT_SETUP([OpenFlow 1.0 action translation])
4 AT_KEYWORDS([ofp-actions OF1.0])
5 AT_DATA([test-data], [dnl
6 # actions=LOCAL
7 0000 0008 fffe 04d2
8
9 # actions=CONTROLLER:1234
10 0000 0008 fffd 04d2
11
12 # actions=mod_vlan_vid:9
13 0001 0008 0009 0000
14
15 # actions=mod_vlan_pcp:6
16 0002 0008 06 000000
17
18 # actions=strip_vlan
19 0003 0008 00000000
20
21 # actions=mod_dl_src:00:11:22:33:44:55
22 0004 0010 001122334455 000000000000
23
24 # actions=mod_dl_dst:10:20:30:40:50:60
25 0005 0010 102030405060 000000000000
26
27 # actions=mod_nw_src:1.2.3.4
28 0006 0008 01020304
29
30 # actions=mod_nw_dst:192.168.0.1
31 0007 0008 c0a80001
32
33 # actions=mod_nw_tos:48
34 0008 0008 30 000000
35
36 # actions=mod_tp_src:80
37 0009 0008 0050 0000
38
39 # actions=mod_tp_dst:443
40 000a 0008 01bb 0000
41
42 # actions=enqueue:10:55
43 000b 0010 000a 000000000000 00000037
44
45 # actions=resubmit:5
46 ffff 0010 00002320 0001 0005 00000000
47
48 # actions=set_tunnel:0x12345678
49 ffff 0010 00002320 0002 0000 12345678
50
51 # actions=set_queue:2309737729
52 ffff 0010 00002320 0004 0000 89abcd01
53
54 # actions=pop_queue
55 ffff 0010 00002320 0005 000000000000
56
57 # actions=move:NXM_OF_IN_PORT[]->NXM_OF_VLAN_TCI[]
58 ffff 0018 00002320 0006 0010 0000 0000 00000002 00000802
59
60 # actions=load:0xf009->NXM_OF_VLAN_TCI[]
61 ffff 0018 00002320 0007 000f 00000802 000000000000f009
62
63 # actions=note:11.e9.9a.ad.67.f3
64 ffff 0010 00002320 0008 11e99aad67f3
65
66 # actions=set_tunnel64:0xc426384d49c53d60
67 ffff 0018 00002320 0009 000000000000 c426384d49c53d60
68
69 # actions=set_tunnel64:0x885f3298
70 ffff 0018 00002320 0009 000000000000 00000000885f3298
71
72 # actions=write_metadata:0xfedcba9876543210
73 ffff 0020 00002320 0016 000000000000 fedcba9876543210 ffffffffffffffff
74
75 # actions=write_metadata:0xfedcba9876543210/0xffff0000ffff0000
76 ffff 0020 00002320 0016 000000000000 fedcba9876543210 ffff0000ffff0000
77
78 # actions=multipath(eth_src,50,modulo_n,1,0,NXM_NX_REG0[])
79 ffff 0020 00002320 000a 0000 0032 0000 0000 0000 0000 0000 0000 001f 00010004
80
81 # actions=bundle(eth_src,0,hrw,ofport,slaves:4,8)
82 ffff 0028 00002320 000c 0001 0000 0000 00000002 0002 0000 00000000 00000000 dnl
83 0004 0008 00000000
84
85 # actions=bundle_load(eth_src,0,hrw,ofport,NXM_NX_REG0[],slaves:4,8)
86 ffff 0028 00002320 000d 0001 0000 0000 00000002 0002 001f 00010004 00000000 dnl
87 0004 0008 00000000
88
89 # actions=resubmit(10,5)
90 ffff 0010 00002320 000e 000a 05 000000
91
92 # actions=output:NXM_NX_REG1[5..10]
93 ffff 0018 00002320 000f 0145 00010204 ffff 000000000000
94
95 # 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[])
96 ffff 0048 00002320 0010 000a 0014 0050 123456789abcdef0 0000 02 00 0002 0004 dnl
97 000c 00000802 0000 00000802 0000 dnl
98 0030 00000406 0000 00000206 0000 dnl
99 1010 00000002 0000 dnl
100 00000000
101
102 # actions=exit
103 ffff 0010 00002320 0011 000000000000
104
105 # actions=dec_ttl
106 ffff 0010 00002320 0012 000000000000
107
108 # actions=fin_timeout(idle_timeout=10,hard_timeout=20)
109 ffff 0010 00002320 0013 000a 0014 0000
110
111 # actions=controller(reason=invalid_ttl,max_len=1234,id=5678)
112 ffff 0010 00002320 0014 04d2 162e 02 00
113
114 # actions=dec_ttl(32768,12345,90,765,1024)
115 ffff 0020 00002320 0015 000500000000 80003039005A02fd 0400000000000000
116
117 # actions=sample(probability=12345,collector_set_id=23456,obs_domain_id=34567,obs_point_id=45678)
118 ffff 0018 00002320 001d 3039 00005BA0 00008707 0000B26E
119
120 ])
121 sed '/^[[#&]]/d' < test-data > input.txt
122 sed -n 's/^# //p; /^$/p' < test-data > expout
123 sed -n 's/^& //p' < test-data > experr
124 AT_CAPTURE_FILE([input.txt])
125 AT_CAPTURE_FILE([expout])
126 AT_CAPTURE_FILE([experr])
127 AT_CHECK(
128   [ovs-ofctl '-vPATTERN:console:%c|%p|%m' parse-ofp10-actions < input.txt],
129   [0], [expout], [experr])
130 AT_CLEANUP
131
132 AT_SETUP([OpenFlow 1.1 action translation])
133 AT_KEYWORDS([ofp-actions OF1.1])
134 AT_DATA([test-data], [dnl
135 # actions=LOCAL
136 0000 0010 fffffffe 04d2 000000000000
137
138 # actions=CONTROLLER:1234
139 0000 0010 fffffffd 04d2 000000000000
140
141 # actions=set_vlan_vid:9
142 0001 0008 0009 0000
143
144 # actions=set_vlan_pcp:6
145 0002 0008 06 000000
146
147 # actions=mod_dl_src:00:11:22:33:44:55
148 0003 0010 001122334455 000000000000
149
150 # actions=mod_dl_dst:10:20:30:40:50:60
151 0004 0010 102030405060 000000000000
152
153 # actions=mod_nw_src:1.2.3.4
154 0005 0008 01020304
155
156 # actions=mod_nw_dst:192.168.0.1
157 0006 0008 c0a80001
158
159 # actions=mod_nw_tos:48
160 0007 0008 30 000000
161
162 # actions=mod_tp_src:80
163 0009 0008 0050 0000
164
165 # actions=mod_tp_dst:443
166 000a 0008 01bb 0000
167
168 # actions=pop_vlan
169 0012 0008 00000000
170
171 # actions=set_queue:2309737729
172 0015 0008 89abcd01
173
174 dnl 802.1ad isn't supported at the moment
175 dnl # actions=push_vlan:0x88a8
176 dnl 0011 0008 88a8 0000
177 # actions=push_vlan:0x8100
178 0011 0008 8100 0000
179
180 # actions=resubmit:5
181 ffff 0010 00002320 0001 0005 00000000
182
183 # actions=set_tunnel:0x12345678
184 ffff 0010 00002320 0002 0000 12345678
185
186 # actions=pop_queue
187 ffff 0010 00002320 0005 000000000000
188
189 # actions=move:NXM_OF_IN_PORT[]->NXM_OF_VLAN_TCI[]
190 ffff 0018 00002320 0006 0010 0000 0000 00000002 00000802
191
192 # actions=load:0xf009->NXM_OF_VLAN_TCI[]
193 ffff 0018 00002320 0007 000f 00000802 000000000000f009
194
195 # actions=note:11.e9.9a.ad.67.f3
196 ffff 0010 00002320 0008 11e99aad67f3
197
198 # actions=set_tunnel64:0xc426384d49c53d60
199 ffff 0018 00002320 0009 000000000000 c426384d49c53d60
200
201 # actions=set_tunnel64:0x885f3298
202 ffff 0018 00002320 0009 000000000000 00000000885f3298
203
204 dnl OpenFlow 1.1 uses OFPIT_WRITE_METADATA to express the NXAST_WRITE_METADATA
205 dnl action instead, so parse-ofp11-actions will recognise and drop this action.
206 # actions=write_metadata:0xfedcba9876543210
207 #  0: ff -> (none)
208 #  1: ff -> (none)
209 #  2: 00 -> (none)
210 #  3: 20 -> (none)
211 #  4: 00 -> (none)
212 #  5: 00 -> (none)
213 #  6: 23 -> (none)
214 #  7: 20 -> (none)
215 #  8: 00 -> (none)
216 #  9: 16 -> (none)
217 # 10: 00 -> (none)
218 # 11: 00 -> (none)
219 # 12: 00 -> (none)
220 # 13: 00 -> (none)
221 # 14: 00 -> (none)
222 # 15: 00 -> (none)
223 # 16: fe -> (none)
224 # 17: dc -> (none)
225 # 18: ba -> (none)
226 # 19: 98 -> (none)
227 # 20: 76 -> (none)
228 # 21: 54 -> (none)
229 # 22: 32 -> (none)
230 # 23: 10 -> (none)
231 # 24: ff -> (none)
232 # 25: ff -> (none)
233 # 26: ff -> (none)
234 # 27: ff -> (none)
235 # 28: ff -> (none)
236 # 29: ff -> (none)
237 # 30: ff -> (none)
238 # 31: ff -> (none)
239 ffff 0020 00002320 0016 000000000000 fedcba9876543210 ffffffffffffffff
240
241 dnl Write-Metadata duplicated.
242 & ofp_actions|WARN|duplicate write_metadata instruction not allowed, for OpenFlow 1.1+ compatibility
243 # bad OF1.1 actions: OFPBAC_UNSUPPORTED_ORDER
244 ffff 0020 00002320 0016 000000000000 fedcba9876543210 ffffffffffffffff ffff 0020 00002320 0016 000000000000 fedcba9876543210 ffffffffffffffff
245
246 dnl Write-Metadata in wrong position.
247 & ofp_actions|WARN|invalid instruction ordering: apply_actions must appear before write_metadata, for OpenFlow 1.1+ compatibility
248 # bad OF1.1 actions: OFPBAC_UNSUPPORTED_ORDER
249 ffff 0020 00002320 0016 000000000000 fedcba9876543210 ffffffffffffffff ffff 0010 00002320 0002 0000 12345678
250
251 # actions=multipath(eth_src,50,modulo_n,1,0,NXM_NX_REG0[])
252 ffff 0020 00002320 000a 0000 0032 0000 0000 0000 0000 0000 0000 001f 00010004
253
254 # actions=bundle(eth_src,0,hrw,ofport,slaves:4,8)
255 ffff 0028 00002320 000c 0001 0000 0000 00000002 0002 0000 00000000 00000000 dnl
256 0004 0008 00000000
257
258 # actions=bundle_load(eth_src,0,hrw,ofport,NXM_NX_REG0[],slaves:4,8)
259 ffff 0028 00002320 000d 0001 0000 0000 00000002 0002 001f 00010004 00000000 dnl
260 0004 0008 00000000
261
262 # actions=resubmit(10,5)
263 ffff 0010 00002320 000e 000a 05 000000
264
265 # actions=output:NXM_NX_REG1[5..10]
266 ffff 0018 00002320 000f 0145 00010204 ffff 000000000000
267
268 # 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[])
269 ffff 0048 00002320 0010 000a 0014 0050 123456789abcdef0 0000 02 00 0002 0004 dnl
270 000c 00000802 0000 00000802 0000 dnl
271 0030 00000406 0000 00000206 0000 dnl
272 1010 00000002 0000 dnl
273 00000000
274
275 # actions=exit
276 ffff 0010 00002320 0011 000000000000
277
278 dnl NXAST_DEC_TTL
279 # actions=dec_ttl
280 ffff 0010 00002320 0012 000000000000
281
282 dnl OpenFlow 1.1 OFPAT_DEC_TTL
283 # actions=dec_ttl
284 0018 0008 00000000
285
286 # actions=fin_timeout(idle_timeout=10,hard_timeout=20)
287 ffff 0010 00002320 0013 000a 0014 0000
288
289 # actions=controller(reason=invalid_ttl,max_len=1234,id=5678)
290 ffff 0010 00002320 0014 04d2 162e 02 00
291
292 # actions=dec_ttl(32768,12345,90,765,1024)
293 ffff 0020 00002320 0015 000500000000 80003039005A02fd 0400000000000000
294
295 # actions=sample(probability=12345,collector_set_id=23456,obs_domain_id=34567,obs_point_id=45678)
296 ffff 0018 00002320 001d 3039 00005BA0 00008707 0000B26E
297
298 ])
299 sed '/^[[#&]]/d' < test-data > input.txt
300 sed -n 's/^# //p; /^$/p' < test-data > expout
301 sed -n 's/^& //p' < test-data > experr
302 AT_CAPTURE_FILE([input.txt])
303 AT_CAPTURE_FILE([expout])
304 AT_CAPTURE_FILE([experr])
305 AT_CHECK(
306   [ovs-ofctl '-vPATTERN:console:%c|%p|%m' parse-ofp11-actions < input.txt],
307   [0], [expout], [experr])
308 AT_CLEANUP
309
310 AT_SETUP([OpenFlow 1.1 instruction translation])
311 AT_KEYWORDS([OF1.1 instruction ofp-actions])
312 AT_DATA([test-data], [dnl
313 # actions=LOCAL
314 0004 0018 00000000 dnl
315 0000 0010 fffffffe 04d2 000000000000
316
317 dnl Apply-Actions non-zero padding
318 # actions=drop
319 #  0: 00 -> (none)
320 #  1: 04 -> (none)
321 #  2: 00 -> (none)
322 #  3: 08 -> (none)
323 #  4: 00 -> (none)
324 #  5: 00 -> (none)
325 #  6: 00 -> (none)
326 #  7: 01 -> (none)
327 0004 0008 00000001
328
329 dnl Check that an empty Apply-Actions instruction gets dropped.
330 # actions=drop
331 #  0: 00 -> (none)
332 #  1: 04 -> (none)
333 #  2: 00 -> (none)
334 #  3: 08 -> (none)
335 #  4: 00 -> (none)
336 #  5: 00 -> (none)
337 #  6: 00 -> (none)
338 #  7: 00 -> (none)
339 0004 0008 00000000
340
341 dnl Duplicate instruction type:
342 # bad OF1.1 instructions: ONFBIC_DUP_INSTRUCTION
343 0004 0008 00000000 0004 0008 00000000
344
345 dnl Instructions not multiple of 8 in length.
346 & ofp_actions|WARN|OpenFlow message instructions length 9 is not a multiple of 8
347 # bad OF1.1 instructions: OFPBIC_BAD_LEN
348 0004 0009 01 00000000
349
350 dnl Goto-Table instruction too long.
351 # bad OF1.1 instructions: OFPBIC_BAD_LEN
352 0001 0010 01 000000 0000000000000000
353
354 dnl Goto-Table 1 instruction non-zero padding
355 # actions=goto_table:1
356 #  7: 01 -> 00
357 0001 0008 01 000001
358
359 dnl Goto-Table 1 instruction go back to the previous table.
360 # bad OF1.1 instructions: OFPBRC_BAD_TABLE_ID
361 2,0001 0008 01 000000
362
363 dnl Goto-Table 1
364 # actions=goto_table:1
365 0001 0008 01 000000
366
367 dnl Write-Metadata.
368 # actions=write_metadata:0xfedcba9876543210
369 0002 0018 00000000 fedcba9876543210 ffffffffffffffff
370
371 dnl Write-Metadata with mask.
372 # actions=write_metadata:0xfedcba9876543210/0xff00ff00ff00ff00
373 0002 0018 00000000 fedcba9876543210 ff00ff00ff00ff00
374
375 dnl Write-Metadata too short.
376 # bad OF1.1 instructions: OFPBIC_BAD_LEN
377 0002 0010 00000000 fedcba9876543210
378
379 dnl Write-Metadata too long.
380 # bad OF1.1 instructions: OFPBIC_BAD_LEN
381 0002 0020 00000000 fedcba9876543210 ffffffffffffffff 0000000000000000
382
383 dnl Write-Metadata duplicated.
384 # bad OF1.1 instructions: ONFBIC_DUP_INSTRUCTION
385 0002 0018 00000000 fedcba9876543210 ff00ff00ff00ff00 0002 0018 00000000 fedcba9876543210 ff00ff00ff00ff00
386
387 dnl Write-Metadata in wrong position (OpenFlow 1.1+ disregards the order
388 dnl and OVS reorders it to the canonical order)
389 # actions=write_metadata:0xfedcba9876543210,goto_table:1
390 #  1: 01 -> 02
391 #  3: 08 -> 18
392 #  4: 01 -> 00
393 #  8: 00 -> fe
394 #  9: 02 -> dc
395 # 10: 00 -> ba
396 # 11: 18 -> 98
397 # 12: 00 -> 76
398 # 13: 00 -> 54
399 # 14: 00 -> 32
400 # 15: 00 -> 10
401 # 16: fe -> ff
402 # 17: dc -> ff
403 # 18: ba -> ff
404 # 19: 98 -> ff
405 # 20: 76 -> ff
406 # 21: 54 -> ff
407 # 22: 32 -> ff
408 # 23: 10 -> ff
409 # 24: ff -> 00
410 # 25: ff -> 01
411 # 26: ff -> 00
412 # 27: ff -> 08
413 # 28: ff -> 01
414 # 29: ff -> 00
415 # 30: ff -> 00
416 # 31: ff -> 00
417 0001 0008 01 000000 0002 0018 00000000 fedcba9876543210 ffffffffffffffff
418
419 dnl empty Write-Actions non-zero padding
420 # actions=write_actions(drop)
421 #  0: 00 -> (none)
422 #  1: 03 -> (none)
423 #  2: 00 -> (none)
424 #  3: 08 -> (none)
425 #  4: 00 -> (none)
426 #  5: 00 -> (none)
427 #  6: 00 -> (none)
428 #  7: 01 -> (none)
429 0003 0008 00000001
430
431 dnl Check that an empty Write-Actions instruction gets dropped.
432 # actions=write_actions(drop)
433 #  0: 00 -> (none)
434 #  1: 03 -> (none)
435 #  2: 00 -> (none)
436 #  3: 08 -> (none)
437 #  4: 00 -> (none)
438 #  5: 00 -> (none)
439 #  6: 00 -> (none)
440 #  7: 00 -> (none)
441 0003 0008 00000000
442
443 dnl Clear-Actions too-long
444 # bad OF1.1 instructions: OFPBIC_BAD_LEN
445 0005 0010 00000000 0000000000000000
446
447 dnl Clear-Actions non-zero padding
448 # actions=clear_actions
449 #  7: 01 -> 00
450 0005 0008 00000001
451
452 dnl Clear-Actions non-zero padding
453 # actions=clear_actions
454 #  4: 01 -> 00
455 0005 0008 01 000000
456
457 dnl Clear-Actions
458 # actions=clear_actions
459 0005 0008 00000000
460
461 dnl Experimenter actions not supported yet.
462 # bad OF1.1 instructions: OFPBIC_BAD_EXPERIMENTER
463 ffff 0008 01 000000
464
465 dnl Bad instruction number (0 not assigned).
466 # bad OF1.1 instructions: OFPBIC_UNKNOWN_INST
467 0000 0008 01 000000
468
469 ])
470 sed '/^[[#&]]/d' < test-data > input.txt
471 sed -n 's/^# //p; /^$/p' < test-data > expout
472 sed -n 's/^& //p' < test-data > experr
473 AT_CAPTURE_FILE([input.txt])
474 AT_CAPTURE_FILE([expout])
475 AT_CAPTURE_FILE([experr])
476 AT_CHECK(
477   [ovs-ofctl '-vPATTERN:console:%c|%p|%m' parse-ofp11-instructions < input.txt],
478   [0], [expout], [experr])
479 AT_CLEANUP
480
481 AT_SETUP([ofp-actions - inconsistent MPLS actions])
482 OVS_VSWITCHD_START
483 dnl OK: Use fin_timeout action on TCP flow
484 AT_CHECK([ovs-ofctl -O OpenFlow11 -vwarn add-flow br0 'tcp actions=fin_timeout(idle_timeout=1)'])
485 dnl Bad: Use fin_timeout action on TCP flow that has been converted to MPLS
486 AT_CHECK([ovs-ofctl -O OpenFlow11 -vwarn add-flow br0 'tcp actions=push_mpls:0x8847,fin_timeout(idle_timeout=1)'],
487          [1], [], [dnl
488 ovs-ofctl: none of the usable flow formats (OpenFlow10,NXM) is among the allowed flow formats (OpenFlow11)
489 ])
490 OVS_VSWITCHD_STOP
491 AT_CLEANUP