summaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
authorStef Walter <stefw@collabora.co.uk>2011-08-19 10:31:51 +0200
committerStef Walter <stefw@collabora.co.uk>2011-08-19 10:31:51 +0200
commitae95625311e98caa3cccf82d24a3b612df11b26d (patch)
tree7ed56ccc0be88540c2bb7ccba74731b00e920891 /tests
parentd4abb441450deceff760086dcdf9d493b258074a (diff)
Ignore spaces in PKCS#11 URIs
* These should be able to occur anywhere and should be ignored according to RFC 3986. This is documented in the PKCS#11 URI specification.
Diffstat (limited to 'tests')
-rw-r--r--tests/uri-test.c24
1 files changed, 24 insertions, 0 deletions
diff --git a/tests/uri-test.c b/tests/uri-test.c
index 8ab8f93..0e8c718 100644
--- a/tests/uri-test.c
+++ b/tests/uri-test.c
@@ -275,6 +275,29 @@ test_uri_parse_with_bad_syntax (CuTest *tc)
}
static void
+test_uri_parse_with_spaces (CuTest *tc)
+{
+ P11KitUri *uri = NULL;
+ CK_INFO_PTR info;
+ int ret;
+
+ uri = p11_kit_uri_new ();
+ CuAssertPtrNotNull (tc, uri);
+
+ ret = p11_kit_uri_parse ("pkc\ns11: lib rary-desc\rrip \n tion =The%20Library;\n\n\nlibrary-manufacturer=\rMe",
+ P11_KIT_URI_FOR_MODULE, uri);
+ CuAssertIntEquals (tc, P11_KIT_URI_OK, ret);
+
+ info = p11_kit_uri_get_module_info (uri);
+
+ CuAssertTrue (tc, is_space_string (info->manufacturerID, sizeof (info->manufacturerID), "Me"));
+ CuAssertTrue (tc, is_space_string (info->libraryDescription, sizeof (info->libraryDescription), "The Library"));
+
+ p11_kit_uri_free (uri);
+}
+
+
+static void
test_uri_parse_with_library (CuTest *tc)
{
P11KitUri *uri = NULL;
@@ -1146,6 +1169,7 @@ main (void)
SUITE_ADD_TEST (suite, test_uri_parse_with_token);
SUITE_ADD_TEST (suite, test_uri_parse_with_token_bad_encoding);
SUITE_ADD_TEST (suite, test_uri_parse_with_bad_syntax);
+ SUITE_ADD_TEST (suite, test_uri_parse_with_spaces);
SUITE_ADD_TEST (suite, test_uri_parse_with_library);
SUITE_ADD_TEST (suite, test_uri_parse_with_library_bad_encoding);
SUITE_ADD_TEST (suite, test_uri_build_empty);