summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorrl1987 <rl1987@sdf.lonestar.org>2019-02-25 19:07:47 +0200
committerrl1987 <rl1987@sdf.lonestar.org>2019-02-25 20:04:02 +0200
commitd731ab45831cfc2104b17b3a623e0c89c3174145 (patch)
tree20cac7ef2f3107a20d4d86ce276a8e3077080234
parent69238ca2da923c8a50d5c1007f3e702eea163b50 (diff)
downloadtor-d731ab45831cfc2104b17b3a623e0c89c3174145.tar.gz
tor-d731ab45831cfc2104b17b3a623e0c89c3174145.zip
Check that all valid values of int and unsigned int can be put into void pointer
-rw-r--r--changes/ticket295373
-rw-r--r--src/test/include.am1
-rw-r--r--src/test/test.h1
-rw-r--r--src/test/test_ptr_slow.c67
-rw-r--r--src/test/test_slow.c1
5 files changed, 73 insertions, 0 deletions
diff --git a/changes/ticket29537 b/changes/ticket29537
new file mode 100644
index 0000000000..048e13c65f
--- /dev/null
+++ b/changes/ticket29537
@@ -0,0 +1,3 @@
+ o Testing:
+ - Check that all valid values of `int` and `unsigned int` can be
+ represented by `void *`. Resolves issue 29537.
diff --git a/src/test/include.am b/src/test/include.am
index d585c2a38a..e6cebe1d1a 100644
--- a/src/test/include.am
+++ b/src/test/include.am
@@ -211,6 +211,7 @@ src_test_test_slow_SOURCES += \
src/test/test_crypto_slow.c \
src/test/test_process_slow.c \
src/test/test_prob_distr.c \
+ src/test/test_ptr_slow.c \
src/test/testing_common.c \
src/test/testing_rsakeys.c \
src/ext/tinytest.c
diff --git a/src/test/test.h b/src/test/test.h
index 2564432985..9d9184e2aa 100644
--- a/src/test/test.h
+++ b/src/test/test.h
@@ -278,6 +278,7 @@ extern struct testcase_t x509_tests[];
extern struct testcase_t slow_crypto_tests[];
extern struct testcase_t slow_process_tests[];
+extern struct testcase_t slow_ptr_tests[];
extern struct testgroup_t testgroups[];
diff --git a/src/test/test_ptr_slow.c b/src/test/test_ptr_slow.c
new file mode 100644
index 0000000000..a5914c9120
--- /dev/null
+++ b/src/test/test_ptr_slow.c
@@ -0,0 +1,67 @@
+/* Copyright (c) 2001-2004, Roger Dingledine.
+ * Copyright (c) 2004-2006, Roger Dingledine, Nick Mathewson.
+ * Copyright (c) 2007-2019, The Tor Project, Inc. */
+/* See LICENSE for licensing information */
+
+#include "orconfig.h"
+#include "core/or/or.h"
+#include "test/test.h"
+
+#include <stdint.h>
+#include <limits.h>
+
+/** Check that all values of int can be cast to void * and back. */
+static void
+test_int_voidstar_interop(void *arg)
+{
+ int a;
+ (void)arg;
+
+ for (a = INT_MIN; a < INT_MAX; a++) {
+ intptr_t ap = (intptr_t)a;
+ void *b = (void *)ap;
+ intptr_t c = (intptr_t)b;
+ void *d = (void *)c;
+
+ tt_assert(ap == c);
+ tt_assert(b == d);
+ }
+
+ done:
+ return;
+}
+
+/** Check that all values of unsigned int can be cast to void * and back. */
+static void
+test_uint_voidstar_interop(void *arg)
+{
+ unsigned int a;
+ (void)arg;
+
+ for (a = 0; a < UINT_MAX; a++) {
+ intptr_t ap = (intptr_t)a;
+ void *b = (void *)ap;
+ intptr_t c = (intptr_t)b;
+ void *d = (void *)c;
+
+ tt_assert(ap == c);
+ tt_assert(b == d);
+ }
+
+ done:
+ return;
+}
+
+struct testcase_t slow_ptr_tests[] = {
+ { .name = "int_voidstar_interop",
+ .fn = test_int_voidstar_interop,
+ .flags = 0,
+ .setup = NULL,
+ .setup_data = NULL },
+ { .name = "uint_voidstar_interop",
+ .fn = test_uint_voidstar_interop,
+ .flags = 0,
+ .setup = NULL,
+ .setup_data = NULL },
+ END_OF_TESTCASES
+};
diff --git a/src/test/test_slow.c b/src/test/test_slow.c
index c3e7edd408..d4d5b755a5 100644
--- a/src/test/test_slow.c
+++ b/src/test/test_slow.c
@@ -22,6 +22,7 @@ struct testgroup_t testgroups[] = {
{ "slow/crypto/", slow_crypto_tests },
{ "slow/process/", slow_process_tests },
{ "slow/prob_distr/", slow_stochastic_prob_distr_tests },
+ { "slow/ptr/", slow_ptr_tests },
END_OF_GROUPS
};