Annotation of embedaddon/strongswan/src/libstrongswan/tests/test_runner.h, revision 1.1.1.1

1.1       misho       1: /*
                      2:  * Copyright (C) 2013 Martin Willi
                      3:  * Copyright (C) 2013 revosec AG
                      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: /**
                     17:  * @defgroup libtest libtest
                     18:  *
                     19:  * @defgroup test_utils test_utils
                     20:  * @ingroup libtest
                     21:  *
                     22:  * @defgroup test_runner test_runner
                     23:  * @{ @ingroup libtest
                     24:  */
                     25: 
                     26: #ifndef TEST_RUNNER_H_
                     27: #define TEST_RUNNER_H_
                     28: 
                     29: #include "test_suite.h"
                     30: 
                     31: #include <plugins/plugin_feature.h>
                     32: 
                     33: typedef struct test_configuration_t test_configuration_t;
                     34: 
                     35: /**
                     36:  * Callback called before and after each test case to de-/initialize the
                     37:  * environment (e.g. to load plugins).  It is also called before and after the
                     38:  * test suites are loaded.
                     39:  *
                     40:  * It is called after libstrongswan has been initialized and likewise before it
                     41:  * gets deinitialized.
                     42:  *
                     43:  * @param init                 TRUE during initialization
                     44:  * @return                             FALSE if de-/init failed
                     45:  */
                     46: typedef bool (*test_runner_init_t)(bool init);
                     47: 
                     48: /**
                     49:  * Test configuration, suite constructor with plugin dependency
                     50:  */
                     51: struct test_configuration_t {
                     52: 
                     53:        /**
                     54:         * Constructor function to create suite.
                     55:         */
                     56:        test_suite_t *(*suite)();
                     57: 
                     58:        /**
                     59:         * Plugin feature this test suite depends on
                     60:         */
                     61:        plugin_feature_t feature;
                     62: };
                     63: 
                     64: /**
                     65:  * Run test configuration.
                     66:  *
                     67:  * The configs array must be terminated with a NULL element. The following
                     68:  * environment variables are currently supported:
                     69:  *
                     70:  * - TESTS_VERBOSITY: Numerical loglevel for debug log
                     71:  * - TESTS_STRONGSWAN_CONF: Specify a path to a custom strongswan.conf
                     72:  * - TESTS_PLUGINS: Specify an explicit list of plugins to load
                     73:  * - TESTS_RUNNERS: Run specific test runners only
                     74:  * - TESTS_SUITES: Run specific test suites only
                     75:  * - TESTS_SUITES_EXCLUDE: Don't run specific test suites
                     76:  * - TESTS_REDUCED_KEYLENGTHS: Test minimal keylengths for public key tests only
                     77:  *
                     78:  * Please note that TESTS_PLUGINS actually must be implemented by the init
                     79:  * callback function, as plugin loading is delegated.
                     80:  *
                     81:  * EXIT_SUCCESS is returned right away if TESTS_RUNNERS is defined but the name
                     82:  * passed to this function is not contained in it.
                     83:  *
                     84:  * @param name                 name of test runner
                     85:  * @param config               test suite constructors with dependencies
                     86:  * @param init_cb              init/deinit callback
                     87:  * @return                             test result, EXIT_SUCCESS if all tests passed
                     88:  */
                     89: int test_runner_run(const char *name, test_configuration_t config[],
                     90:                                        test_runner_init_t init_cb);
                     91: 
                     92: #endif /** TEST_RUNNER_H_ @}*/

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>