X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=src%2Ftest_filter_frontend_net.cpp;h=9eaf40a0c4581d1b274239988f06e7ad55306e36;hb=b80f4b3d531f36265ea46d337cb7e1000604cafb;hp=f5ea15a6bb549b4a93f15ebb0550217b9c2f24e1;hpb=57c1c4822f1de4d983c1aee3bc6059ad2600d991;p=metaproxy-moved-to-github.git diff --git a/src/test_filter_frontend_net.cpp b/src/test_filter_frontend_net.cpp index f5ea15a..9eaf40a 100644 --- a/src/test_filter_frontend_net.cpp +++ b/src/test_filter_frontend_net.cpp @@ -1,96 +1,126 @@ +/* $Id: test_filter_frontend_net.cpp,v 1.15 2006-03-16 10:40:59 adam Exp $ + Copyright (c) 2005-2006, Index Data. + +%LICENSE% + */ #include "config.hpp" #include #include -#include "router.hpp" +#include "util.hpp" +#include "filter_frontend_net.hpp" + +#include "router_chain.hpp" #include "session.hpp" #include "package.hpp" -#include "filter_frontend_net.hpp" #define BOOST_AUTO_TEST_MAIN #include using namespace boost::unit_test; +namespace mp = metaproxy_1; -class FilterInit: public yp2::Filter { +class FilterInit: public mp::filter::Base { public: - yp2::Package & process(yp2::Package & package) const { - ODR odr = odr_createmem(ODR_ENCODE); - Z_APDU *apdu = zget_APDU(odr, Z_APDU_initResponse); - - apdu->u.initResponse->implementationName = "YP2/YAZ"; - - package.response() = apdu; - odr_destroy(odr); - return package.move(); + void process(mp::Package & package) const { + + if (package.session().is_closed()) + { + // std::cout << "Got Close.\n"; + } + + Z_GDU *gdu = package.request().get(); + if (gdu) + { + // std::cout << "Got PDU. Sending init response\n"; + mp::odr odr; + Z_APDU *apdu = zget_APDU(odr, Z_APDU_initResponse); + + apdu->u.initResponse->implementationName = "YP2/YAZ"; + + package.response() = apdu; + } + return package.move(); }; }; -BOOST_AUTO_TEST_CASE( test_filter_frontend_net_1 ) +BOOST_AUTO_UNIT_TEST( test_filter_frontend_net_1 ) { try { { - yp2::FilterFrontendNet nf; + mp::filter::FrontendNet nf; } - BOOST_CHECK(true); } catch ( ... ) { BOOST_CHECK (false); } } -BOOST_AUTO_TEST_CASE( test_filter_frontend_net_2 ) +BOOST_AUTO_UNIT_TEST( test_filter_frontend_net_2 ) { try { { - yp2::RouterChain router; + mp::RouterChain router; FilterInit tf; - router.rule(tf); + router.append(tf); - yp2::Session session; - yp2::Origin origin; - yp2::Package pack_in(session, origin); - - pack_in.router(router).move(); + // Create package with Z39.50 init request in it + mp::Package pack; - yazpp_1::GDU *gdu = &pack_in.response(); + mp::odr odr; + Z_APDU *apdu = zget_APDU(odr, Z_APDU_initRequest); + + pack.request() = apdu; + // Done creating query. - BOOST_CHECK_EQUAL(gdu->get()->which, Z_GDU_Z3950); - BOOST_CHECK_EQUAL(gdu->get()->u.z3950->which, Z_APDU_initResponse); + // Put it in router + pack.router(router).move(); + + // Inspect that we got Z39.50 init response + yazpp_1::GDU *gdu = &pack.response(); + + Z_GDU *z_gdu = gdu->get(); + BOOST_CHECK(z_gdu); + if (z_gdu) { + BOOST_CHECK_EQUAL(z_gdu->which, Z_GDU_Z3950); + BOOST_CHECK_EQUAL(z_gdu->u.z3950->which, Z_APDU_initResponse); + } } - BOOST_CHECK(true); } catch ( ... ) { BOOST_CHECK (false); } } -BOOST_AUTO_TEST_CASE( test_filter_frontend_net_3 ) +BOOST_AUTO_UNIT_TEST( test_filter_frontend_net_3 ) { try { { - yp2::RouterChain router; + mp::RouterChain router; + + // put in frontend first + mp::filter::FrontendNet filter_front; - yp2::FilterFrontendNet filter_front; - filter_front.listen_address() = "unix:socket"; - filter_front.listen_duration() = 2; // listen a short time only - router.rule(filter_front); + std::vector ports; + ports.insert(ports.begin(), "unix:socket"); + filter_front.ports() = ports; + filter_front.listen_duration() = 1; // listen a short time only + router.append(filter_front); + // put in a backend FilterInit filter_init; - router.rule(filter_init); + router.append(filter_init); - yp2::Session session; - yp2::Origin origin; - yp2::Package pack_in(session, origin); + mp::Package pack; - pack_in.router(router).move(); + pack.router(router).move(); } BOOST_CHECK(true); } @@ -103,6 +133,7 @@ BOOST_AUTO_TEST_CASE( test_filter_frontend_net_3 ) * Local variables: * c-basic-offset: 4 * indent-tabs-mode: nil + * c-file-style: "stroustrup" * End: * vim: shiftwidth=4 tabstop=8 expandtab */