aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2014-10-01 13:55:14 +0100
committerVsevolod Stakhov <vsevolod@highsecure.ru>2014-10-01 13:55:14 +0100
commit5b545bdf825c5961ed2aea5a3e071f08ce6c6e3d (patch)
tree04dbfa33a7d9bf340997c767f84a2177f36434e8
parent56d73d7a1826d016a96b6ca374d43b80dce72c60 (diff)
downloadrspamd-5b545bdf825c5961ed2aea5a3e071f08ce6c6e3d.tar.gz
rspamd-5b545bdf825c5961ed2aea5a3e071f08ce6c6e3d.zip
Add tests for ipv6 addresses.
-rw-r--r--test/rspamd_radix_test.c62
1 files changed, 45 insertions, 17 deletions
diff --git a/test/rspamd_radix_test.c b/test/rspamd_radix_test.c
index 5e77b02f9..68f5fcc71 100644
--- a/test/rspamd_radix_test.c
+++ b/test/rspamd_radix_test.c
@@ -26,7 +26,7 @@
#include "radix.h"
#include "ottery.h"
-const gsize max_elts = 20 * 1024;
+const gsize max_elts = 50 * 1024;
const gint lookup_cycles = 1 * 1024;
const uint masks[] = {
@@ -81,18 +81,35 @@ rspamd_radix_text_vec (void)
radix_compressed_t *tree = radix_tree_create_compressed ();
struct _tv *t = &test_vec[0];
struct in_addr ina;
+ struct in6_addr in6a;
gulong i, val;
while (t->ip != NULL) {
- t->addr = g_malloc (sizeof (ina));
- t->naddr = g_malloc (sizeof (ina));
- inet_aton (t->ip, &ina);
- memcpy (t->addr, &ina, sizeof (ina));
+ t->addr = g_malloc (sizeof (in6a));
+ t->naddr = g_malloc (sizeof (in6a));
+ if (inet_pton (AF_INET, t->ip, &ina) == 1) {
+ memcpy (t->addr, &ina, sizeof (ina));
+ t->len = sizeof (ina);
+ }
+ else if (inet_pton (AF_INET6, t->ip, &in6a) == 1) {
+ memcpy (t->addr, &in6a, sizeof (in6a));
+ t->len = sizeof (in6a);
+ }
+ else {
+ g_assert (0);
+ }
if (t->nip) {
- inet_aton (t->nip, &ina);
- memcpy (t->naddr, &ina, sizeof (ina));
+ if (inet_pton (AF_INET, t->nip, &ina) == 1) {
+ memcpy (t->naddr, &ina, sizeof (ina));
+ }
+ else if (inet_pton (AF_INET6, t->nip, &in6a) == 1) {
+ memcpy (t->naddr, &in6a, sizeof (in6a));
+ }
+ else {
+ g_assert (0);
+ }
}
- t->len = sizeof (ina);
+
t->mask = t->len * NBBY - strtoul (t->m, NULL, 10);
t ++;
}
@@ -128,6 +145,8 @@ rspamd_radix_test_func (void)
struct {
guint32 addr;
guint32 mask;
+ guint8 addr6[16];
+ guint32 mask6;
} *addrs;
gsize nelts, i;
gint lc;
@@ -146,6 +165,8 @@ rspamd_radix_test_func (void)
for (i = 0; i < nelts; i ++) {
addrs[i].addr = ottery_rand_uint32 ();
addrs[i].mask = masks[ottery_rand_range(G_N_ELEMENTS (masks) - 1)];
+ ottery_rand_bytes (addrs[i].addr6, sizeof(addrs[i].addr6));
+ addrs[i].mask6 = ottery_rand_range(128);
}
msg_info ("old radix performance (%z elts)", nelts);
@@ -187,8 +208,8 @@ rspamd_radix_test_func (void)
msg_info ("new radix performance (%z elts)", nelts);
clock_gettime (CLOCK_MONOTONIC, &ts1);
for (i = 0; i < nelts; i ++) {
- radix_insert_compressed (comp_tree, &addrs[i].addr, sizeof (guint32),
- 32 - addrs[i].mask, 1);
+ radix_insert_compressed (comp_tree, addrs[i].addr6, sizeof (addrs[i].addr6),
+ 128 - addrs[i].mask6, i);
}
clock_gettime (CLOCK_MONOTONIC, &ts2);
diff = (ts2.tv_sec - ts1.tv_sec) * 1000. + /* Seconds */
@@ -199,18 +220,25 @@ rspamd_radix_test_func (void)
clock_gettime (CLOCK_MONOTONIC, &ts1);
for (lc = 0; lc < lookup_cycles; lc ++) {
for (i = 0; i < nelts; i ++) {
-#if 0
- /* Used to write bad random vector */
- msg_info("{\"%s\", NULL, \"%ud\", 0, 0, 0, 0},",
- inet_ntoa(*(struct in_addr *)&addrs[i].addr),
- addrs[i].mask);
-#endif
- if (radix_find_compressed (comp_tree, &addrs[i].addr, sizeof (guint32))
+ if (radix_find_compressed (comp_tree, addrs[i].addr6, sizeof (addrs[i].addr6))
== RADIX_NO_VALUE) {
all_good = FALSE;
}
}
}
+#if 1
+ if (!all_good) {
+ for (i = 0; i < nelts; i ++) {
+ /* Used to write bad random vector */
+ char ipbuf[INET6_ADDRSTRLEN + 1];
+ inet_ntop(AF_INET6, addrs[i].addr6, ipbuf, sizeof(ipbuf));
+ msg_info("{\"%s\", NULL, \"%ud\", 0, 0, 0, 0},",
+ ipbuf,
+ addrs[i].mask6);
+ }
+ }
+#endif
+
g_assert (all_good);
clock_gettime (CLOCK_MONOTONIC, &ts2);
diff = (ts2.tv_sec - ts1.tv_sec) * 1000. + /* Seconds */