t_parser.c revision 1.1
1/* $Id: t_parser.c,v 1.1 2010/11/27 21:23:59 agc Exp $ */ 2 3/* Copyright (c) 2010 The NetBSD Foundation, Inc. 4 * All rights reserved. 5 * 6 * This code is derived from software contributed to The NetBSD Foundation 7 * by Mateusz Kocielski. 8 * 9 * Redistribution and use in source and binary forms, with or without 10 * modification, are permitted provided that the following conditions 11 * are met: 12 * 1. Redistributions of source code must retain the above copyright 13 * notice, this list of conditions and the following disclaimer. 14 * 2. Redistributions in binary form must reproduce the above copyright 15 * notice, this list of conditions and the following disclaimer in the 16 * documentation and/or other materials provided with the distribution. 17 * 3. All advertising materials mentioning features or use of this software 18 * must display the following acknowledgement: 19 * This product includes software developed by the NetBSD 20 * Foundation, Inc. and its contributors. 21 * 4. Neither the name of The NetBSD Foundation nor the names of its 22 * contributors may be used to endorse or promote products derived 23 * from this software without specific prior written permission. 24 * 25 * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS 26 * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 27 * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 28 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS 29 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 30 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 31 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 32 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 33 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 34 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 35 * POSSIBILITY OF SUCH DAMAGE. 36 */ 37 38#include <atf-c.h> 39#include <stdio.h> 40#include <dict.h> 41#include <saslc.h> 42#include "parser.h" 43//#include "saslc_private.h" 44 45/* src/parser.c test cases */ 46 47ATF_TC(t_parser_test1); 48ATF_TC_HEAD(t_parser_test1, tc) 49{ 50 atf_tc_set_md_var(tc, "descr", "parser test1"); 51} 52ATF_TC_BODY(t_parser_test1, tc) 53{ 54 saslc_t *ctx; 55 56 ATF_REQUIRE(ctx = saslc_alloc()); 57 ATF_CHECK_EQ(saslc_init(ctx, "test1"), 0); 58 ATF_REQUIRE_EQ(saslc_end(ctx), 0); 59} 60 61ATF_TC(t_parser_test2); 62ATF_TC_HEAD(t_parser_test2, tc) 63{ 64 atf_tc_set_md_var(tc, "descr", "parser test2"); 65} 66ATF_TC_BODY(t_parser_test2, tc) 67{ 68 saslc_t *ctx; 69 saslc_sess_t *sess; 70 const char *val; 71 72 ATF_REQUIRE(ctx = saslc_alloc()); 73 ATF_CHECK_EQ(saslc_init(ctx, "test2"), 0); 74 ATF_REQUIRE((sess = saslc_sess_init(ctx, "ANONYMOUS"))); 75 ATF_REQUIRE(val = saslc_sess_getprop(sess, "TEST")); 76 ATF_CHECK_STREQ(val, "one"); 77 ATF_REQUIRE(val = saslc_sess_getprop(sess, "TEST2")); 78 ATF_CHECK_STREQ(val, "one two"); 79 ATF_REQUIRE(val = saslc_sess_getprop(sess, "TEST3")); 80 ATF_CHECK_STREQ(val, "one two three"); 81 ATF_REQUIRE(val = saslc_sess_getprop(sess, "ID")); 82 ATF_CHECK_STREQ(val, "6669"); 83 saslc_sess_end(sess); 84 ATF_REQUIRE_EQ(saslc_end(ctx), 0); 85} 86 87ATF_TC(t_parser_test3); 88ATF_TC_HEAD(t_parser_test3, tc) 89{ 90 atf_tc_set_md_var(tc, "descr", "parser test3"); 91} 92ATF_TC_BODY(t_parser_test3, tc) 93{ 94 saslc_t *ctx; 95 int r; 96 97 ATF_REQUIRE(ctx = saslc_alloc()); 98 ATF_CHECK_EQ(saslc_init(ctx, "test3"), -1); 99 ATF_REQUIRE_EQ(saslc_end(ctx), 0); 100} 101 102 103 104 105ATF_TP_ADD_TCS(tp) 106{ 107 setenv(SASLC__ENV_PATH, "parser_tests/", 1); 108 ATF_TP_ADD_TC(tp, t_parser_test1); 109 ATF_TP_ADD_TC(tp, t_parser_test2); 110 ATF_TP_ADD_TC(tp, t_parser_test3); 111 112 return atf_no_error(); 113} 114