From 65bb386107c535d639e5aa9de60d7cc6fbbdd39f Mon Sep 17 00:00:00 2001 From: randomdan Date: Tue, 4 Nov 2014 20:42:34 +0000 Subject: Add beginnings of UT toolkit and a few tiny UTs over the ice client/compiler --- project2/common/optionsSource.cpp | 12 ++++++++++++ project2/common/optionsSource.h | 5 ++++- project2/common/plugable.cpp | 8 ++++++++ project2/common/plugable.h | 2 +- project2/daemon/p2daemonAppEngine.cpp | 2 +- project2/ice/Jamfile.jam | 24 ++++++++++++++++++++++++ project2/ice/test.ice | 9 +++++++++ project2/ice/testClient.cpp | 32 ++++++++++++++++++++++++++++++++ project2/ut/Jamfile.jam | 12 ++++++++++++ project2/ut/testOptionsSource.cpp | 30 ++++++++++++++++++++++++++++++ project2/ut/testOptionsSource.h | 22 ++++++++++++++++++++++ 11 files changed, 155 insertions(+), 3 deletions(-) create mode 100644 project2/common/plugable.cpp create mode 100644 project2/ice/test.ice create mode 100644 project2/ice/testClient.cpp create mode 100644 project2/ut/Jamfile.jam create mode 100644 project2/ut/testOptionsSource.cpp create mode 100644 project2/ut/testOptionsSource.h diff --git a/project2/common/optionsSource.cpp b/project2/common/optionsSource.cpp index 58c9b1f..85aebb1 100644 --- a/project2/common/optionsSource.cpp +++ b/project2/common/optionsSource.cpp @@ -43,5 +43,17 @@ OptionsSource::loadSources(const Options::CurrentPlatform & platform) } } +void +OptionsSource::loadSource(const Options::CurrentPlatform & platform, OptionsSourcePtr opts) +{ + InstanceSet::OnAll(boost::bind(&Options::reset, _1)); + + DefaultConfigConsumer dcc; + opts->loadInto(dcc, platform); + Plugable::onAllComponents(boost::bind(&ComponentLoader::onConfigLoad, _1)); + + Logger()->message(LOG_DEBUG, "Loaded configuration"); +} + INSTANTIATESTORE(std::string, OptionsSource); diff --git a/project2/common/optionsSource.h b/project2/common/optionsSource.h index 97a3566..6cfbce9 100644 --- a/project2/common/optionsSource.h +++ b/project2/common/optionsSource.h @@ -13,6 +13,9 @@ class ConfigConsumer { virtual const Options::Option * get(const Glib::ustring & name) const = 0; }; +class OptionsSource; +typedef boost::shared_ptr OptionsSourcePtr; + /// Base class of things that load options class OptionsSource { public: @@ -20,8 +23,8 @@ class OptionsSource { virtual bool needReload() const = 0; static void loadSources(const Options::CurrentPlatform & platform); + static void loadSource(const Options::CurrentPlatform & platform, OptionsSourcePtr opts); }; -typedef boost::intrusive_ptr OptionsSourcePtr; typedef PluginsSameBase OptionsSources; #define DECLARE_OPTIONSSOURCE(Id, Inst) \ diff --git a/project2/common/plugable.cpp b/project2/common/plugable.cpp new file mode 100644 index 0000000..83d0cc5 --- /dev/null +++ b/project2/common/plugable.cpp @@ -0,0 +1,8 @@ +#include "plugable.h" + +void +Plugable::onAllComponents(const boost::function & func, bool coe) +{ + InstanceSet::OnAll(func, coe); +} + diff --git a/project2/common/plugable.h b/project2/common/plugable.h index af7f91f..ce3439a 100644 --- a/project2/common/plugable.h +++ b/project2/common/plugable.h @@ -10,7 +10,7 @@ class ComponentLoader; class Plugable : public InstanceSet { public: - static void onAllComponents(const boost::function & func) { InstanceSet::OnAll(func, true); } + static void onAllComponents(const boost::function & func, bool coe = false); }; /// All loaders, keyed by string, enum, int, etc diff --git a/project2/daemon/p2daemonAppEngine.cpp b/project2/daemon/p2daemonAppEngine.cpp index b48b75b..7a1c602 100644 --- a/project2/daemon/p2daemonAppEngine.cpp +++ b/project2/daemon/p2daemonAppEngine.cpp @@ -120,7 +120,7 @@ bool DaemonAppEngine::periodicCallback() { Logger()->messagebf(LOG_DEBUG, "%s: firing component periodics.", __PRETTY_FUNCTION__); - Plugable::onAllComponents(boost::bind(&ComponentLoader::onPeriodic, _1)); + Plugable::onAllComponents(boost::bind(&ComponentLoader::onPeriodic, _1), true); return true; } diff --git a/project2/ice/Jamfile.jam b/project2/ice/Jamfile.jam index 1376c34..d6cf16f 100644 --- a/project2/ice/Jamfile.jam +++ b/project2/ice/Jamfile.jam @@ -1,3 +1,5 @@ +import testing ; + alias glibmm : : : : "`pkg-config --cflags glibmm-2.4`" "`pkg-config --libs glibmm-2.4`" @@ -33,6 +35,7 @@ lib p2iceclient : pthread : : p2ice + ../common//p2common ; lib p2icedaemon : @@ -68,3 +71,24 @@ lib p2ice : IceUtil boost_filesystem ; + +lib test : + test.ice + : + Ice + IceUtil + pthread + ; + +unit-test testClient : + [ glob testClient.cpp ] + : + test.ice + p2iceclient + ../ut//p2ut + ../basics//p2basics + Ice + IceUtil + boost_filesystem + ; + diff --git a/project2/ice/test.ice b/project2/ice/test.ice new file mode 100644 index 0000000..3c18999 --- /dev/null +++ b/project2/ice/test.ice @@ -0,0 +1,9 @@ +module test { + interface a + { + ["project2:task"] + void someTask(); + + }; +}; + diff --git a/project2/ice/testClient.cpp b/project2/ice/testClient.cpp new file mode 100644 index 0000000..d7256ae --- /dev/null +++ b/project2/ice/testClient.cpp @@ -0,0 +1,32 @@ +#define BOOST_TEST_MODULE Client +#include +#include +#include "iceClient.h" +#include + +const auto self = boost::filesystem::canonical("/proc/self/exe"); +const Glib::ustring testPlatform; + +BOOST_AUTO_TEST_CASE( compile_client_full ) +{ + const std::string tmpdir = "/tmp/ut/project2.slice/full"; + boost::filesystem::remove_all(tmpdir); + + TestOptionsSource::LoadTestOptions({ + { "ice.compile.tmpdir", tmpdir }, + { "ice.client.slice", "test.ice" } + }); +} + +BOOST_AUTO_TEST_CASE( compile_client_clientOnly ) +{ + const std::string tmpdir = "/tmp/ut/project2.slice/clientOnly"; + boost::filesystem::remove_all(tmpdir); + + TestOptionsSource::LoadTestOptions({ + { "library", (self.parent_path() / "libtest.so").string() }, + { "ice.compile.tmpdir", tmpdir }, + { "ice.client.sliceclient", "test.ice" } + }); +} + diff --git a/project2/ut/Jamfile.jam b/project2/ut/Jamfile.jam new file mode 100644 index 0000000..0c7aa08 --- /dev/null +++ b/project2/ut/Jamfile.jam @@ -0,0 +1,12 @@ +lib boost_utf : : boost_unit_test_framework ; + +lib p2ut : + [ glob *.cpp ] + : + ../common//p2common + : : + BOOST_TEST_DYN_LINK + boost_utf + . + ; + diff --git a/project2/ut/testOptionsSource.cpp b/project2/ut/testOptionsSource.cpp new file mode 100644 index 0000000..59dc882 --- /dev/null +++ b/project2/ut/testOptionsSource.cpp @@ -0,0 +1,30 @@ +#include "testOptionsSource.h" + +const Glib::ustring testPlatform; + +TestOptionsSource::TestOptionsSource(const Opts & o) : + opts(o) +{ +} + +void +TestOptionsSource::loadInto(const ConfigConsumer & consume, const Options::CurrentPlatform & platform) const +{ + BOOST_FOREACH(const auto & opt, opts) { + consume(opt.first, testPlatform, opt.second, platform); + } +} + +bool +TestOptionsSource::needReload() const +{ + return true; +} + +void +TestOptionsSource::LoadTestOptions(const Opts & o) +{ + OptionsSource::loadSource(boost::bind([]{ return testPlatform; }), + OptionsSourcePtr(new TestOptionsSource(o))); +} + diff --git a/project2/ut/testOptionsSource.h b/project2/ut/testOptionsSource.h new file mode 100644 index 0000000..9bc2101 --- /dev/null +++ b/project2/ut/testOptionsSource.h @@ -0,0 +1,22 @@ +#ifndef P2_TEST_OPTIONSSOURCE_H +#define P2_TEST_OPTIONSSOURCE_H + +#include + +class TestOptionsSource : public OptionsSource { + public: + typedef std::list> Opts; + + void loadInto(const ConfigConsumer & consume, const Options::CurrentPlatform & platform) const override; + bool needReload() const override; + + static void LoadTestOptions(const Opts & o); + + private: + TestOptionsSource(const Opts & o); + + const Opts opts; +}; + +#endif + -- cgit v1.2.3