diff options
author | Mikhail Galanin <mgalanin@mimecast.com> | 2018-09-19 15:42:38 +0100 |
---|---|---|
committer | Mikhail Galanin <mgalanin@mimecast.com> | 2018-09-19 15:42:38 +0100 |
commit | 57d19346b6ff61c360ce5d1653d1e25118277c88 (patch) | |
tree | 8cc845db0d615031b3dbe1831fc28419287aa236 | |
parent | 50d51fca34585b51c1e6ecd168bda6e9e48b0bb2 (diff) | |
download | rspamd-57d19346b6ff61c360ce5d1653d1e25118277c88.tar.gz rspamd-57d19346b6ff61c360ce5d1653d1e25118277c88.zip |
[Test] Added key to run specifig lua-test
example:
$ ./test/rspamd-test -p /rspamd/lua -t selectors.lua
no way to run two test suites atm
-rw-r--r-- | test/rspamd_lua_test.c | 22 | ||||
-rw-r--r-- | test/rspamd_test_suite.c | 21 |
2 files changed, 42 insertions, 1 deletions
diff --git a/test/rspamd_lua_test.c b/test/rspamd_lua_test.c index 0c785e9e6..b87df0f58 100644 --- a/test/rspamd_lua_test.c +++ b/test/rspamd_lua_test.c @@ -24,6 +24,8 @@ #endif static const char *lua_src = BUILDROOT "/test/lua/tests.lua"; +extern gchar *lua_test; +extern struct rspamd_main *rspamd_main; static int traceback (lua_State *L) @@ -61,6 +63,8 @@ rspamd_lua_test_func (void) glob_t globbuf; gint i, len; + rspamd_lua_set_globals (rspamd_main->cfg, L, NULL); + rspamd_printf ("Starting lua tests\n"); if ((rp = realpath (lua_src, rp_buf)) == NULL) { @@ -90,11 +94,27 @@ rspamd_lua_test_func (void) pattern = g_malloc (len); rspamd_snprintf (pattern, len, "%s/unit/%s", dir, "*.lua"); + gint lua_test_len = 0; + gint inserted_file = 1; + gint path_start; + if (lua_test) { + lua_test_len = strlen (lua_test); + } if (glob (pattern, GLOB_DOOFFS, NULL, &globbuf) == 0) { for (i = 0; i < (gint)globbuf.gl_pathc; i++) { - lua_pushinteger (L, i + 1); + if (lua_test) { + path_start = strlen (globbuf.gl_pathv[i]) - lua_test_len; + if (path_start < 0 || + strncmp (globbuf.gl_pathv[i] + path_start, lua_test, lua_test_len) != 0) { + continue; + } + } + + lua_pushinteger (L, inserted_file); lua_pushstring (L, globbuf.gl_pathv[i]); lua_settable (L, -3); + + inserted_file ++; } globfree (&globbuf); g_free (pattern); diff --git a/test/rspamd_test_suite.c b/test/rspamd_test_suite.c index 07b728ecf..0be3091d9 100644 --- a/test/rspamd_test_suite.c +++ b/test/rspamd_test_suite.c @@ -7,10 +7,22 @@ struct rspamd_main *rspamd_main = NULL; struct event_base *base = NULL; worker_t *workers[] = { NULL }; +gchar *lua_test = NULL; +gboolean verbose = FALSE; + +static GOptionEntry entries[] = +{ + { "test", 't', 0, G_OPTION_ARG_STRING, &lua_test, + "Lua test to run (i.e. selectors.lua)", NULL }, + { NULL, 0, 0, G_OPTION_ARG_NONE, NULL, NULL, NULL } +}; + int main (int argc, char **argv) { struct rspamd_config *cfg; + GOptionContext *context; + GError *error = NULL; rspamd_main = (struct rspamd_main *)g_malloc (sizeof (struct rspamd_main)); memset (rspamd_main, 0, sizeof (struct rspamd_main)); @@ -27,6 +39,15 @@ main (int argc, char **argv) g_test_init (&argc, &argv, NULL); + context = g_option_context_new ("- run rspamd test"); + g_option_context_add_main_entries (context, entries, NULL); + + if (!g_option_context_parse (context, &argc, &argv, &error)) { + fprintf (stderr, "option parsing failed: %s\n", error->message); + g_option_context_free (context); + exit (1); + } + cfg->libs_ctx = rspamd_init_libs (); base = event_init (); |