Test improved fcc_remove_cred()

This commit is contained in:
Nicolas Williams
2013-08-14 21:31:03 -05:00
parent be816fadd4
commit ff0bdc9bc8

View File

@@ -57,7 +57,7 @@ test_default_name(krb5_context context)
p1 = estrdup(p);
ret = krb5_cc_set_default_name(context, NULL);
if (p == NULL)
if (ret)
krb5_errx (context, 1, "krb5_cc_set_default_name failed");
p = krb5_cc_default_name(context);
@@ -69,7 +69,7 @@ test_default_name(krb5_context context)
krb5_errx (context, 1, "krb5_cc_default_name no longer same");
ret = krb5_cc_set_default_name(context, test_cc_name);
if (p == NULL)
if (ret)
krb5_errx (context, 1, "krb5_cc_set_default_name 1 failed");
p = krb5_cc_default_name(context);
@@ -549,14 +549,15 @@ test_prefix_ops(krb5_context context, const char *name, const krb5_cc_ops *ops)
}
static void
test_cc_config(krb5_context context)
test_cc_config(krb5_context context, const char *cc_type,
const char *cc_name, size_t count)
{
krb5_error_code ret;
krb5_principal p;
krb5_ccache id;
unsigned int i;
ret = krb5_cc_new_unique(context, "MEMORY", "bar", &id);
ret = krb5_cc_new_unique(context, cc_type, cc_name, &id);
if (ret)
krb5_err(context, 1, ret, "krb5_cc_new_unique");
@@ -568,7 +569,7 @@ test_cc_config(krb5_context context)
if (ret)
krb5_err(context, 1, ret, "krb5_cc_initialize");
for (i = 0; i < 1000; i++) {
for (i = 0; i < count; i++) {
krb5_data data, data2;
const char *name = "foo";
krb5_principal p1 = NULL;
@@ -579,6 +580,10 @@ test_cc_config(krb5_context context)
data.data = rk_UNCONST(name);
data.length = strlen(name);
/*
* Because of how krb5_cc_set_config() this will also test
* krb5_cc_remove_cred().
*/
ret = krb5_cc_set_config(context, id, p1, "FriendlyName", &data);
if (ret)
krb5_errx(context, 1, "krb5_cc_set_config: add");
@@ -586,8 +591,16 @@ test_cc_config(krb5_context context)
ret = krb5_cc_get_config(context, id, p1, "FriendlyName", &data2);
if (ret)
krb5_errx(context, 1, "krb5_cc_get_config: first");
if (data.length != data2.length ||
memcmp(data.data, data2.data, data.length) != 0)
krb5_errx(context, 1, "krb5_cc_get_config: did not fetch what was set");
krb5_data_free(&data2);
data.data = rk_UNCONST("bar");
data.length = strlen("bar");
ret = krb5_cc_set_config(context, id, p1, "FriendlyName", &data);
if (ret)
krb5_errx(context, 1, "krb5_cc_set_config: add -second");
@@ -595,6 +608,11 @@ test_cc_config(krb5_context context)
ret = krb5_cc_get_config(context, id, p1, "FriendlyName", &data2);
if (ret)
krb5_errx(context, 1, "krb5_cc_get_config: second");
if (data.length != data2.length ||
memcmp(data.data, data2.data, data.length) != 0)
krb5_errx(context, 1, "krb5_cc_get_config: replace failed");
krb5_data_free(&data2);
ret = krb5_cc_set_config(context, id, p1, "FriendlyName", NULL);
@@ -604,6 +622,9 @@ test_cc_config(krb5_context context)
ret = krb5_cc_get_config(context, id, p1, "FriendlyName", &data2);
if (ret == 0)
krb5_errx(context, 1, "krb5_cc_get_config: non-existant");
if (data2.length)
krb5_errx(context, 1, "krb5_cc_get_config: delete failed");
}
krb5_cc_destroy(context, id);
@@ -741,7 +762,8 @@ main(int argc, char **argv)
krb5_cc_destroy(context, id1);
krb5_cc_destroy(context, id2);
test_cc_config(context);
test_cc_config(context, "MEMORY", "bar", 1000); /* 1000 because fast */
test_cc_config(context, "FILE", "/tmp/foocc", 30); /* 30 because slower */
krb5_free_context(context);