more cc tests, mostly related to mcc behavior
git-svn-id: svn://svn.h5l.se/heimdal/trunk/heimdal@13419 ec53bebd-3082-4978-b11e-865c3cabbd6b
This commit is contained in:
@@ -35,21 +35,12 @@
|
|||||||
|
|
||||||
RCSID("$Id$");
|
RCSID("$Id$");
|
||||||
|
|
||||||
#define TEST_CC_NAME "/tmp/foo"
|
static void
|
||||||
|
test_default_name(krb5_context context)
|
||||||
int
|
|
||||||
main(int argc, char **argv)
|
|
||||||
{
|
{
|
||||||
krb5_context context;
|
|
||||||
krb5_error_code ret;
|
krb5_error_code ret;
|
||||||
|
const char *p, *test_cc_name = "/tmp/krb5-cc-test-foo";
|
||||||
char *p1, *p2, *p3;
|
char *p1, *p2, *p3;
|
||||||
const char *p;
|
|
||||||
|
|
||||||
setprogname(argv[0]);
|
|
||||||
|
|
||||||
ret = krb5_init_context(&context);
|
|
||||||
if (ret)
|
|
||||||
errx (1, "krb5_init_context failed: %d", ret);
|
|
||||||
|
|
||||||
p = krb5_cc_default_name(context);
|
p = krb5_cc_default_name(context);
|
||||||
if (p == NULL)
|
if (p == NULL)
|
||||||
@@ -68,7 +59,7 @@ main(int argc, char **argv)
|
|||||||
if (strcmp(p1, p2) != 0)
|
if (strcmp(p1, p2) != 0)
|
||||||
krb5_errx (context, 1, "krb5_cc_default_name no longer same");
|
krb5_errx (context, 1, "krb5_cc_default_name no longer same");
|
||||||
|
|
||||||
ret = krb5_cc_set_default_name(context, TEST_CC_NAME);
|
ret = krb5_cc_set_default_name(context, test_cc_name);
|
||||||
if (p == NULL)
|
if (p == NULL)
|
||||||
krb5_errx (context, 1, "krb5_cc_set_default_name 1 failed");
|
krb5_errx (context, 1, "krb5_cc_set_default_name 1 failed");
|
||||||
|
|
||||||
@@ -77,8 +68,136 @@ main(int argc, char **argv)
|
|||||||
krb5_errx (context, 1, "krb5_cc_default_name 2 failed");
|
krb5_errx (context, 1, "krb5_cc_default_name 2 failed");
|
||||||
p3 = estrdup(p);
|
p3 = estrdup(p);
|
||||||
|
|
||||||
if (strcmp(p3, TEST_CC_NAME) != 0)
|
if (strcmp(p3, test_cc_name) != 0)
|
||||||
krb5_errx (context, 1, "krb5_cc_set_default_name 1 failed");
|
krb5_errx (context, 1, "krb5_cc_set_default_name 1 failed");
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Check that a closed cc still keeps it data and that its no longer
|
||||||
|
* there when its destroyed.
|
||||||
|
*/
|
||||||
|
|
||||||
|
static void
|
||||||
|
test_mcache(krb5_context context)
|
||||||
|
{
|
||||||
|
krb5_error_code ret;
|
||||||
|
krb5_ccache id, id2;
|
||||||
|
const char *nc, *tc;
|
||||||
|
char *n, *t, *c;
|
||||||
|
krb5_principal p, p2;
|
||||||
|
|
||||||
|
ret = krb5_parse_name(context, "lha@SU.SE", &p);
|
||||||
|
if (ret)
|
||||||
|
krb5_err(context, 1, ret, "krb5_parse_name");
|
||||||
|
|
||||||
|
ret = krb5_cc_gen_new(context, &krb5_mcc_ops, &id);
|
||||||
|
if (ret)
|
||||||
|
krb5_err(context, 1, ret, "krb5_cc_gen_new");
|
||||||
|
|
||||||
|
ret = krb5_cc_initialize(context, id, p);
|
||||||
|
if (ret)
|
||||||
|
krb5_err(context, 1, ret, "krb5_cc_initialize");
|
||||||
|
|
||||||
|
nc = krb5_cc_get_name(context, id);
|
||||||
|
if (nc == NULL)
|
||||||
|
krb5_errx(context, 1, "krb5_cc_get_name");
|
||||||
|
|
||||||
|
tc = krb5_cc_get_type(context, id);
|
||||||
|
if (tc == NULL)
|
||||||
|
krb5_errx(context, 1, "krb5_cc_get_name");
|
||||||
|
|
||||||
|
n = estrdup(nc);
|
||||||
|
t = estrdup(tc);
|
||||||
|
|
||||||
|
asprintf(&c, "%s:%s", t, n);
|
||||||
|
|
||||||
|
krb5_cc_close(context, id);
|
||||||
|
|
||||||
|
ret = krb5_cc_resolve(context, c, &id2);
|
||||||
|
if (ret)
|
||||||
|
krb5_err(context, 1, ret, "krb5_cc_resolve");
|
||||||
|
|
||||||
|
ret = krb5_cc_get_principal(context, id2, &p2);
|
||||||
|
if (ret)
|
||||||
|
krb5_err(context, 1, ret, "krb5_cc_get_principal");
|
||||||
|
|
||||||
|
if (krb5_principal_compare(context, p, p2) == FALSE)
|
||||||
|
krb5_errx(context, 1, "p != p2");
|
||||||
|
|
||||||
|
krb5_cc_destroy(context, id2);
|
||||||
|
krb5_free_principal(context, p);
|
||||||
|
krb5_free_principal(context, p2);
|
||||||
|
|
||||||
|
ret = krb5_cc_resolve(context, c, &id2);
|
||||||
|
if (ret)
|
||||||
|
krb5_err(context, 1, ret, "krb5_cc_resolve");
|
||||||
|
|
||||||
|
ret = krb5_cc_get_principal(context, id2, &p2);
|
||||||
|
if (ret == 0)
|
||||||
|
krb5_err(context, 1, ret, "krb5_cc_get_principal");
|
||||||
|
|
||||||
|
krb5_cc_destroy(context, id2);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Test that init works on a destroyed cc.
|
||||||
|
*/
|
||||||
|
|
||||||
|
static void
|
||||||
|
test_init_vs_destroy(krb5_context context, const krb5_cc_ops *ops)
|
||||||
|
{
|
||||||
|
krb5_error_code ret;
|
||||||
|
krb5_ccache id, id2;
|
||||||
|
krb5_principal p, p2;
|
||||||
|
char *n;
|
||||||
|
|
||||||
|
ret = krb5_parse_name(context, "lha@SU.SE", &p);
|
||||||
|
if (ret)
|
||||||
|
krb5_err(context, 1, ret, "krb5_parse_name");
|
||||||
|
|
||||||
|
ret = krb5_cc_gen_new(context, ops, &id);
|
||||||
|
if (ret)
|
||||||
|
krb5_err(context, 1, ret, "krb5_cc_gen_new");
|
||||||
|
|
||||||
|
asprintf(&n, "%s:%s",
|
||||||
|
krb5_cc_get_type(context, id),
|
||||||
|
krb5_cc_get_name(context, id));
|
||||||
|
|
||||||
|
ret = krb5_cc_resolve(context, n, &id2);
|
||||||
|
if (ret)
|
||||||
|
krb5_err(context, 1, ret, "krb5_cc_resolve");
|
||||||
|
|
||||||
|
krb5_cc_destroy(context, id);
|
||||||
|
|
||||||
|
ret = krb5_cc_initialize(context, id2, p);
|
||||||
|
if (ret)
|
||||||
|
krb5_err(context, 1, ret, "krb5_cc_initialize");
|
||||||
|
|
||||||
|
ret = krb5_cc_get_principal(context, id2, &p2);
|
||||||
|
if (ret)
|
||||||
|
krb5_err(context, 1, ret, "krb5_cc_get_principal");
|
||||||
|
|
||||||
|
krb5_cc_destroy(context, id2);
|
||||||
|
krb5_free_principal(context, p);
|
||||||
|
krb5_free_principal(context, p2);
|
||||||
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
main(int argc, char **argv)
|
||||||
|
{
|
||||||
|
krb5_context context;
|
||||||
|
krb5_error_code ret;
|
||||||
|
|
||||||
|
setprogname(argv[0]);
|
||||||
|
|
||||||
|
ret = krb5_init_context(&context);
|
||||||
|
if (ret)
|
||||||
|
errx (1, "krb5_init_context failed: %d", ret);
|
||||||
|
|
||||||
|
test_default_name(context);
|
||||||
|
test_mcache(context);
|
||||||
|
test_init_vs_destroy(context, &krb5_mcc_ops);
|
||||||
|
test_init_vs_destroy(context, &krb5_fcc_ops);
|
||||||
|
|
||||||
krb5_free_context(context);
|
krb5_free_context(context);
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user