18373020dSJacques Vidrine /* 28373020dSJacques Vidrine * Copyright (c) 2002 Kungliga Tekniska H�gskolan 38373020dSJacques Vidrine * (Royal Institute of Technology, Stockholm, Sweden). 48373020dSJacques Vidrine * All rights reserved. 58373020dSJacques Vidrine * 68373020dSJacques Vidrine * Redistribution and use in source and binary forms, with or without 78373020dSJacques Vidrine * modification, are permitted provided that the following conditions 88373020dSJacques Vidrine * are met: 98373020dSJacques Vidrine * 108373020dSJacques Vidrine * 1. Redistributions of source code must retain the above copyright 118373020dSJacques Vidrine * notice, this list of conditions and the following disclaimer. 128373020dSJacques Vidrine * 138373020dSJacques Vidrine * 2. Redistributions in binary form must reproduce the above copyright 148373020dSJacques Vidrine * notice, this list of conditions and the following disclaimer in the 158373020dSJacques Vidrine * documentation and/or other materials provided with the distribution. 168373020dSJacques Vidrine * 178373020dSJacques Vidrine * 3. Neither the name of KTH nor the names of its contributors may be 188373020dSJacques Vidrine * used to endorse or promote products derived from this software without 198373020dSJacques Vidrine * specific prior written permission. 208373020dSJacques Vidrine * 218373020dSJacques Vidrine * THIS SOFTWARE IS PROVIDED BY KTH AND ITS CONTRIBUTORS ``AS IS'' AND ANY 228373020dSJacques Vidrine * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 238373020dSJacques Vidrine * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 248373020dSJacques Vidrine * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL KTH OR ITS CONTRIBUTORS BE 258373020dSJacques Vidrine * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 268373020dSJacques Vidrine * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 278373020dSJacques Vidrine * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR 288373020dSJacques Vidrine * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, 298373020dSJacques Vidrine * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR 308373020dSJacques Vidrine * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF 318373020dSJacques Vidrine * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ 328373020dSJacques Vidrine 338373020dSJacques Vidrine #include "krb5_locl.h" 34c19800e8SDoug Rabson #include <err.h> 358373020dSJacques Vidrine 36c19800e8SDoug Rabson RCSID("$Id: parse-name-test.c 16342 2005-12-02 14:14:43Z lha $"); 378373020dSJacques Vidrine 388373020dSJacques Vidrine enum { MAX_COMPONENTS = 3 }; 398373020dSJacques Vidrine 408373020dSJacques Vidrine static struct testcase { 418373020dSJacques Vidrine const char *input_string; 428373020dSJacques Vidrine const char *output_string; 438373020dSJacques Vidrine krb5_realm realm; 448373020dSJacques Vidrine unsigned ncomponents; 458373020dSJacques Vidrine char *comp_val[MAX_COMPONENTS]; 468373020dSJacques Vidrine int realmp; 478373020dSJacques Vidrine } tests[] = { 488373020dSJacques Vidrine {"", "@", "", 1, {""}, FALSE}, 498373020dSJacques Vidrine {"a", "a@", "", 1, {"a"}, FALSE}, 508373020dSJacques Vidrine {"\\n", "\\n@", "", 1, {"\n"}, FALSE}, 518373020dSJacques Vidrine {"\\ ", "\\ @", "", 1, {" "}, FALSE}, 528373020dSJacques Vidrine {"\\t", "\\t@", "", 1, {"\t"}, FALSE}, 538373020dSJacques Vidrine {"\\b", "\\b@", "", 1, {"\b"}, FALSE}, 548373020dSJacques Vidrine {"\\\\", "\\\\@", "", 1, {"\\"}, FALSE}, 558373020dSJacques Vidrine {"\\/", "\\/@", "", 1, {"/"}, FALSE}, 568373020dSJacques Vidrine {"\\@", "\\@@", "", 1, {"@"}, FALSE}, 578373020dSJacques Vidrine {"@", "@", "", 1, {""}, TRUE}, 588373020dSJacques Vidrine {"a/b", "a/b@", "", 2, {"a", "b"}, FALSE}, 598373020dSJacques Vidrine {"a/", "a/@", "", 2, {"a", ""}, FALSE}, 608373020dSJacques Vidrine {"a\\//\\/", "a\\//\\/@", "", 2, {"a/", "/"}, FALSE}, 618373020dSJacques Vidrine {"/a", "/a@", "", 2, {"", "a"}, FALSE}, 628373020dSJacques Vidrine {"\\@@\\@", "\\@@\\@", "@", 1, {"@"}, TRUE}, 638373020dSJacques Vidrine {"a/b/c", "a/b/c@", "", 3, {"a", "b", "c"}, FALSE}, 641c43270aSJacques Vidrine {NULL, NULL, "", 0, { NULL }, FALSE}}; 658373020dSJacques Vidrine 66c19800e8SDoug Rabson int KRB5_LIB_FUNCTION 678373020dSJacques Vidrine main(int argc, char **argv) 688373020dSJacques Vidrine { 698373020dSJacques Vidrine struct testcase *t; 708373020dSJacques Vidrine krb5_context context; 718373020dSJacques Vidrine krb5_error_code ret; 728373020dSJacques Vidrine int val = 0; 738373020dSJacques Vidrine 748373020dSJacques Vidrine ret = krb5_init_context (&context); 758373020dSJacques Vidrine if (ret) 768373020dSJacques Vidrine errx (1, "krb5_init_context failed: %d", ret); 778373020dSJacques Vidrine 788373020dSJacques Vidrine /* to enable realm-less principal name above */ 798373020dSJacques Vidrine 808373020dSJacques Vidrine krb5_set_default_realm(context, ""); 818373020dSJacques Vidrine 828373020dSJacques Vidrine for (t = tests; t->input_string; ++t) { 838373020dSJacques Vidrine krb5_principal princ; 848373020dSJacques Vidrine int i, j; 858373020dSJacques Vidrine char name_buf[1024]; 868373020dSJacques Vidrine char *s; 878373020dSJacques Vidrine 888373020dSJacques Vidrine ret = krb5_parse_name(context, t->input_string, &princ); 898373020dSJacques Vidrine if (ret) 908373020dSJacques Vidrine krb5_err (context, 1, ret, "krb5_parse_name %s", 918373020dSJacques Vidrine t->input_string); 928373020dSJacques Vidrine if (strcmp (t->realm, princ->realm) != 0) { 938373020dSJacques Vidrine printf ("wrong realm (\"%s\" should be \"%s\")" 948373020dSJacques Vidrine " for \"%s\"\n", 958373020dSJacques Vidrine princ->realm, t->realm, 968373020dSJacques Vidrine t->input_string); 978373020dSJacques Vidrine val = 1; 988373020dSJacques Vidrine } 998373020dSJacques Vidrine 1008373020dSJacques Vidrine if (t->ncomponents != princ->name.name_string.len) { 1018373020dSJacques Vidrine printf ("wrong number of components (%u should be %u)" 1028373020dSJacques Vidrine " for \"%s\"\n", 1038373020dSJacques Vidrine princ->name.name_string.len, t->ncomponents, 1048373020dSJacques Vidrine t->input_string); 1058373020dSJacques Vidrine val = 1; 1068373020dSJacques Vidrine } else { 1078373020dSJacques Vidrine for (i = 0; i < t->ncomponents; ++i) { 1088373020dSJacques Vidrine if (strcmp(t->comp_val[i], 1098373020dSJacques Vidrine princ->name.name_string.val[i]) != 0) { 1108373020dSJacques Vidrine printf ("bad component %d (\"%s\" should be \"%s\")" 1118373020dSJacques Vidrine " for \"%s\"\n", 1128373020dSJacques Vidrine i, 1138373020dSJacques Vidrine princ->name.name_string.val[i], 1148373020dSJacques Vidrine t->comp_val[i], 1158373020dSJacques Vidrine t->input_string); 1168373020dSJacques Vidrine val = 1; 1178373020dSJacques Vidrine } 1188373020dSJacques Vidrine } 1198373020dSJacques Vidrine } 1208373020dSJacques Vidrine for (j = 0; j < strlen(t->output_string); ++j) { 1218373020dSJacques Vidrine ret = krb5_unparse_name_fixed(context, princ, 1228373020dSJacques Vidrine name_buf, j); 1238373020dSJacques Vidrine if (ret != ERANGE) { 1248373020dSJacques Vidrine printf ("unparse_name %s with length %d should have failed\n", 1258373020dSJacques Vidrine t->input_string, j); 1268373020dSJacques Vidrine val = 1; 1278373020dSJacques Vidrine break; 1288373020dSJacques Vidrine } 1298373020dSJacques Vidrine } 1308373020dSJacques Vidrine ret = krb5_unparse_name_fixed(context, princ, 1318373020dSJacques Vidrine name_buf, sizeof(name_buf)); 1328373020dSJacques Vidrine if (ret) 1338373020dSJacques Vidrine krb5_err (context, 1, ret, "krb5_unparse_name_fixed"); 1348373020dSJacques Vidrine 1358373020dSJacques Vidrine if (strcmp (t->output_string, name_buf) != 0) { 1368373020dSJacques Vidrine printf ("failed comparing the re-parsed" 1378373020dSJacques Vidrine " (\"%s\" should be \"%s\")\n", 1388373020dSJacques Vidrine name_buf, t->output_string); 1398373020dSJacques Vidrine val = 1; 1408373020dSJacques Vidrine } 1418373020dSJacques Vidrine 1428373020dSJacques Vidrine ret = krb5_unparse_name(context, princ, &s); 1438373020dSJacques Vidrine if (ret) 1448373020dSJacques Vidrine krb5_err (context, 1, ret, "krb5_unparse_name"); 1458373020dSJacques Vidrine 1468373020dSJacques Vidrine if (strcmp (t->output_string, s) != 0) { 1478373020dSJacques Vidrine printf ("failed comparing the re-parsed" 1488373020dSJacques Vidrine " (\"%s\" should be \"%s\"\n", 1498373020dSJacques Vidrine s, t->output_string); 1508373020dSJacques Vidrine val = 1; 1518373020dSJacques Vidrine } 1528373020dSJacques Vidrine free(s); 1538373020dSJacques Vidrine 1548373020dSJacques Vidrine if (!t->realmp) { 1558373020dSJacques Vidrine for (j = 0; j < strlen(t->input_string); ++j) { 1568373020dSJacques Vidrine ret = krb5_unparse_name_fixed_short(context, princ, 1578373020dSJacques Vidrine name_buf, j); 1588373020dSJacques Vidrine if (ret != ERANGE) { 1598373020dSJacques Vidrine printf ("unparse_name_short %s with length %d" 1608373020dSJacques Vidrine " should have failed\n", 1618373020dSJacques Vidrine t->input_string, j); 1628373020dSJacques Vidrine val = 1; 1638373020dSJacques Vidrine break; 1648373020dSJacques Vidrine } 1658373020dSJacques Vidrine } 1668373020dSJacques Vidrine ret = krb5_unparse_name_fixed_short(context, princ, 1678373020dSJacques Vidrine name_buf, sizeof(name_buf)); 1688373020dSJacques Vidrine if (ret) 1698373020dSJacques Vidrine krb5_err (context, 1, ret, "krb5_unparse_name_fixed"); 1708373020dSJacques Vidrine 1718373020dSJacques Vidrine if (strcmp (t->input_string, name_buf) != 0) { 1728373020dSJacques Vidrine printf ("failed comparing the re-parsed" 1738373020dSJacques Vidrine " (\"%s\" should be \"%s\")\n", 1748373020dSJacques Vidrine name_buf, t->input_string); 1758373020dSJacques Vidrine val = 1; 1768373020dSJacques Vidrine } 1778373020dSJacques Vidrine 1788373020dSJacques Vidrine ret = krb5_unparse_name_short(context, princ, &s); 1798373020dSJacques Vidrine if (ret) 1808373020dSJacques Vidrine krb5_err (context, 1, ret, "krb5_unparse_name_short"); 1818373020dSJacques Vidrine 1828373020dSJacques Vidrine if (strcmp (t->input_string, s) != 0) { 1838373020dSJacques Vidrine printf ("failed comparing the re-parsed" 1848373020dSJacques Vidrine " (\"%s\" should be \"%s\"\n", 1858373020dSJacques Vidrine s, t->input_string); 1868373020dSJacques Vidrine val = 1; 1878373020dSJacques Vidrine } 1888373020dSJacques Vidrine free(s); 1898373020dSJacques Vidrine } 1908373020dSJacques Vidrine krb5_free_principal (context, princ); 1918373020dSJacques Vidrine } 192c19800e8SDoug Rabson krb5_free_context(context); 1938373020dSJacques Vidrine return val; 1948373020dSJacques Vidrine } 195