diff options
author | Nick Mathewson <nickm@torproject.org> | 2016-01-03 08:27:54 -0800 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2016-01-03 08:27:54 -0800 |
commit | de8110fba2b177d0fcd0f1b92a42caae8cf7addf (patch) | |
tree | 2825f4813a37718f662e5847c3c95e4f2ed72ae2 | |
parent | a8749ea9fd6d2a686293a6f24dec4dd4a52b1e3e (diff) | |
download | tor-de8110fba2b177d0fcd0f1b92a42caae8cf7addf.tar.gz tor-de8110fba2b177d0fcd0f1b92a42caae8cf7addf.zip |
Explicitly test our get/set_uint{8,16,32,64}.
-rw-r--r-- | configure.ac | 1 | ||||
-rw-r--r-- | src/test/test_util_format.c | 40 |
2 files changed, 41 insertions, 0 deletions
diff --git a/configure.ac b/configure.ac index a47cee6058..7dfab58cf4 100644 --- a/configure.ac +++ b/configure.ac @@ -391,6 +391,7 @@ AC_CHECK_FUNCS( getrlimit \ gettimeofday \ gmtime_r \ + htonll \ inet_aton \ ioctl \ issetugid \ diff --git a/src/test/test_util_format.c b/src/test/test_util_format.c index 705dfcf605..45a28ccaac 100644 --- a/src/test/test_util_format.c +++ b/src/test/test_util_format.c @@ -11,6 +11,44 @@ #define NS_MODULE util_format +#if !defined(HAVE_HTONLL) && !defined(htonll) +#ifdef WORDS_BIGENDIAN +#define htonll(x) (x) +#else +static uint64_t +htonll(uint64_t a) +{ + return htonl((uint32_t)(a>>32)) | (((uint64_t)htonl((uint32_t)a))<<32); +} +#endif +#endif + +static void +test_util_format_unaligned_accessors(void *ignored) +{ + (void)ignored; + char buf[9] = "onionsoup"; // 6f6e696f6e736f7570 + + tt_u64_op(get_uint64(buf+1), OP_EQ, htonll(U64_LITERAL(0x6e696f6e736f7570))); + tt_uint_op(get_uint32(buf+1), OP_EQ, htonl(0x6e696f6e)); + tt_uint_op(get_uint16(buf+1), OP_EQ, htons(0x6e69)); + tt_uint_op(get_uint8(buf+1), OP_EQ, 0x6e); + + set_uint8(buf+7, 0x61); + tt_mem_op(buf, OP_EQ, "onionsoap", 9); + + set_uint16(buf+6, htons(0x746f)); + tt_mem_op(buf, OP_EQ, "onionstop", 9); + + set_uint32(buf+1, htonl(0x78696465)); + tt_mem_op(buf, OP_EQ, "oxidestop", 9); + + set_uint64(buf+1, htonll(U64_LITERAL(0x6266757363617465))); + tt_mem_op(buf, OP_EQ, "obfuscate", 9); + done: + ; +} + static void test_util_format_base64_encode(void *ignored) { @@ -252,6 +290,8 @@ test_util_format_base16_decode(void *ignored) } struct testcase_t util_format_tests[] = { + { "unaligned_accessors", test_util_format_unaligned_accessors, 0, + NULL, NULL }, { "base64_encode", test_util_format_base64_encode, 0, NULL, NULL }, { "base64_decode_nopad", test_util_format_base64_decode_nopad, 0, NULL, NULL }, |