From 077d9b3c2f22dd2d4e66971e999dc01ac2fa2b44 Mon Sep 17 00:00:00 2001 From: Vsevolod Stakhov Date: Thu, 4 Jan 2018 19:19:43 +0000 Subject: [Feature] Add timeout to rspamc when doing corpus test --- src/rspamadm/corpus_test.c | 56 +++++++++++++++++++++++++--------------------- src/rspamadm/rescore.c | 12 +++++++--- 2 files changed, 40 insertions(+), 28 deletions(-) (limited to 'src') diff --git a/src/rspamadm/corpus_test.c b/src/rspamadm/corpus_test.c index 62aecb148..7e1aa40e9 100644 --- a/src/rspamadm/corpus_test.c +++ b/src/rspamadm/corpus_test.c @@ -22,6 +22,7 @@ static gchar *ham_directory = NULL; static gchar *spam_directory = NULL; static gchar *output_location = "results.log"; static gint connections = 10; +static gdouble timeout = 60.0; static void rspamadm_corpus_test (gint argc, gchar **argv); static const char *rspamadm_corpus_test_help (gboolean full_help); @@ -35,15 +36,17 @@ struct rspamadm_command corpus_test_command = { // TODO add -nparellel and -o options static GOptionEntry entries[] = { - {"ham", 'a', 0, G_OPTION_ARG_FILENAME, &ham_directory, - "Ham directory", NULL}, - {"spam", 's', 0, G_OPTION_ARG_FILENAME, &spam_directory, - "Spam directory", NULL}, - {"output", 'o', 0, G_OPTION_ARG_FILENAME, &output_location, - "Log output location", NULL}, - {"connections", 'n', 0, G_OPTION_ARG_INT, &connections, - "Number of parellel connections [Default: 10]", NULL}, - {NULL, 0, 0, G_OPTION_ARG_NONE, NULL, NULL, NULL} + {"ham", 'a', 0, G_OPTION_ARG_FILENAME, &ham_directory, + "Ham directory", NULL}, + {"spam", 's', 0, G_OPTION_ARG_FILENAME, &spam_directory, + "Spam directory", NULL}, + {"output", 'o', 0, G_OPTION_ARG_FILENAME, &output_location, + "Log output location", NULL}, + {"connections", 'n', 0, G_OPTION_ARG_INT, &connections, + "Number of parellel connections [Default: 10]", NULL}, + {"timeout", 't', 0, G_OPTION_ARG_DOUBLE, &timeout, + "Timeout for connections [Default: 60]", NULL}, + {NULL, 0, 0, G_OPTION_ARG_NONE, NULL, NULL, NULL} }; static const char * @@ -53,13 +56,14 @@ rspamadm_corpus_test_help (gboolean full_help) if (full_help) { help_str = "Create logs files from email corpus\n\n" - "Usage: rspamadm corpus_test [-a ]" - " [-s ]\n" - "Where option are:\n\n" - "-a: path to ham directory\n" - "-s: path to spam directory\n" - "-n: maximum parellel connections\n" - "-o: log output file\n"; + "Usage: rspamadm corpus_test [-a ]" + " [-s ]\n" + "Where option are:\n\n" + "-a: path to ham directory\n" + "-s: path to spam directory\n" + "-n: maximum parallel connections\n" + "-o: log output file\n" + "-t: timeout for rspamc operations (default: 60)\n"; } @@ -79,7 +83,7 @@ rspamadm_corpus_test (gint argc, gchar **argv) ucl_object_t *obj; context = g_option_context_new ( - "corpus_test - Create logs files from email corpus"); + "corpus_test - create logs files from email corpus"); g_option_context_set_summary (context, "Summary:\n Rspamd administration utility version " @@ -102,19 +106,21 @@ rspamadm_corpus_test (gint argc, gchar **argv) obj = ucl_object_typed_new (UCL_OBJECT); ucl_object_insert_key (obj, ucl_object_fromstring (ham_directory), - "ham_directory", 0, false); + "ham_directory", 0, false); ucl_object_insert_key (obj, ucl_object_fromstring (spam_directory), - "spam_directory", 0, false); + "spam_directory", 0, false); ucl_object_insert_key (obj, ucl_object_fromstring (output_location), - "output_location", 0, false); + "output_location", 0, false); ucl_object_insert_key (obj, ucl_object_fromint (connections), - "connections", 0, false); + "connections", 0, false); + ucl_object_insert_key (obj, ucl_object_fromdouble (timeout), + "timeout", 0, false); rspamadm_execute_lua_ucl_subr (L, - argc, - argv, - obj, - "corpus_test"); + argc, + argv, + obj, + "corpus_test"); lua_close (L); ucl_object_unref (obj); diff --git a/src/rspamadm/rescore.c b/src/rspamadm/rescore.c index 48dbc1f1f..ba5619776 100644 --- a/src/rspamadm/rescore.c +++ b/src/rspamadm/rescore.c @@ -29,6 +29,7 @@ static gchar *output = "new.scores"; static gdouble threshold = 15; /* Spam threshold */ static gboolean score_diff = false; /* Print score diff flag */ static gint64 iters = 500; /* Perceptron max iterations */ +gdouble timeout = 60.0; /* TODO: think about adding the config file reading */ @@ -52,6 +53,8 @@ static GOptionEntry entries[] = { "Print score diff", NULL}, {"iters", 'i', 0, G_OPTION_ARG_INT64, &iters, "Max iterations for perceptron [Default: 500]", NULL}, + {"timeout", 't', 0, G_OPTION_ARG_DOUBLE, &timeout, + "Timeout for connections [Default: 60]", NULL}, {NULL, 0, 0, G_OPTION_ARG_NONE, NULL, NULL, NULL} }; @@ -65,9 +68,10 @@ rspamadm_rescore_help (gboolean full_help) { "Usage: rspamadm rescore -l \n" "Where options are:\n\n" "-l: path to logs directory\n" - "-o: Scores output file location\n" - "-d: Print scores diff\n" - "-i: Max iterations for perceptron\n"; + "-o: scores output file location\n" + "-d: print scores diff\n" + "-i: max iterations for perceptron\n" + "-t: timeout for rspamc operations (default: 60)\n"; } else { help_str = "Estimate optimal symbol weights from log files"; } @@ -127,6 +131,8 @@ rspamadm_rescore (gint argc, gchar **argv) { "iters", 0, false); ucl_object_insert_key (obj, ucl_object_frombool (score_diff), "diff", 0, false); + ucl_object_insert_key (obj, ucl_object_fromdouble (timeout), + "timeout", 0, false); rspamadm_execute_lua_ucl_subr (L, argc, -- cgit v1.2.3