Fix dependencies for the unit tests

fixes #11832
This commit is contained in:
Gunnar Beutner 2016-05-24 13:37:14 +02:00
parent 7b371f20d8
commit 99735a5b2d
5 changed files with 128 additions and 94 deletions

View File

@ -23,13 +23,13 @@ set(base_test_SOURCES
base-serialize.cpp base-shellescape.cpp base-stacktrace.cpp base-serialize.cpp base-shellescape.cpp base-stacktrace.cpp
base-stream.cpp base-string.cpp base-timer.cpp base-type.cpp base-stream.cpp base-string.cpp base-timer.cpp base-type.cpp
base-value.cpp config-ops.cpp icinga-macros.cpp base-value.cpp config-ops.cpp icinga-macros.cpp
icinga-perfdata.cpp test.cpp icinga-perfdata.cpp base-test.cpp
remote-base64.cpp remote-url.cpp remote-base64.cpp remote-url.cpp
) )
set(livestatus_test_SOURCES set(livestatus_test_SOURCES
livestatus.cpp livestatus.cpp
test.cpp livestatus-test.cpp
) )
set_property(SOURCE test.cpp PROPERTY EXCLUDE_UNITY_BUILD TRUE) set_property(SOURCE test.cpp PROPERTY EXCLUDE_UNITY_BUILD TRUE)
@ -39,7 +39,7 @@ if(ICINGA2_UNITY_BUILD)
endif() endif()
add_boost_test(base add_boost_test(base
SOURCES test.cpp ${base_test_SOURCES} SOURCES base-test.cpp ${base_test_SOURCES}
LIBRARIES base config icinga LIBRARIES base config icinga
TESTS base_array/construct TESTS base_array/construct
base_array/getset base_array/getset
@ -117,8 +117,9 @@ add_boost_test(base
if(ICINGA2_WITH_LIVESTATUS) if(ICINGA2_WITH_LIVESTATUS)
add_boost_test(livestatus add_boost_test(livestatus
SOURCES test.cpp ${livestatus_test_SOURCES} SOURCES livestatus-test.cpp ${livestatus_test_SOURCES}
LIBRARIES base config icinga cli livestatus LIBRARIES base config icinga cli livestatus
DEPENDENCIES methods
TESTS livestatus/hosts livestatus/services TESTS livestatus/hosts livestatus/services
) )
endif() endif()

114
test/livestatus-test.cpp Normal file
View File

@ -0,0 +1,114 @@
/******************************************************************************
* Icinga 2 *
* Copyright (C) 2012-2016 Icinga Development Team (https://www.icinga.org/) *
* *
* This program is free software; you can redistribute it and/or *
* modify it under the terms of the GNU General Public License *
* as published by the Free Software Foundation; either version 2 *
* of the License, or (at your option) any later version. *
* *
* This program 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 General Public License for more details. *
* *
* You should have received a copy of the GNU General Public License *
* along with this program; if not, write to the Free Software Foundation *
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA. *
******************************************************************************/
#define BOOST_TEST_MAIN
#define BOOST_TEST_MODULE icinga2_test
#include "cli/daemonutility.hpp"
#include "config/configcompiler.hpp"
#include "config/configitem.hpp"
#include "base/application.hpp"
#include "base/loader.hpp"
#include <fstream>
#include <BoostTestTargetConfig.h>
using namespace icinga;
struct LivestatusFixture
{
LivestatusFixture(void)
: TestConfig("test-config.conf")
{
BOOST_TEST_MESSAGE("setup global config fixture");
Application::InitializeBase();
String cfg_file_path = TestConfig;
String cfg_file_path_tmp = TestConfig + ".tmp";
std::ofstream cfgfp;
cfgfp.open(cfg_file_path_tmp.CStr(), std::ofstream::out | std::ofstream::trunc);
cfgfp << std::fixed;
cfgfp << "object CheckCommand \"dummy\" {\n";
cfgfp << " execute = PluginCheck\n";
cfgfp << " command = \"/bin/echo\"\n";
cfgfp << "}\n";
cfgfp << "object Host \"test-01\" {\n";
cfgfp << " address = \"127.0.0.1\"\n";
cfgfp << " check_command = \"dummy\"\n";
cfgfp << "}\n";
cfgfp << "object Host \"test-02\" {\n";
cfgfp << " address = \"127.0.0.2\"\n";
cfgfp << " check_command = \"dummy\"\n";
cfgfp << "}\n";
cfgfp << "apply Service \"livestatus\"{\n";
cfgfp << " check_command = \"dummy\"\n";
cfgfp << " notes = \"test livestatus\"\n";
cfgfp << " assign where match(\"test-*\", host.name)\n";
cfgfp << "}\n";
cfgfp.close();
#ifdef _WIN32
_unlink(cfg_file_path.CStr());
#endif /* _WIN32 */
if (rename(cfg_file_path_tmp.CStr(), cfg_file_path.CStr()) < 0) {
BOOST_THROW_EXCEPTION(posix_error()
<< boost::errinfo_api_function("rename")
<< boost::errinfo_errno(errno)
<< boost::errinfo_file_name(cfg_file_path_tmp));
}
BOOST_TEST_MESSAGE( "Preparing config objects...");
/* start the Icinga application and load the configuration */
Application::DeclareSysconfDir("etc");
Application::DeclareLocalStateDir("var");
ActivationScope ascope;
Loader::LoadExtensionLibrary("icinga");
Loader::LoadExtensionLibrary("methods"); //loaded by ITL
std::vector<std::string> configs;
configs.push_back(TestConfig);
std::vector<ConfigItem::Ptr> newItems;
DaemonUtility::LoadConfigFiles(configs, newItems, "icinga2.debug", "icinga2.vars");
/* ignore config errors */
WorkQueue upq;
ConfigItem::ActivateItems(upq, newItems);
}
~LivestatusFixture(void)
{
BOOST_TEST_MESSAGE("cleanup global config fixture");
unlink(TestConfig.CStr());
Application::UninitializeBase();
}
String TestConfig;
};
BOOST_GLOBAL_FIXTURE(LivestatusFixture);

View File

@ -18,100 +18,13 @@
******************************************************************************/ ******************************************************************************/
#include "livestatus/livestatusquery.hpp" #include "livestatus/livestatusquery.hpp"
#include "config/configcompiler.hpp"
#include "config/configitem.hpp"
#include "base/application.hpp" #include "base/application.hpp"
#include "base/stdiostream.hpp" #include "base/stdiostream.hpp"
#include "base/json.hpp" #include "base/json.hpp"
#include "base/loader.hpp"
#include "cli/daemonutility.hpp"
#include <boost/test/unit_test.hpp> #include <boost/test/unit_test.hpp>
#include <fstream>
using namespace icinga; using namespace icinga;
struct GlobalConfigFixture {
GlobalConfigFixture()
: TestConfig("test-config.conf")
{
BOOST_TEST_MESSAGE("setup global config fixture");
String cfg_file_path = TestConfig;
String cfg_file_path_tmp = TestConfig + ".tmp";
std::ofstream cfgfp;
cfgfp.open(cfg_file_path_tmp.CStr(), std::ofstream::out | std::ofstream::trunc);
cfgfp << std::fixed;
cfgfp << "object CheckCommand \"dummy\" {\n";
cfgfp << " execute = PluginCheck\n";
cfgfp << " command = \"/bin/echo\"\n";
cfgfp << "}\n";
cfgfp << "object Host \"test-01\" {\n";
cfgfp << " address = \"127.0.0.1\"\n";
cfgfp << " check_command = \"dummy\"\n";
cfgfp << "}\n";
cfgfp << "object Host \"test-02\" {\n";
cfgfp << " address = \"127.0.0.2\"\n";
cfgfp << " check_command = \"dummy\"\n";
cfgfp << "}\n";
cfgfp << "apply Service \"livestatus\"{\n";
cfgfp << " check_command = \"dummy\"\n";
cfgfp << " notes = \"test livestatus\"\n";
cfgfp << " assign where match(\"test-*\", host.name)\n";
cfgfp << "}\n";
cfgfp.close();
#ifdef _WIN32
_unlink(cfg_file_path.CStr());
#endif /* _WIN32 */
if (rename(cfg_file_path_tmp.CStr(), cfg_file_path.CStr()) < 0) {
BOOST_THROW_EXCEPTION(posix_error()
<< boost::errinfo_api_function("rename")
<< boost::errinfo_errno(errno)
<< boost::errinfo_file_name(cfg_file_path_tmp));
}
BOOST_TEST_MESSAGE( "Preparing config objects...");
/* start the Icinga application and load the configuration */
Application::DeclareSysconfDir("etc");
Application::DeclareLocalStateDir("var");
ActivationScope ascope;
Loader::LoadExtensionLibrary("icinga");
Loader::LoadExtensionLibrary("methods"); //loaded by ITL
std::vector<std::string> configs;
configs.push_back(TestConfig);
std::vector<ConfigItem::Ptr> newItems;
DaemonUtility::LoadConfigFiles(configs, newItems, "icinga2.debug", "icinga2.vars");
/* ignore config errors */
WorkQueue upq;
ConfigItem::ActivateItems(upq, newItems);
}
~GlobalConfigFixture()
{
BOOST_TEST_MESSAGE("cleanup global config fixture");
unlink(TestConfig.CStr());
}
String TestConfig;
};
BOOST_GLOBAL_FIXTURE(GlobalConfigFixture);
struct LocalFixture {
LocalFixture() { }
~LocalFixture() { }
};
String LivestatusQueryHelper(const std::vector<String>& lines) String LivestatusQueryHelper(const std::vector<String>& lines)
{ {
LivestatusQuery::Ptr query = new LivestatusQuery(lines, ""); LivestatusQuery::Ptr query = new LivestatusQuery(lines, "");
@ -147,7 +60,7 @@ String LivestatusQueryHelper(const std::vector<String>& lines)
//____________________________________________________________________________// //____________________________________________________________________________//
BOOST_FIXTURE_TEST_SUITE(livestatus, LocalFixture) BOOST_AUTO_TEST_SUITE(livestatus)
BOOST_AUTO_TEST_CASE(hosts) BOOST_AUTO_TEST_CASE(hosts)
{ {

View File

@ -14,7 +14,8 @@
# [LAUNCHER <generic launcher script>] # [LAUNCHER <generic launcher script>]
# [LIBRARIES <library> [<library>...]] # [LIBRARIES <library> [<library>...]]
# [RESOURCES <resource> [<resource>...]] # [RESOURCES <resource> [<resource>...]]
# [TESTS <testcasename> [<testcasename>...]]) # [TESTS <testcasename> [<testcasename>...]]
# [DEPENDENCIES <dependency> [<dependency>...]])
# #
# If for some reason you need access to the executable target created, # If for some reason you need access to the executable target created,
# it can be found in ${${testdriver_name}_TARGET_NAME} as specified when # it can be found in ${${testdriver_name}_TARGET_NAME} as specified when
@ -116,7 +117,8 @@ function(add_boost_test _name)
LAUNCHER LAUNCHER
LIBRARIES LIBRARIES
RESOURCES RESOURCES
TESTS) TESTS
DEPENDENCIES)
set(_bool_args set(_bool_args
USE_COMPILED_LIBRARY) USE_COMPILED_LIBRARY)
foreach(_arg ${_val_args} ${_bool_args}) foreach(_arg ${_val_args} ${_bool_args})
@ -265,6 +267,10 @@ function(add_boost_test _name)
endif() endif()
endif() endif()
if (DEPENDENCIES)
add_dependencies(${_target_name} ${DEPENDENCIES})
endif()
# CppCheck the test if we can. # CppCheck the test if we can.
if(COMMAND add_cppcheck) if(COMMAND add_cppcheck)
add_cppcheck(${_target_name} STYLE UNUSED_FUNCTIONS) add_cppcheck(${_target_name} STYLE UNUSED_FUNCTIONS)