1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136
|
/*
* Copyright (C) 2020 Linux Studio Plugins Project <https://lsp-plug.in/>
* (C) 2020 Vladimir Sadovnikov <sadko4u@gmail.com>
*
* This file is part of lsp-test-fw
* Created on: 22 мар. 2020 г.
*
* lsp-test-fw is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* any later version.
*
* lsp-test-fw is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with lsp-test-fw. If not, see <https://www.gnu.org/licenses/>.
*/
#ifndef LSP_PLUG_IN_TEST_FW_INIT_H_
#define LSP_PLUG_IN_TEST_FW_INIT_H_
#include <lsp-plug.in/test-fw/version.h>
#include <lsp-plug.in/test-fw/env.h>
#include <lsp-plug.in/test-fw/main/dynarray.h>
#define INIT_BEGIN(name) \
namespace lsp { \
namespace test_init { \
namespace { \
\
using namespace ::lsp::test; \
\
class init_ ## name: public Initializer { \
private: \
init_ ## name & operator = (const init_ ## name &); \
\
public: \
typedef init_ ## name init_type_t;\
\
public: \
\
_Pragma("GCC diagnostic push") \
_Pragma("GCC diagnostic ignored \"-Wuninitialized\"") \
explicit init_ ## name() : Initializer(#name) {} \
_Pragma("GCC diagnostic pop") \
\
virtual ~init_ ## name() {}
#define INIT_FUNC virtual void initialize()
#define INFO_FUNC virtual void info()
#define FINI_FUNC virtual void finalize()
#define BEFORE_FUNC virtual void before(const char *test, test_mode_t type)
#define AFTER_FUNC virtual void after(const char *test, test_mode_t type)
#define INIT_END \
} initializer; /* initializer class */ \
} /* anonymous namespace */ \
} /* namespace test_init */ \
} /* namespace lsp */
namespace lsp
{
namespace test
{
/**
* Test initializer base class
*/
class LSP_TEST_FW_PUBLIC Initializer: public Environment
{
private:
Initializer & operator = (const Initializer &);
private:
friend test_status_t init_init(dynarray_t *list);
private:
static Initializer *__root;
Initializer *__next;
const char *__name;
public:
explicit Initializer(const char *name);
virtual ~Initializer();
public:
inline const char *full_name() const { return __name; };
public:
/** Call an initializer function at test start
* This function is executed once at process start.
*
* This function can be used to initialize global state of program
* before the target test will be called.
*
* IMPORTANT: Since different operating systems provide different
* Inter-process-communication, don't consider that this
* function will start only once for the whole test lifecycle.
*
*/
virtual void initialize();
/**
* Output additional info if required
*/
virtual void info();
/**
* Call a finalizer function at test end
*
* IMPORTANT: Since different operating systems provide different
* Inter-process-communication, don't consider that this
* function will start only once for the whole test lifecycle.
*/
virtual void finalize();
/**
* Call function before each test
* @param test fully-qualified test name
* @param type type of test
*/
virtual void before(const char *test, test_mode_t type);
/**
* Call function after each test
* @param test fully-qualified test name
* @param type type of test
*/
virtual void after(const char *test, test_mode_t type);
};
}
}
#endif /* LSP_PLUG_IN_TEST_FW_INIT_H_ */
|