1 /* $NetBSD: test-ldap.c,v 1.1.1.2 2014/04/24 12:45:56 pettai Exp $ */ 2 3 /* 4 * Copyright (c) 2008 Kungliga Tekniska Högskolan 5 * (Royal Institute of Technology, Stockholm, Sweden). 6 * All rights reserved. 7 * 8 * Redistribution and use in source and binary forms, with or without 9 * modification, are permitted provided that the following conditions 10 * are met: 11 * 12 * 1. Redistributions of source code must retain the above copyright 13 * notice, this list of conditions and the following disclaimer. 14 * 15 * 2. Redistributions in binary form must reproduce the above copyright 16 * notice, this list of conditions and the following disclaimer in the 17 * documentation and/or other materials provided with the distribution. 18 * 19 * 3. Neither the name of the Institute nor the names of its contributors 20 * may be used to endorse or promote products derived from this software 21 * without specific prior written permission. 22 * 23 * THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND 24 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 25 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 26 * ARE DISCLAIMED. IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE 27 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 28 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 29 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 30 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 31 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 32 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 33 * SUCH DAMAGE. 34 */ 35 36 #ifdef HAVE_CONFIG_H 37 #include <config.h> 38 #endif 39 #include <stdio.h> 40 #include <string.h> 41 #include <err.h> 42 #include <assert.h> 43 #include "windlocl.h" 44 45 #define MAX_LENGTH 10 46 47 struct testcase { 48 uint32_t in[MAX_LENGTH]; 49 size_t ilen; 50 uint32_t out[MAX_LENGTH]; 51 size_t olen; 52 }; 53 54 static const struct testcase testcases[] = { 55 { { 0x20 }, 1, { 0 }, 0 }, 56 { { 0x20, 0x61 }, 2, { 0x20, 0x61, 0x20}, 3 }, 57 { { 0x20, 0x61, 0x20 }, 3, { 0x20, 0x61, 0x20}, 3 }, 58 { { 0x20, 0x61, 0x20, 0x61 }, 4, { 0x20, 0x61, 0x20, 0x20, 0x61, 0x20}, 6 } 59 }; 60 61 static const struct testcase testcases2[] = { 62 { { 0x20 }, 1, { 0x20 }, 1 }, 63 { { 0x20, 0x41 }, 2, { 0x20, 0x61}, 2 } 64 }; 65 66 67 int 68 main(void) 69 { 70 uint32_t out[MAX_LENGTH]; 71 unsigned failures = 0; 72 unsigned i; 73 size_t olen; 74 int ret; 75 76 77 for (i = 0; i < sizeof(testcases)/sizeof(testcases[0]); ++i) { 78 const struct testcase *t = &testcases[i]; 79 80 olen = sizeof(out)/sizeof(out[0]); 81 assert(olen > t->olen); 82 83 ret = _wind_ldap_case_exact_attribute(t->in, t->ilen, out, &olen); 84 if (ret) { 85 printf("wlcea: %u: %d\n", i, ret); 86 ++failures; 87 continue; 88 } 89 if (olen != t->olen) { 90 printf("len wlcea: %u %u != %u\n", i, 91 (unsigned)olen, (unsigned)t->olen); 92 failures++; 93 continue; 94 } 95 if (memcmp(t->out, out, sizeof(out[0]) * olen) != 0) { 96 printf("memcmp wlcea: %u\n", i); 97 failures++; 98 continue; 99 } 100 } 101 102 for (i = 0; i < sizeof(testcases2)/sizeof(testcases2[0]); ++i) { 103 const struct testcase *t = &testcases2[i]; 104 105 olen = sizeof(out)/sizeof(out[0]); 106 assert(olen > t->olen); 107 108 ret = wind_stringprep(t->in, t->ilen, out, &olen, 109 WIND_PROFILE_LDAP_CASE); 110 111 if (ret) { 112 printf("wsplc: %u: %d\n", i, ret); 113 ++failures; 114 continue; 115 } 116 117 if (olen != t->olen) { 118 printf("strlen wsplc: %u: %d\n", i, ret); 119 ++failures; 120 continue; 121 } 122 if (memcmp(t->out, out, sizeof(out[0]) * olen) != 0) { 123 printf("memcmp wsplc: %u\n", i); 124 failures++; 125 continue; 126 } 127 } 128 129 return failures != 0; 130 } 131