2016-02-04 10:37:21 +01:00
|
|
|
/*-
|
|
|
|
* Copyright 2016 Vsevolod Stakhov
|
2015-02-27 16:33:58 +01:00
|
|
|
*
|
2016-02-04 10:37:21 +01:00
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
2015-02-27 16:33:58 +01:00
|
|
|
*
|
2016-02-04 10:37:21 +01:00
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
2015-02-27 16:33:58 +01:00
|
|
|
*/
|
|
|
|
#include "config.h"
|
2015-09-22 19:17:24 +02:00
|
|
|
#include "rspamd.h"
|
2015-02-27 16:33:58 +01:00
|
|
|
#include "util.h"
|
|
|
|
#include "lua/lua_common.h"
|
2015-10-08 14:15:15 +02:00
|
|
|
#include "unix-std.h"
|
|
|
|
|
|
|
|
#ifdef HAVE_GLOB_H
|
|
|
|
#include <glob.h>
|
|
|
|
#endif
|
2015-02-27 16:33:58 +01:00
|
|
|
|
2015-02-28 01:11:56 +01:00
|
|
|
static const char *lua_src = BUILDROOT "/test/lua/tests.lua";
|
2018-09-19 16:42:38 +02:00
|
|
|
extern gchar *lua_test;
|
2018-09-20 12:26:36 +02:00
|
|
|
extern gchar *lua_test_case;
|
2018-09-19 16:42:38 +02:00
|
|
|
extern struct rspamd_main *rspamd_main;
|
2015-02-28 01:11:56 +01:00
|
|
|
|
|
|
|
static int
|
|
|
|
traceback (lua_State *L)
|
|
|
|
{
|
|
|
|
if (!lua_isstring (L, 1)) {
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
2015-03-09 00:45:29 +01:00
|
|
|
lua_getglobal (L, "debug");
|
2015-02-28 01:11:56 +01:00
|
|
|
|
|
|
|
if (!lua_istable(L, -1)) {
|
|
|
|
lua_pop(L, 1);
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
lua_getfield (L, -1, "traceback");
|
|
|
|
|
|
|
|
if (!lua_isfunction(L, -1)) {
|
|
|
|
lua_pop(L, 2);
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
lua_pushvalue (L, 1);
|
|
|
|
lua_pushinteger (L, 2);
|
|
|
|
lua_call(L, 2, 1);
|
|
|
|
|
|
|
|
return 1;
|
|
|
|
}
|
2015-02-27 16:33:58 +01:00
|
|
|
|
|
|
|
void
|
2015-02-28 01:11:56 +01:00
|
|
|
rspamd_lua_test_func (void)
|
2015-02-27 16:33:58 +01:00
|
|
|
{
|
2019-05-10 18:53:10 +02:00
|
|
|
lua_State *L = (lua_State *)rspamd_main->cfg->lua_state;
|
2015-02-28 01:11:56 +01:00
|
|
|
gchar *rp, rp_buf[PATH_MAX], path_buf[PATH_MAX], *tmp, *dir, *pattern;
|
2015-02-27 18:12:41 +01:00
|
|
|
const gchar *old_path;
|
2015-02-28 01:11:56 +01:00
|
|
|
glob_t globbuf;
|
|
|
|
gint i, len;
|
2015-02-27 16:33:58 +01:00
|
|
|
|
2019-03-27 15:18:22 +01:00
|
|
|
rspamd_lua_set_env (L, NULL, NULL, NULL);
|
2019-03-26 17:38:27 +01:00
|
|
|
rspamd_lua_set_globals (rspamd_main->cfg, L);
|
2019-05-10 18:40:39 +02:00
|
|
|
rspamd_lua_start_gc (rspamd_main->cfg);
|
2018-09-19 16:42:38 +02:00
|
|
|
|
2018-09-20 12:26:36 +02:00
|
|
|
if (lua_test_case) {
|
|
|
|
lua_pushstring (L, lua_test_case);
|
|
|
|
lua_setglobal (L, "test_pattern");
|
|
|
|
}
|
|
|
|
|
2015-02-28 01:11:56 +01:00
|
|
|
rspamd_printf ("Starting lua tests\n");
|
2015-02-27 16:33:58 +01:00
|
|
|
|
2015-02-28 01:11:56 +01:00
|
|
|
if ((rp = realpath (lua_src, rp_buf)) == NULL) {
|
|
|
|
msg_err ("cannot find path %s: %s",
|
|
|
|
lua_src, strerror (errno));
|
2015-02-27 16:33:58 +01:00
|
|
|
g_assert (0);
|
|
|
|
}
|
|
|
|
|
2015-02-28 01:11:56 +01:00
|
|
|
tmp = g_strdup (rp);
|
|
|
|
dir = dirname (tmp);
|
2015-02-27 18:12:41 +01:00
|
|
|
/* Set lua path */
|
|
|
|
lua_getglobal (L, "package");
|
|
|
|
lua_getfield (L, -1, "path");
|
|
|
|
old_path = luaL_checkstring (L, -1);
|
2015-02-27 16:33:58 +01:00
|
|
|
|
2015-02-28 01:11:56 +01:00
|
|
|
rspamd_snprintf (path_buf, sizeof (path_buf), "%s;%s/?.lua;%s/unit/?.lua",
|
|
|
|
old_path, dir, dir);
|
2015-02-27 18:12:41 +01:00
|
|
|
lua_pop (L, 1);
|
|
|
|
lua_pushstring (L, path_buf);
|
|
|
|
lua_setfield (L, -2, "path");
|
|
|
|
lua_pop (L, 1);
|
2015-02-27 16:33:58 +01:00
|
|
|
|
2015-02-28 01:11:56 +01:00
|
|
|
lua_newtable (L);
|
2015-02-27 16:55:46 +01:00
|
|
|
|
2015-02-28 01:11:56 +01:00
|
|
|
globbuf.gl_offs = 0;
|
|
|
|
len = strlen (dir) + sizeof ("/unit/") + sizeof ("*.lua");
|
|
|
|
pattern = g_malloc (len);
|
|
|
|
rspamd_snprintf (pattern, len, "%s/unit/%s", dir, "*.lua");
|
2015-02-27 16:55:46 +01:00
|
|
|
|
2018-09-19 16:42:38 +02:00
|
|
|
gint lua_test_len = 0;
|
|
|
|
gint inserted_file = 1;
|
|
|
|
gint path_start;
|
|
|
|
if (lua_test) {
|
|
|
|
lua_test_len = strlen (lua_test);
|
|
|
|
}
|
2015-02-28 01:11:56 +01:00
|
|
|
if (glob (pattern, GLOB_DOOFFS, NULL, &globbuf) == 0) {
|
|
|
|
for (i = 0; i < (gint)globbuf.gl_pathc; i++) {
|
2018-09-19 16:42:38 +02:00
|
|
|
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);
|
2015-02-28 01:11:56 +01:00
|
|
|
lua_pushstring (L, globbuf.gl_pathv[i]);
|
|
|
|
lua_settable (L, -3);
|
2018-09-19 16:42:38 +02:00
|
|
|
|
|
|
|
inserted_file ++;
|
2015-02-28 01:11:56 +01:00
|
|
|
}
|
|
|
|
globfree (&globbuf);
|
|
|
|
g_free (pattern);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
msg_err ("pattern %s doesn't match: %s", pattern,
|
|
|
|
strerror (errno));
|
|
|
|
g_assert (0);
|
2015-02-27 16:33:58 +01:00
|
|
|
}
|
2015-02-27 18:12:41 +01:00
|
|
|
|
2015-02-28 01:11:56 +01:00
|
|
|
lua_setglobal (L, "tests_list");
|
2017-05-18 17:32:26 +02:00
|
|
|
rspamd_lua_set_path (L, NULL, NULL);
|
2015-02-28 01:11:56 +01:00
|
|
|
|
|
|
|
lua_pushcfunction (L, traceback);
|
|
|
|
luaL_loadfile (L, rp);
|
2015-02-27 18:12:41 +01:00
|
|
|
|
2015-02-28 01:11:56 +01:00
|
|
|
if (lua_pcall (L, 0, 0, lua_gettop (L) - 1) != 0) {
|
|
|
|
msg_err ("run test failed: %s", lua_tostring (L, -1));
|
2015-02-27 16:33:58 +01:00
|
|
|
g_assert (0);
|
|
|
|
}
|
2015-02-27 18:12:41 +01:00
|
|
|
|
|
|
|
exit (EXIT_SUCCESS);
|
2015-02-27 16:33:58 +01:00
|
|
|
}
|