aboutsummaryrefslogtreecommitdiffstats
path: root/test/rspamd_shingles_test.c
diff options
context:
space:
mode:
Diffstat (limited to 'test/rspamd_shingles_test.c')
-rw-r--r--test/rspamd_shingles_test.c16
1 files changed, 10 insertions, 6 deletions
diff --git a/test/rspamd_shingles_test.c b/test/rspamd_shingles_test.c
index 182830fd2..5084cd120 100644
--- a/test/rspamd_shingles_test.c
+++ b/test/rspamd_shingles_test.c
@@ -61,15 +61,17 @@ generate_fuzzy_words (gsize cnt, gsize max_len)
static void
permute_vector (GArray *in, gdouble prob)
{
- gsize i;
+ gsize i, total = 0;
rspamd_fstring_t *w;
for (i = 0; i < in->len; i ++) {
if (ottery_rand_unsigned () <= G_MAXUINT * prob) {
w = &g_array_index (in, rspamd_fstring_t, i);
generate_random_string (w->begin, w->len);
+ total ++;
}
}
+ msg_debug ("generated %z permutations of %ud words", total, in->len);
}
static void
@@ -93,7 +95,7 @@ test_case (gsize cnt, gsize max_len, gdouble perm_factor)
guchar key[16];
ottery_rand_bytes (key, sizeof (key));
- input = generate_fuzzy_words (5, 100);
+ input = generate_fuzzy_words (cnt, max_len);
sgl = rspamd_shingles_generate (input, key, NULL,
rspamd_shingles_default_filter, NULL);
permute_vector (input, perm_factor);
@@ -102,7 +104,8 @@ test_case (gsize cnt, gsize max_len, gdouble perm_factor)
res = rspamd_shingles_compare (sgl, sgl_permuted);
- g_assert_cmpfloat (fabs (res - perm_factor), <=, 0.15);
+ msg_debug ("percentage of common shingles: %.3f", res);
+ g_assert_cmpfloat (fabs ((1.0 - res) - sqrt (perm_factor)), <=, 0.20);
free_fuzzy_words (input);
g_free (sgl);
@@ -112,9 +115,10 @@ test_case (gsize cnt, gsize max_len, gdouble perm_factor)
void
rspamd_shingles_test_func (void)
{
- test_case (5, 100, 0.5);
- test_case (500, 100, 0.5);
- test_case (5000, 200, 0.1);
+ //test_case (5, 100, 0.5);
+ test_case (200, 10, 0.1);
+ test_case (500, 100, 0.01);
+ test_case (5000, 200, 0.01);
test_case (5000, 100, 0);
test_case (5000, 100, 1.0);
}