ofp-print: Make port "config" and "state" output easier to read.
[sliver-openvswitch.git] / tests / ofproto.at
1 AT_BANNER([ofproto])
2
3 AT_SETUP([ofproto - echo request])
4 OFPROTO_START
5 AT_CHECK([ovs-ofctl -vANY:ANY:WARN probe br0])
6 OFPROTO_STOP
7 AT_CLEANUP
8
9 AT_SETUP([ofproto - feature request, config request])
10 OFPROTO_START
11 AT_CHECK([ovs-ofctl -vANY:ANY:WARN show br0], [0], [stdout])
12 AT_CHECK([STRIP_XIDS stdout], [0], [dnl
13 OFPT_FEATURES_REPLY: ver:0x1, dpid:fedcba9876543210
14 n_tables:1, n_buffers:256
15 features: capabilities:0x87, actions:0xfff
16  LOCAL(br0): addr:aa:55:aa:55:00:00
17      config:     PORT_DOWN
18      state:      LINK_DOWN
19 OFPT_GET_CONFIG_REPLY: frags=normal miss_send_len=0
20 ])
21 OFPROTO_STOP
22 AT_CLEANUP
23
24 AT_SETUP([ofproto - mod-port])
25 OFPROTO_START
26 for command_config_state in \
27     'up 0 0' \
28     'noflood NO_FLOOD 0' \
29     'down PORT_DOWN,NO_FLOOD LINK_DOWN' \
30     'flood PORT_DOWN LINK_DOWN'
31 do
32     set $command_config_state
33     command=$[1] config=`echo $[2] | sed 's/,/ /g'` state=$[3]
34     AT_CHECK([ovs-ofctl -vANY:ANY:WARN mod-port br0 br0 $command])
35     AT_CHECK([ovs-ofctl -vANY:ANY:WARN show br0], [0], [stdout])
36     AT_CHECK_UNQUOTED([STRIP_XIDS stdout], [0], [dnl
37 OFPT_FEATURES_REPLY: ver:0x1, dpid:fedcba9876543210
38 n_tables:1, n_buffers:256
39 features: capabilities:0x87, actions:0xfff
40  LOCAL(br0): addr:aa:55:aa:55:00:00
41      config:     $config
42      state:      $state
43 OFPT_GET_CONFIG_REPLY: frags=normal miss_send_len=0
44 ])
45 done
46 OFPROTO_STOP
47 AT_CLEANUP
48
49 AT_SETUP([ofproto - basic flow_mod commands (NXM)])
50 OFPROTO_START
51 AT_CHECK([ovs-ofctl dump-flows br0 | STRIP_XIDS], [0], [NXST_FLOW reply:
52 ])
53 AT_CHECK([echo 'in_port=1,actions=0' | ovs-ofctl add-flows br0 -])
54 AT_CHECK([ovs-ofctl add-flow br0 in_port=0,actions=1])
55 # Check that a table_id is really sent:
56 AT_CHECK([ovs-ofctl -F nxm add-flow br0 table=1,in_port=0,actions=1 2>&1 | STRIP_XIDS | sed 1q], [0], [dnl
57 OFPT_ERROR: type OFPET_FLOW_MOD_FAILED, code NXFMFC_BAD_TABLE_ID
58 ])
59 AT_CHECK([ovs-ofctl dump-flows br0 | STRIP_XIDS | STRIP_DURATION | sort], [0], [dnl
60  cookie=0x0, duration=?s, table=0, n_packets=0, n_bytes=0, in_port=0 actions=output:1
61  cookie=0x0, duration=?s, table=0, n_packets=0, n_bytes=0, in_port=1 actions=output:0
62 NXST_FLOW reply:
63 ])
64 AT_CHECK([ovs-ofctl dump-aggregate br0 | STRIP_XIDS], [0], [dnl
65 NXST_AGGREGATE reply: packet_count=0 byte_count=0 flow_count=2
66 ])
67 AT_CHECK([ovs-ofctl del-flows br0])
68 AT_CHECK([ovs-ofctl dump-flows br0 | STRIP_XIDS], [0], [NXST_FLOW reply:
69 ])
70 OFPROTO_STOP
71 AT_CLEANUP
72
73 AT_SETUP([ofproto - basic flow_mod commands (OpenFlow 1.0)])
74 OFPROTO_START
75 AT_CHECK([ovs-ofctl -F openflow10 dump-flows br0 | STRIP_XIDS], [0], [OFPST_FLOW reply:
76 ])
77 AT_CHECK([echo 'in_port=1,actions=0' | ovs-ofctl -F openflow10 add-flows br0 -])
78 AT_CHECK([ovs-ofctl -F openflow10 add-flow br0 in_port=0,actions=1])
79 # Check that a table_id is really sent:
80 AT_CHECK([ovs-ofctl -F openflow10 add-flow br0 table=1,in_port=0,actions=1 2>&1 | STRIP_XIDS | sed 1q], [0], [dnl
81 OFPT_ERROR: type OFPET_FLOW_MOD_FAILED, code NXFMFC_BAD_TABLE_ID
82 ])
83 AT_CHECK([ovs-ofctl -F openflow10 dump-flows br0 | STRIP_XIDS | STRIP_DURATION | sort], [0], [dnl
84  cookie=0x0, duration=?s, table=0, n_packets=0, n_bytes=0, in_port=0 actions=output:1
85  cookie=0x0, duration=?s, table=0, n_packets=0, n_bytes=0, in_port=1 actions=output:0
86 OFPST_FLOW reply:
87 ])
88 AT_CHECK([ovs-ofctl -F openflow10 dump-aggregate br0 | STRIP_XIDS], [0], [dnl
89 OFPST_AGGREGATE reply: packet_count=0 byte_count=0 flow_count=2
90 ])
91 AT_CHECK([ovs-ofctl -F openflow10 del-flows br0])
92 AT_CHECK([ovs-ofctl -F openflow10 dump-flows br0 | STRIP_XIDS], [0], [OFPST_FLOW reply:
93 ])
94 OFPROTO_STOP
95 AT_CLEANUP