X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=src%2Ftest_filter_factory.cpp;h=e08a2ff37f5086da112976756236ac1d76ee016c;hb=b70b9ec78f0ab1c3ed3b432de986159129a0e4ed;hp=2ab42af8452afab425a32ab7ad8a6495dd92cc7f;hpb=8a595f41f5eaaa7ef846a697cfe4466ea57d224a;p=metaproxy-moved-to-github.git diff --git a/src/test_filter_factory.cpp b/src/test_filter_factory.cpp index 2ab42af..e08a2ff 100644 --- a/src/test_filter_factory.cpp +++ b/src/test_filter_factory.cpp @@ -1,81 +1,123 @@ -/* $Id: test_filter_factory.cpp,v 1.2 2005-10-29 17:58:14 marc Exp $ - Copyright (c) 2005, Index Data. - -%LICENSE% - */ +/* $Id: test_filter_factory.cpp,v 1.15 2007-01-25 14:05:54 adam Exp $ + Copyright (c) 2005-2007, Index Data. + See the LICENSE file for details +*/ #include #include #include "config.hpp" #include "filter.hpp" -#include "filter_factory.hpp" +#include "package.hpp" +#include "factory_filter.hpp" #define BOOST_AUTO_TEST_MAIN #include using namespace boost::unit_test; +namespace mp = metaproxy_1; -class XFilter: public yp2::filter::Base { +// XFilter +class XFilter: public mp::filter::Base { public: - void process(yp2::Package & package) const {}; - std::string name(){ - return std::string("xfilter"); - } + void process(mp::Package & package) const; }; +void XFilter::process(mp::Package & package) const +{ + //package.data() = 1; +} -yp2::filter::Base* xfilter_creator(){ +static mp::filter::Base* xfilter_creator(){ return new XFilter; } - -class YFilter: public yp2::filter::Base { +// YFilter ... +class YFilter: public mp::filter::Base { public: - void process(yp2::Package & package) const {}; - std::string name(){ - return std::string("yfilter"); - } + void process(mp::Package & package) const; }; -yp2::filter::Base* yfilter_creator(){ - return new YFilter; +void YFilter::process(mp::Package & package) const +{ + //package.data() = 2; } +static mp::filter::Base* yfilter_creator(){ + return new YFilter; +} - -//int main(int argc, char **argv) -BOOST_AUTO_TEST_CASE( test_filter_factory_1 ) +BOOST_AUTO_UNIT_TEST( test_filter_factory_1 ) { try { - yp2::filter::FilterFactory ffactory; - - BOOST_CHECK_EQUAL(ffactory.add_creator("xfilter", xfilter_creator), - true); - BOOST_CHECK_EQUAL(ffactory.drop_creator("xfilter"), - true); - BOOST_CHECK_EQUAL(ffactory.add_creator("xfilter", xfilter_creator), - true); - BOOST_CHECK_EQUAL(ffactory.add_creator("yfilter", yfilter_creator), - true); + mp::FactoryFilter ffactory; - yp2::filter::Base* xfilter = ffactory.create("xfilter"); - yp2::filter::Base* yfilter = ffactory.create("yfilter"); + XFilter xf; + YFilter yf; + + const std::string xfid = "XFilter"; + const std::string yfid = "YFilter"; - //BOOST_CHECK_EQUAL(xfilter->name(), std::string("xfilter")); - //BOOST_CHECK_EQUAL(yfilter->name(), std::string("yfilter")); + BOOST_CHECK(ffactory.add_creator(xfid, xfilter_creator)); + BOOST_CHECK(ffactory.drop_creator(xfid)); + BOOST_CHECK(ffactory.add_creator(xfid, xfilter_creator)); + BOOST_CHECK(ffactory.add_creator(yfid, yfilter_creator)); - } + mp::filter::Base* xfilter = 0; + xfilter = ffactory.create(xfid); + mp::filter::Base* yfilter = 0; + yfilter = ffactory.create(yfid); + + BOOST_CHECK(0 != xfilter); + BOOST_CHECK(0 != yfilter); + + mp::Package pack; + xfilter->process(pack); + //BOOST_CHECK_EQUAL(pack.data(), 1); + + yfilter->process(pack); + //BOOST_CHECK_EQUAL(pack.data(), 2); + } catch ( ... ) { + throw; BOOST_CHECK (false); } - - std::exit(0); } +#if HAVE_DL_SUPPORT +#if HAVE_DLFCN_H +BOOST_AUTO_UNIT_TEST( test_filter_factory_2 ) +{ + try { + mp::FactoryFilter ffactory; + + const std::string id = "dl"; + + // first load + BOOST_CHECK(ffactory.add_creator_dl(id, ".libs")); + + // test double load + BOOST_CHECK(ffactory.add_creator_dl(id, ".libs")); + + mp::filter::Base* filter = 0; + filter = ffactory.create(id); + + BOOST_CHECK(0 != filter); + + mp::Package pack; + filter->process(pack); + //BOOST_CHECK_EQUAL(pack.data(), 42); // magic from filter_dl .. + } + catch ( ... ) { + throw; + BOOST_CHECK (false); + } +} +#endif +#endif /* * Local variables: