]> git.proxmox.com Git - mirror_ovs.git/blame - tests/classifier.at
ofp-actions: Support "copy_field" ONF extension to OpenFlow 1.3.
[mirror_ovs.git] / tests / classifier.at
CommitLineData
3223e977
BP
1AT_BANNER([flow classifier unit tests])
2m4_foreach(
3 [testname],
4 [[empty],
5 [destroy-null],
6 [single-rule],
7 [rule-replacement],
b5d97350 8 [many-rules-in-one-list],
3223e977 9 [many-rules-in-one-table],
b5d97350
BP
10 [many-rules-in-two-tables],
11 [many-rules-in-five-tables]],
3223e977 12 [AT_SETUP([flow classifier - m4_bpatsubst(testname, [-], [ ])])
eadd1644 13 AT_CHECK([ovstest test-classifier testname], [0], [], [])
3223e977 14 AT_CLEANUP])])
5cb7a798
BP
15
16AT_BANNER([miniflow unit tests])
17m4_foreach(
18 [testname],
19 [[miniflow],
20 [minimask_has_extra],
21 [minimask_combine]],
22 [AT_SETUP([miniflow - m4_bpatsubst(testname, [-], [ ])])
eadd1644 23 AT_CHECK([ovstest test-classifier testname], [0], [], [])
5cb7a798 24 AT_CLEANUP])])
476f36e8
JR
25
26AT_BANNER([flow classifier lookup segmentation])
27AT_SETUP([flow classifier - lookup segmentation])
28OVS_VSWITCHD_START
29ADD_OF_PORTS([br0], [1], [2], [3])
30AT_DATA([flows.txt], [dnl
31table=0 in_port=1 priority=16,tcp,nw_dst=10.1.0.0/255.255.0.0,action=output(3)
32table=0 in_port=1 priority=32,tcp,nw_dst=10.1.2.15,action=output(2)
33table=0 in_port=1 priority=33,tcp,nw_dst=10.1.2.15,tp_dst=80,action=drop
34table=0 in_port=1 priority=0,ip,action=drop
35table=0 in_port=2 priority=16,tcp,nw_dst=192.168.0.0/255.255.0.0,action=output(1)
36table=0 in_port=2 priority=0,ip,action=drop
37table=0 in_port=3 priority=16,tcp,nw_src=10.1.0.0/255.255.0.0,action=output(1)
38table=0 in_port=3 priority=0,ip,action=drop
39])
40AT_CHECK([ovs-ofctl add-flows br0 flows.txt])
41AT_CHECK([ovs-appctl ofproto/trace br0 'in_port=2,dl_src=50:54:00:00:00:05,dl_dst=50:54:00:00:00:07,dl_type=0x0800,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_proto=6,nw_tos=0,nw_ttl=128,tp_src=8,tp_dst=80'], [0], [stdout])
42AT_CHECK([tail -2 stdout], [0],
16194afd 43 [Megaflow: recirc_id=0,tcp,in_port=2,nw_dst=192.168.0.0/16,nw_frag=no
476f36e8
JR
44Datapath actions: 1
45])
46AT_CHECK([ovs-appctl ofproto/trace br0 'in_port=1,dl_src=50:54:00:00:00:05,dl_dst=50:54:00:00:00:07,dl_type=0x0800,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_proto=6,nw_tos=0,nw_ttl=128,tp_src=8,tp_dst=80'], [0], [stdout])
47AT_CHECK([tail -2 stdout], [0],
16194afd 48 [Megaflow: recirc_id=0,ip,in_port=1,nw_dst=0.0.0.0/2.0.0.0,nw_frag=no
476f36e8
JR
49Datapath actions: drop
50])
51AT_CHECK([ovs-appctl ofproto/trace br0 'in_port=1,dl_src=50:54:00:00:00:05,dl_dst=50:54:00:00:00:07,dl_type=0x0800,nw_src=192.168.0.1,nw_dst=10.1.2.15,nw_proto=6,nw_tos=0,nw_ttl=128,tp_src=8,tp_dst=80'], [0], [stdout])
52AT_CHECK([tail -2 stdout], [0],
16194afd 53 [Megaflow: recirc_id=0,tcp,in_port=1,nw_dst=10.1.2.15,nw_frag=no,tp_dst=80
476f36e8
JR
54Datapath actions: drop
55])
56AT_CHECK([ovs-appctl ofproto/trace br0 'in_port=1,dl_src=50:54:00:00:00:05,dl_dst=50:54:00:00:00:07,dl_type=0x0800,nw_src=192.168.0.1,nw_dst=10.1.2.15,nw_proto=6,nw_tos=0,nw_ttl=128,tp_src=8,tp_dst=79'], [0], [stdout])
57AT_CHECK([tail -2 stdout], [0],
16194afd 58 [Megaflow: recirc_id=0,tcp,in_port=1,nw_dst=10.1.2.15,nw_frag=no,tp_dst=0x1/0x1
476f36e8
JR
59Datapath actions: 2
60])
61OVS_VSWITCHD_STOP
62AT_CLEANUP
13751fd8
JR
63
64AT_BANNER([flow classifier prefix lookup])
65AT_SETUP([flow classifier - prefix lookup])
66OVS_VSWITCHD_START
67ADD_OF_PORTS([br0], [1], [2], [3])
68AT_CHECK([ovs-vsctl set Bridge br0 flow_tables:0=@N1 -- --id=@N1 create Flow_Table name=t0], [0], [ignore], [])
13751fd8
JR
69AT_DATA([flows.txt], [dnl
70table=0 in_port=1 priority=16,tcp,nw_dst=10.1.0.0/255.255.0.0,action=output(3)
71table=0 in_port=1 priority=32,tcp,nw_dst=10.1.2.0/255.255.255.0,tp_src=79,action=output(2)
72table=0 in_port=1 priority=33,tcp,nw_dst=10.1.2.15,tp_dst=80,action=drop
69d6040e
JR
73table=0 in_port=1 priority=33,tcp,nw_dst=10.1.2.15,tp_dst=8080,action=output(2)
74table=0 in_port=1 priority=33,tcp,nw_dst=10.1.2.15,tp_dst=192,action=output(2)
13751fd8
JR
75table=0 in_port=1 priority=0,ip,action=drop
76table=0 in_port=2 priority=16,tcp,nw_dst=192.168.0.0/255.255.0.0,action=output(1)
77table=0 in_port=2 priority=0,ip,action=drop
78table=0 in_port=3 priority=16,tcp,nw_src=10.1.0.0/255.255.0.0,action=output(1)
79table=0 in_port=3 priority=0,ip,action=drop
80])
81AT_CHECK([ovs-ofctl add-flows br0 flows.txt])
f017d986
JR
82
83# nw_dst and nw_src should be on by default
84AT_CHECK([ovs-appctl ofproto/trace br0 'in_port=1,dl_src=50:54:00:00:00:05,dl_dst=50:54:00:00:00:07,dl_type=0x0800,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_proto=6,nw_tos=0,nw_ttl=128,tp_src=8,tp_dst=80'], [0], [stdout])
85AT_CHECK([tail -2 stdout], [0],
16194afd 86 [Megaflow: recirc_id=0,ip,in_port=1,nw_dst=192.168.0.0/16,nw_frag=no
f017d986
JR
87Datapath actions: drop
88])
89
90AT_CHECK([ovs-vsctl set Flow_Table t0 prefixes=ipv6_label], [0])
91AT_CHECK([ovs-vsctl set Flow_Table t0 prefixes=nw_dst,nw_src,tun_dst,tun_src], [1], [],
92[ovs-vsctl: nw_dst,nw_src,tun_dst,tun_src: 4 value(s) specified but the maximum number is 3
93])
94AT_CHECK([ovs-vsctl set Flow_Table t0 prefixes=nw_dst,nw_dst], [1], [],
95[ovs-vsctl: nw_dst,nw_dst: set contains duplicate value
96])
97
98AT_CHECK([ovs-vsctl set Flow_Table t0 prefixes=nw_dst], [0])
13751fd8
JR
99AT_CHECK([ovs-appctl ofproto/trace br0 'in_port=1,dl_src=50:54:00:00:00:05,dl_dst=50:54:00:00:00:07,dl_type=0x0800,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_proto=6,nw_tos=0,nw_ttl=128,tp_src=8,tp_dst=80'], [0], [stdout])
100AT_CHECK([tail -2 stdout], [0],
16194afd 101 [Megaflow: recirc_id=0,ip,in_port=1,nw_dst=192.168.0.0/16,nw_frag=no
13751fd8
JR
102Datapath actions: drop
103])
104AT_CHECK([ovs-appctl ofproto/trace br0 'in_port=2,dl_src=50:54:00:00:00:05,dl_dst=50:54:00:00:00:07,dl_type=0x0800,nw_src=192.168.0.1,nw_dst=192.168.0.2,nw_proto=6,nw_tos=0,nw_ttl=128,tp_src=8,tp_dst=80'], [0], [stdout])
105AT_CHECK([tail -2 stdout], [0],
16194afd 106 [Megaflow: recirc_id=0,tcp,in_port=2,nw_dst=192.168.0.0/16,nw_frag=no
13751fd8
JR
107Datapath actions: 1
108])
109AT_CHECK([ovs-appctl ofproto/trace br0 'in_port=1,dl_src=50:54:00:00:00:05,dl_dst=50:54:00:00:00:07,dl_type=0x0800,nw_src=192.168.0.1,nw_dst=10.1.2.15,nw_proto=6,nw_tos=0,nw_ttl=128,tp_src=8,tp_dst=80'], [0], [stdout])
110AT_CHECK([tail -2 stdout], [0],
16194afd 111 [Megaflow: recirc_id=0,tcp,in_port=1,nw_dst=10.1.2.15,nw_frag=no,tp_dst=80
13751fd8
JR
112Datapath actions: drop
113])
114AT_CHECK([ovs-appctl ofproto/trace br0 'in_port=1,dl_src=50:54:00:00:00:05,dl_dst=50:54:00:00:00:07,dl_type=0x0800,nw_src=192.168.0.1,nw_dst=10.1.2.15,nw_proto=6,nw_tos=0,nw_ttl=128,tp_src=8,tp_dst=79'], [0], [stdout])
115AT_CHECK([tail -2 stdout], [0],
16194afd 116 [Megaflow: recirc_id=0,tcp,in_port=1,nw_dst=10.1.2.15,nw_frag=no,tp_src=0x0/0x1,tp_dst=0x40/0xfff0
13751fd8
JR
117Datapath actions: 3
118])
f017d986
JR
119AT_CHECK([ovs-vsctl set Flow_Table t0 prefixes=none], [0])
120AT_CHECK([ovs-appctl ofproto/trace br0 'in_port=1,dl_src=50:54:00:00:00:05,dl_dst=50:54:00:00:00:07,dl_type=0x0800,nw_src=192.168.0.1,nw_dst=10.1.3.16,nw_proto=6,nw_tos=0,nw_ttl=128,tp_src=8,tp_dst=79'], [0], [stdout])
121AT_CHECK([tail -2 stdout], [0],
16194afd 122 [Megaflow: recirc_id=0,tcp,in_port=1,nw_dst=10.1.3.16,nw_frag=no
f017d986
JR
123Datapath actions: 3
124])
13751fd8
JR
125OVS_VSWITCHD_STOP(["/'prefixes' with incompatible field: ipv6_label/d"])
126AT_CLEANUP