blob: aef91d86243f539fedcc77b363e9d65a5ce6f68b [file] [log] [blame]
Rich Lanea06d0c32013-03-25 08:52:03 -07001:: # Copyright 2013, Big Switch Networks, Inc.
2:: #
3:: # LoxiGen is licensed under the Eclipse Public License, version 1.0 (EPL), with
4:: # the following special exception:
5:: #
6:: # LOXI Exception
7:: #
8:: # As a special exception to the terms of the EPL, you may distribute libraries
9:: # generated by LoxiGen (LoxiGen Libraries) under the terms of your choice, provided
10:: # that copyright and licensing notices generated by LoxiGen are not altered or removed
11:: # from the LoxiGen Libraries and the notice provided below is (i) included in
12:: # the LoxiGen Libraries, if distributed in source code form and (ii) included in any
13:: # documentation for the LoxiGen Libraries, if distributed in binary form.
14:: #
15:: # Notice: "Copyright 2013, Big Switch Networks, Inc. This library was generated by the LoxiGen Compiler."
16:: #
17:: # You may not use this file except in compliance with the EPL or LOXI Exception. You may obtain
18:: # a copy of the EPL at:
19:: #
20:: # http://www.eclipse.org/legal/epl-v10.html
21:: #
22:: # Unless required by applicable law or agreed to in writing, software
23:: # distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
24:: # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
25:: # EPL for the specific language governing permissions and limitations
26:: # under the EPL.
27::
28/* Copyright 2013, Big Switch Networks, Inc. */
29
30/**
31 * Test that list append fails gracefully when running out of wire buffer
32 * space.
33 */
34
35#include <locitest/test_common.h>
36
37static int
38test_list_limits(void)
39{
40 of_flow_stats_reply_t *obj = of_flow_stats_reply_new(OF_VERSION_1_0);
41 of_list_flow_stats_entry_t list;
42 of_flow_stats_entry_t *element = of_flow_stats_entry_new(OF_VERSION_1_0);
43 int i = 0;
44
45 of_flow_stats_reply_entries_bind(obj, &list);
46
47 ASSERT(element != NULL);
48
49
50 while (1) {
51 int rv = of_list_flow_stats_entry_append(&list, element);
52 ASSERT(rv == OF_ERROR_NONE || rv == OF_ERROR_RESOURCE);
53 if (rv != OF_ERROR_NONE) {
54 break;
55 }
56 i++;
57 }
58
59 ASSERT(i == 744);
60
61 of_flow_stats_entry_delete(element);
62 of_flow_stats_reply_delete(obj);
63 return TEST_PASS;
64}
65
66static int
67test_list_limits_bind(void)
68{
69 of_flow_stats_reply_t *obj = of_flow_stats_reply_new(OF_VERSION_1_0);
70 of_list_flow_stats_entry_t list;
71 int i = 0;
72 of_flow_stats_reply_entries_bind(obj, &list);
73
74
75 while (1) {
76 of_flow_stats_entry_t element;
77 int rv;
78 of_flow_stats_entry_init(&element, OF_VERSION_1_0, -1, 1);
79 rv = of_list_flow_stats_entry_append_bind(&list, &element);
80 ASSERT(rv == OF_ERROR_NONE || rv == OF_ERROR_RESOURCE);
81 if (rv != OF_ERROR_NONE) {
82 break;
83 }
84 i++;
85 }
86
87 ASSERT(i == 744);
88
89 of_flow_stats_reply_delete(obj);
90 return TEST_PASS;
91}
92
93int
94run_list_limits_tests(void)
95{
96 RUN_TEST(list_limits);
97 RUN_TEST(list_limits_bind);
98
99 return TEST_PASS;
100}