summaryrefslogtreecommitdiff
path: root/src/test
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2014-09-11 00:00:13 -0400
committerNick Mathewson <nickm@torproject.org>2014-09-11 00:00:13 -0400
commit284cc9a22405bf320944b34ac08be74c2d897fc3 (patch)
treeabafe075c57425932a7bcb4a5e26bc41c3b03ff1 /src/test
parent59f9a5c78695213442599e8f2e8a535e8a9cc666 (diff)
downloadtor-284cc9a22405bf320944b34ac08be74c2d897fc3.tar.gz
tor-284cc9a22405bf320944b34ac08be74c2d897fc3.zip
Avoid an overflow on negation in format_helper_exit_status
Part of 13104; patch from teor.
Diffstat (limited to 'src/test')
-rw-r--r--src/test/test_util.c23
1 files changed, 23 insertions, 0 deletions
diff --git a/src/test/test_util.c b/src/test/test_util.c
index f091fc95a1..eed37ca817 100644
--- a/src/test/test_util.c
+++ b/src/test/test_util.c
@@ -2561,12 +2561,17 @@ test_util_exit_status(void *ptr)
int n;
(void)ptr;
+
+ clear_hex_errno(hex_errno);
+ test_streq("", hex_errno);
clear_hex_errno(hex_errno);
n = format_helper_exit_status(0, 0, hex_errno);
test_streq("0/0\n", hex_errno);
test_eq(n, strlen(hex_errno));
+#if SIZEOF_INT == 4
+
clear_hex_errno(hex_errno);
n = format_helper_exit_status(0, 0x7FFFFFFF, hex_errno);
test_streq("0/7FFFFFFF\n", hex_errno);
@@ -2577,6 +2582,21 @@ test_util_exit_status(void *ptr)
test_streq("FF/-80000000\n", hex_errno);
test_eq(n, strlen(hex_errno));
test_eq(n, HEX_ERRNO_SIZE);
+
+#elif SIZEOF_INT == 8
+
+ clear_hex_errno(hex_errno);
+ n = format_helper_exit_status(0, 0x7FFFFFFFFFFFFFFF, hex_errno);
+ test_streq("0/7FFFFFFFFFFFFFFF\n", hex_errno);
+ test_eq(n, strlen(hex_errno));
+
+ clear_hex_errno(hex_errno);
+ n = format_helper_exit_status(0xFF, -0x8000000000000000, hex_errno);
+ test_streq("FF/-8000000000000000\n", hex_errno);
+ test_eq(n, strlen(hex_errno));
+ test_eq(n, HEX_ERRNO_SIZE);
+
+#endif
clear_hex_errno(hex_errno);
n = format_helper_exit_status(0x7F, 0, hex_errno);
@@ -2587,6 +2607,9 @@ test_util_exit_status(void *ptr)
n = format_helper_exit_status(0x08, -0x242, hex_errno);
test_streq("8/-242\n", hex_errno);
test_eq(n, strlen(hex_errno));
+
+ clear_hex_errno(hex_errno);
+ test_streq("", hex_errno);
done:
;