X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=tests%2Ftest-stp.c;h=9ca9c6c677be3a64ac8ee7cf171807f14e630b7e;hb=003ce655b7116d18c86a74c50391e54990346931;hp=073368154d6fa86969f23ebb59891cab5b489090;hpb=064af42167bf4fc9aaea2702d80ce08074b889c0;p=sliver-openvswitch.git diff --git a/tests/test-stp.c b/tests/test-stp.c index 073368154..9ca9c6c67 100644 --- a/tests/test-stp.c +++ b/tests/test-stp.c @@ -1,19 +1,21 @@ /* - * Copyright (c) 2008, 2009 Nicira Networks. + * Copyright (c) 2008, 2009, 2010, 2012, 2013, 2014 Nicira, Inc. * - * Permission to use, copy, modify, and/or distribute this software for any - * purpose with or without fee is hereby granted, provided that the above - * copyright notice and this permission notice appear in all copies. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at: * - * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES - * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF - * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR - * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES - * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN - * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF - * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. */ +#include + #include "stp.h" #include #include @@ -23,6 +25,8 @@ #include #include "ofpbuf.h" #include "packets.h" +#include "vlog.h" +#include "ovstest.h" struct bpdu { int port_no; @@ -89,7 +93,7 @@ send_bpdu(struct ofpbuf *pkt, int port_no, void *b_) assert(port_no < b->n_ports); lan = b->ports[port_no]; if (lan) { - const void *data = pkt->l3; + const void *data = ofpbuf_l3(pkt); size_t size = (char *) ofpbuf_tail(pkt) - (char *) data; int i; @@ -241,7 +245,7 @@ dump_bridge_tree(struct test_case *tc, struct bridge *b, int level) } static void -dump_lan_tree(struct test_case *tc, struct lan *lan, int level) +dump_lan_tree(struct test_case *tc, struct lan *lan, int level) { int i; @@ -301,6 +305,7 @@ simulate(struct test_case *tc, int granularity) struct bpdu *bpdu = &b->rxq[b->rxq_tail % RXQ_SIZE]; stp_received_bpdu(stp_get_port(b->stp, bpdu->port_no), bpdu->data, bpdu->size); + free(bpdu->data); any = true; } } @@ -321,7 +326,7 @@ err(const char *message, ...) { va_list args; - fprintf(stderr, "%s:%d:%td: ", file_name, line_number, pos - line); + fprintf(stderr, "%s:%d:%"PRIdPTR": ", file_name, line_number, pos - line); va_start(args, message); vfprintf(stderr, message, args); va_end(args); @@ -357,6 +362,7 @@ get_token(void) pos++; } if (*pos == '\0') { + free(token); token = NULL; return false; } @@ -429,13 +435,16 @@ must_match(const char *want) } } -int -main(int argc, char *argv[]) +static void +test_stp_main(int argc, char *argv[]) { struct test_case *tc; FILE *input_file; int i; + vlog_set_pattern(VLF_CONSOLE, "%c|%p|%m"); + vlog_set_levels(NULL, VLF_SYSLOG, VLL_OFF); + if (argc != 2) { ovs_fatal(0, "usage: test-stp INPUT.STP\n"); } @@ -501,8 +510,9 @@ main(int argc, char *argv[]) if (!strcmp(token, "0")) { lan = NULL; - } else if (strlen(token) == 1 && islower(*token)) { - lan = tc->lans[*token - 'a']; + } else if (strlen(token) == 1 + && islower((unsigned char)*token)) { + lan = tc->lans[*token - 'a']; } else { err("%s is not a valid LAN name " "(0 or a lowercase letter)", token); @@ -643,6 +653,19 @@ main(int argc, char *argv[]) err("trailing garbage on line"); } } + free(token); - return 0; + for (i = 0; i < tc->n_lans; i++) { + struct lan *lan = tc->lans[i]; + free(CONST_CAST(char *, lan->name)); + free(lan); + } + for (i = 0; i < tc->n_bridges; i++) { + struct bridge *bridge = tc->bridges[i]; + stp_unref(bridge->stp); + free(bridge); + } + free(tc); } + +OVSTEST_REGISTER("test-stp", test_stp_main);