libhydra: Move kernel interface to libcharon
[strongswan.git] / src / libhydra / tests / hydra_tests.c
1 /*
2 * Copyright (C) 2014 Tobias Brunner
3 * Hochschule fuer Technik Rapperswil
4 *
5 * This program is free software; you can redistribute it and/or modify it
6 * under the terms of the GNU General Public License as published by the
7 * Free Software Foundation; either version 2 of the License, or (at your
8 * option) any later version. See <http://www.fsf.org/copyleft/gpl.txt>.
9 *
10 * This program is distributed in the hope that it will be useful, but
11 * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
12 * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
13 * for more details.
14 */
15
16 #include <test_runner.h>
17 #include <hydra.h>
18
19 /* declare test suite constructors */
20 #define TEST_SUITE(x) test_suite_t* x();
21 #define TEST_SUITE_DEPEND(x, ...) TEST_SUITE(x)
22 #include "hydra_tests.h"
23 #undef TEST_SUITE
24 #undef TEST_SUITE_DEPEND
25
26 static test_configuration_t tests[] = {
27 #define TEST_SUITE(x) \
28 { .suite = x, },
29 #define TEST_SUITE_DEPEND(x, type, ...) \
30 { .suite = x, .feature = PLUGIN_DEPENDS(type, __VA_ARGS__) },
31 #include "hydra_tests.h"
32 { .suite = NULL, }
33 };
34
35 static bool test_runner_init(bool init)
36 {
37 if (init)
38 {
39 libhydra_init();
40 }
41 else
42 {
43 lib->processor->set_threads(lib->processor, 0);
44 lib->processor->cancel(lib->processor);
45 libhydra_deinit();
46 }
47 return TRUE;
48 }
49
50 int main(int argc, char *argv[])
51 {
52 return test_runner_run("libhydra", tests, test_runner_init);
53 }