Test improved fcc_remove_cred()
This commit is contained in:
@@ -57,7 +57,7 @@ test_default_name(krb5_context context)
|
|||||||
p1 = estrdup(p);
|
p1 = estrdup(p);
|
||||||
|
|
||||||
ret = krb5_cc_set_default_name(context, NULL);
|
ret = krb5_cc_set_default_name(context, NULL);
|
||||||
if (p == NULL)
|
if (ret)
|
||||||
krb5_errx (context, 1, "krb5_cc_set_default_name failed");
|
krb5_errx (context, 1, "krb5_cc_set_default_name failed");
|
||||||
|
|
||||||
p = krb5_cc_default_name(context);
|
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");
|
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 (ret)
|
||||||
krb5_errx (context, 1, "krb5_cc_set_default_name 1 failed");
|
krb5_errx (context, 1, "krb5_cc_set_default_name 1 failed");
|
||||||
|
|
||||||
p = krb5_cc_default_name(context);
|
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
|
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_error_code ret;
|
||||||
krb5_principal p;
|
krb5_principal p;
|
||||||
krb5_ccache id;
|
krb5_ccache id;
|
||||||
unsigned int i;
|
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)
|
if (ret)
|
||||||
krb5_err(context, 1, ret, "krb5_cc_new_unique");
|
krb5_err(context, 1, ret, "krb5_cc_new_unique");
|
||||||
|
|
||||||
@@ -568,7 +569,7 @@ test_cc_config(krb5_context context)
|
|||||||
if (ret)
|
if (ret)
|
||||||
krb5_err(context, 1, ret, "krb5_cc_initialize");
|
krb5_err(context, 1, ret, "krb5_cc_initialize");
|
||||||
|
|
||||||
for (i = 0; i < 1000; i++) {
|
for (i = 0; i < count; i++) {
|
||||||
krb5_data data, data2;
|
krb5_data data, data2;
|
||||||
const char *name = "foo";
|
const char *name = "foo";
|
||||||
krb5_principal p1 = NULL;
|
krb5_principal p1 = NULL;
|
||||||
@@ -579,6 +580,10 @@ test_cc_config(krb5_context context)
|
|||||||
data.data = rk_UNCONST(name);
|
data.data = rk_UNCONST(name);
|
||||||
data.length = strlen(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);
|
ret = krb5_cc_set_config(context, id, p1, "FriendlyName", &data);
|
||||||
if (ret)
|
if (ret)
|
||||||
krb5_errx(context, 1, "krb5_cc_set_config: add");
|
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);
|
ret = krb5_cc_get_config(context, id, p1, "FriendlyName", &data2);
|
||||||
if (ret)
|
if (ret)
|
||||||
krb5_errx(context, 1, "krb5_cc_get_config: first");
|
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);
|
krb5_data_free(&data2);
|
||||||
|
|
||||||
|
data.data = rk_UNCONST("bar");
|
||||||
|
data.length = strlen("bar");
|
||||||
|
|
||||||
ret = krb5_cc_set_config(context, id, p1, "FriendlyName", &data);
|
ret = krb5_cc_set_config(context, id, p1, "FriendlyName", &data);
|
||||||
if (ret)
|
if (ret)
|
||||||
krb5_errx(context, 1, "krb5_cc_set_config: add -second");
|
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);
|
ret = krb5_cc_get_config(context, id, p1, "FriendlyName", &data2);
|
||||||
if (ret)
|
if (ret)
|
||||||
krb5_errx(context, 1, "krb5_cc_get_config: second");
|
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);
|
krb5_data_free(&data2);
|
||||||
|
|
||||||
ret = krb5_cc_set_config(context, id, p1, "FriendlyName", NULL);
|
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);
|
ret = krb5_cc_get_config(context, id, p1, "FriendlyName", &data2);
|
||||||
if (ret == 0)
|
if (ret == 0)
|
||||||
krb5_errx(context, 1, "krb5_cc_get_config: non-existant");
|
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);
|
krb5_cc_destroy(context, id);
|
||||||
@@ -741,7 +762,8 @@ main(int argc, char **argv)
|
|||||||
krb5_cc_destroy(context, id1);
|
krb5_cc_destroy(context, id1);
|
||||||
krb5_cc_destroy(context, id2);
|
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);
|
krb5_free_context(context);
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user