forked from cory/tildefriends
libuv 1.47.0.
git-svn-id: https://www.unprompted.com/svn/projects/tildefriends/trunk@4615 ed5197a5-7fde-0310-b194-c3ffbd925b24
This commit is contained in:
73
deps/libuv/test/test-idna.c
vendored
73
deps/libuv/test/test-idna.c
vendored
@@ -20,6 +20,7 @@
|
||||
*/
|
||||
|
||||
#include "task.h"
|
||||
#define uv__malloc malloc
|
||||
#include "../src/idna.c"
|
||||
#include <string.h>
|
||||
|
||||
@@ -31,66 +32,66 @@ TEST_IMPL(utf8_decode1) {
|
||||
/* ASCII. */
|
||||
p = b;
|
||||
snprintf(b, sizeof(b), "%c\x7F", 0x00);
|
||||
ASSERT(0 == uv__utf8_decode1(&p, b + sizeof(b)));
|
||||
ASSERT(p == b + 1);
|
||||
ASSERT(127 == uv__utf8_decode1(&p, b + sizeof(b)));
|
||||
ASSERT(p == b + 2);
|
||||
ASSERT_OK(uv__utf8_decode1(&p, b + sizeof(b)));
|
||||
ASSERT_PTR_EQ(p, b + 1);
|
||||
ASSERT_EQ(127, uv__utf8_decode1(&p, b + sizeof(b)));
|
||||
ASSERT_PTR_EQ(p, b + 2);
|
||||
|
||||
/* Two-byte sequences. */
|
||||
p = b;
|
||||
snprintf(b, sizeof(b), "\xC2\x80\xDF\xBF");
|
||||
ASSERT(128 == uv__utf8_decode1(&p, b + sizeof(b)));
|
||||
ASSERT(p == b + 2);
|
||||
ASSERT(0x7FF == uv__utf8_decode1(&p, b + sizeof(b)));
|
||||
ASSERT(p == b + 4);
|
||||
ASSERT_EQ(128, uv__utf8_decode1(&p, b + sizeof(b)));
|
||||
ASSERT_PTR_EQ(p, b + 2);
|
||||
ASSERT_EQ(0x7FF, uv__utf8_decode1(&p, b + sizeof(b)));
|
||||
ASSERT_PTR_EQ(p, b + 4);
|
||||
|
||||
/* Three-byte sequences. */
|
||||
p = b;
|
||||
snprintf(b, sizeof(b), "\xE0\xA0\x80\xEF\xBF\xBF");
|
||||
ASSERT(0x800 == uv__utf8_decode1(&p, b + sizeof(b)));
|
||||
ASSERT(p == b + 3);
|
||||
ASSERT(0xFFFF == uv__utf8_decode1(&p, b + sizeof(b)));
|
||||
ASSERT(p == b + 6);
|
||||
ASSERT_EQ(0x800, uv__utf8_decode1(&p, b + sizeof(b)));
|
||||
ASSERT_PTR_EQ(p, b + 3);
|
||||
ASSERT_EQ(0xFFFF, uv__utf8_decode1(&p, b + sizeof(b)));
|
||||
ASSERT_PTR_EQ(p, b + 6);
|
||||
|
||||
/* Four-byte sequences. */
|
||||
p = b;
|
||||
snprintf(b, sizeof(b), "\xF0\x90\x80\x80\xF4\x8F\xBF\xBF");
|
||||
ASSERT(0x10000 == uv__utf8_decode1(&p, b + sizeof(b)));
|
||||
ASSERT(p == b + 4);
|
||||
ASSERT(0x10FFFF == uv__utf8_decode1(&p, b + sizeof(b)));
|
||||
ASSERT(p == b + 8);
|
||||
ASSERT_EQ(0x10000, uv__utf8_decode1(&p, b + sizeof(b)));
|
||||
ASSERT_PTR_EQ(p, b + 4);
|
||||
ASSERT_EQ(0x10FFFF, uv__utf8_decode1(&p, b + sizeof(b)));
|
||||
ASSERT_PTR_EQ(p, b + 8);
|
||||
|
||||
/* Four-byte sequences > U+10FFFF; disallowed. */
|
||||
p = b;
|
||||
snprintf(b, sizeof(b), "\xF4\x90\xC0\xC0\xF7\xBF\xBF\xBF");
|
||||
ASSERT((unsigned) -1 == uv__utf8_decode1(&p, b + sizeof(b)));
|
||||
ASSERT(p == b + 4);
|
||||
ASSERT((unsigned) -1 == uv__utf8_decode1(&p, b + sizeof(b)));
|
||||
ASSERT(p == b + 8);
|
||||
ASSERT_EQ((unsigned) -1, uv__utf8_decode1(&p, b + sizeof(b)));
|
||||
ASSERT_PTR_EQ(p, b + 4);
|
||||
ASSERT_EQ((unsigned) -1, uv__utf8_decode1(&p, b + sizeof(b)));
|
||||
ASSERT_PTR_EQ(p, b + 8);
|
||||
|
||||
/* Overlong; disallowed. */
|
||||
p = b;
|
||||
snprintf(b, sizeof(b), "\xC0\x80\xC1\x80");
|
||||
ASSERT((unsigned) -1 == uv__utf8_decode1(&p, b + sizeof(b)));
|
||||
ASSERT(p == b + 2);
|
||||
ASSERT((unsigned) -1 == uv__utf8_decode1(&p, b + sizeof(b)));
|
||||
ASSERT(p == b + 4);
|
||||
ASSERT_EQ((unsigned) -1, uv__utf8_decode1(&p, b + sizeof(b)));
|
||||
ASSERT_PTR_EQ(p, b + 2);
|
||||
ASSERT_EQ((unsigned) -1, uv__utf8_decode1(&p, b + sizeof(b)));
|
||||
ASSERT_PTR_EQ(p, b + 4);
|
||||
|
||||
/* Surrogate pairs; disallowed. */
|
||||
p = b;
|
||||
snprintf(b, sizeof(b), "\xED\xA0\x80\xED\xA3\xBF");
|
||||
ASSERT((unsigned) -1 == uv__utf8_decode1(&p, b + sizeof(b)));
|
||||
ASSERT(p == b + 3);
|
||||
ASSERT((unsigned) -1 == uv__utf8_decode1(&p, b + sizeof(b)));
|
||||
ASSERT(p == b + 6);
|
||||
ASSERT_EQ((unsigned) -1, uv__utf8_decode1(&p, b + sizeof(b)));
|
||||
ASSERT_PTR_EQ(p, b + 3);
|
||||
ASSERT_EQ((unsigned) -1, uv__utf8_decode1(&p, b + sizeof(b)));
|
||||
ASSERT_PTR_EQ(p, b + 6);
|
||||
|
||||
/* Simply illegal. */
|
||||
p = b;
|
||||
snprintf(b, sizeof(b), "\xF8\xF9\xFA\xFB\xFC\xFD\xFE\xFF");
|
||||
|
||||
for (i = 1; i <= 8; i++) {
|
||||
ASSERT((unsigned) -1 == uv__utf8_decode1(&p, b + sizeof(b)));
|
||||
ASSERT(p == b + i);
|
||||
ASSERT_EQ((unsigned) -1, uv__utf8_decode1(&p, b + sizeof(b)));
|
||||
ASSERT_PTR_EQ(p, b + i);
|
||||
}
|
||||
|
||||
return 0;
|
||||
@@ -122,7 +123,7 @@ TEST_IMPL(utf8_decode1_overrun) {
|
||||
do { \
|
||||
char d[256] = {0}; \
|
||||
static const char s[] = "" input ""; \
|
||||
ASSERT(err == uv__idna_toascii(s, s + sizeof(s) - 1, d, d + sizeof(d))); \
|
||||
ASSERT_EQ(err, uv__idna_toascii(s, s + sizeof(s) - 1, d, d + sizeof(d))); \
|
||||
} while (0)
|
||||
|
||||
#define T(input, expected) \
|
||||
@@ -132,13 +133,13 @@ TEST_IMPL(utf8_decode1_overrun) {
|
||||
char d2[256] = {0}; \
|
||||
static const char s[] = "" input ""; \
|
||||
n = uv__idna_toascii(s, s + sizeof(s) - 1, d1, d1 + sizeof(d1)); \
|
||||
ASSERT(n == sizeof(expected)); \
|
||||
ASSERT(0 == memcmp(d1, expected, n)); \
|
||||
ASSERT_EQ(n, sizeof(expected)); \
|
||||
ASSERT_OK(memcmp(d1, expected, n)); \
|
||||
/* Sanity check: encoding twice should not change the output. */ \
|
||||
n = uv__idna_toascii(d1, d1 + strlen(d1), d2, d2 + sizeof(d2)); \
|
||||
ASSERT(n == sizeof(expected)); \
|
||||
ASSERT(0 == memcmp(d2, expected, n)); \
|
||||
ASSERT(0 == memcmp(d1, d2, sizeof(d2))); \
|
||||
ASSERT_EQ(n, sizeof(expected)); \
|
||||
ASSERT_OK(memcmp(d2, expected, n)); \
|
||||
ASSERT_OK(memcmp(d1, d2, sizeof(d2))); \
|
||||
} while (0)
|
||||
|
||||
TEST_IMPL(idna_toascii) {
|
||||
|
Reference in New Issue
Block a user