Forráskód Böngészése

Unit test: url encoding in not unique

bel 10 éve
szülő
commit
f6b254e9a7
1 módosított fájl, 19 hozzáadás és 9 törlés
  1. 19 9
      test/private.c

+ 19 - 9
test/private.c

@@ -353,10 +353,13 @@ START_TEST(test_encode_decode)
 {
 	char buf[128];
 	const char *alpha = "abcdefghijklmnopqrstuvwxyz";
-	const char *alpha_enc = "YWJjZGVmZ2hpamtsbW5vcHFyc3R1dnd4eXo=";
+	const char *alpha_b64_enc = "YWJjZGVmZ2hpamtsbW5vcHFyc3R1dnd4eXo=";
 	const char *nonalpha = " !\"#$%&'()*+,-./0123456789:;<=>?@";
-	const char *nonalpha_enc = "ICEiIyQlJicoKSorLC0uLzAxMjM0NTY3ODk6Ozw9Pj9A";
-	const char *nonalpha_url =
+	const char *nonalpha_b64_enc =
+	    "ICEiIyQlJicoKSorLC0uLzAxMjM0NTY3ODk6Ozw9Pj9A";
+	const char *nonalpha_url_enc1 =
+	    "%20%21%22%23$%25%26%27()%2a%2b,-.%2f0123456789%3a;%3c%3d%3e%3f%40";
+	const char *nonalpha_url_enc2 =
 	    "%20!%22%23%24%25%26'()*%2B%2C-.%2F0123456789%3A%3B%3C%3D%3E%3F%40";
 	int ret;
 	size_t len;
@@ -392,18 +395,18 @@ START_TEST(test_encode_decode)
 
 	memset(buf, 77, sizeof(buf));
 	base64_encode((unsigned char *)alpha, (int)strlen(alpha), buf);
-	ck_assert_str_eq(buf, alpha_enc);
+	ck_assert_str_eq(buf, alpha_b64_enc);
 
 	memset(buf, 77, sizeof(buf));
 	base64_encode((unsigned char *)nonalpha, (int)strlen(nonalpha), buf);
-	ck_assert_str_eq(buf, nonalpha_enc);
+	ck_assert_str_eq(buf, nonalpha_b64_enc);
 #endif
 
 #if defined(USE_LUA)
 	memset(buf, 77, sizeof(buf));
 	len = 9999;
 	ret = base64_decode(
-	    (unsigned char *)alpha_enc, (int)strlen(alpha_enc), buf, &len);
+	    (unsigned char *)alpha_b64_enc, (int)strlen(alpha_b64_enc), buf, &len);
 	ck_assert_int_eq(ret, -1);
 	ck_assert_uint_eq((unsigned int)len, (unsigned int)strlen(alpha));
 	ck_assert_str_eq(buf, alpha);
@@ -423,8 +426,8 @@ START_TEST(test_encode_decode)
 	memset(buf, 77, sizeof(buf));
 	ret = mg_url_encode(nonalpha, buf, sizeof(buf));
 	ck_assert_int_eq(ret, (int)strlen(buf));
-	ck_assert_int_eq(ret, (int)strlen(nonalpha_url));
-	ck_assert_str_eq(buf, nonalpha_url);
+	ck_assert_int_eq(ret, (int)strlen(nonalpha_url_enc1));
+	ck_assert_str_eq(buf, nonalpha_url_enc1);
 
 	memset(buf, 77, sizeof(buf));
 	ret = mg_url_decode(alpha, (int)strlen(alpha), buf, sizeof(buf), 0);
@@ -434,7 +437,14 @@ START_TEST(test_encode_decode)
 
 	memset(buf, 77, sizeof(buf));
 	ret = mg_url_decode(
-	    nonalpha_url, (int)strlen(nonalpha_url), buf, sizeof(buf), 0);
+	    nonalpha_url_enc1, (int)strlen(nonalpha_url_enc1), buf, sizeof(buf), 0);
+	ck_assert_int_eq(ret, (int)strlen(buf));
+	ck_assert_int_eq(ret, (int)strlen(nonalpha));
+	ck_assert_str_eq(buf, nonalpha);
+
+	memset(buf, 77, sizeof(buf));
+	ret = mg_url_decode(
+	    nonalpha_url_enc2, (int)strlen(nonalpha_url_enc2), buf, sizeof(buf), 0);
 	ck_assert_int_eq(ret, (int)strlen(buf));
 	ck_assert_int_eq(ret, (int)strlen(nonalpha));
 	ck_assert_str_eq(buf, nonalpha);