X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=src%2Ftest_filter_frontend_net.cpp;h=74f2c42869f5e3524b16dc4db5ab2aeb6987e0aa;hb=1c5e3c3f45380b6ad370fa7ba6c2b8239c21071c;hp=1c9b8c26d2fa279fc46fc8a474376f4e0f0f84bd;hpb=d50228aa34df04bcef967019f584437d058368d2;p=metaproxy-moved-to-github.git diff --git a/src/test_filter_frontend_net.cpp b/src/test_filter_frontend_net.cpp index 1c9b8c2..74f2c42 100644 --- a/src/test_filter_frontend_net.cpp +++ b/src/test_filter_frontend_net.cpp @@ -1,23 +1,51 @@ +/* $Id: test_filter_frontend_net.cpp,v 1.19 2007-11-02 17:47:41 adam Exp $ + Copyright (c) 2005-2007, Index Data. + +This file is part of Metaproxy. + +Metaproxy 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, or (at your option) any later +version. + +Metaproxy 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 Metaproxy; see the file LICENSE. If not, write to the +Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA +02111-1307, USA. + */ +/* $Id: test_filter_frontend_net.cpp,v 1.19 2007-11-02 17:47:41 adam Exp $ + Copyright (c) 2005-2007, Index Data. + + See the LICENSE file for details + */ #include "config.hpp" #include #include +#include "util.hpp" #include "filter_frontend_net.hpp" -#include "router.hpp" +#include "router_chain.hpp" #include "session.hpp" #include "package.hpp" #define BOOST_AUTO_TEST_MAIN +#define BOOST_TEST_DYN_LINK #include using namespace boost::unit_test; +namespace mp = metaproxy_1; -class FilterInit: public yp2::Filter { +class FilterInit: public mp::filter::Base { public: - void process(yp2::Package & package) const { - + void process(mp::Package & package) const { + if (package.session().is_closed()) { // std::cout << "Got Close.\n"; @@ -27,13 +55,12 @@ public: if (gdu) { // std::cout << "Got PDU. Sending init response\n"; - ODR odr = odr_createmem(ODR_ENCODE); + mp::odr odr; Z_APDU *apdu = zget_APDU(odr, Z_APDU_initResponse); apdu->u.initResponse->implementationName = "YP2/YAZ"; package.response() = apdu; - odr_destroy(odr); } return package.move(); }; @@ -45,7 +72,7 @@ BOOST_AUTO_TEST_CASE( test_filter_frontend_net_1 ) try { { - yp2::FilterFrontendNet nf; + mp::filter::FrontendNet nf; } } catch ( ... ) { @@ -58,20 +85,19 @@ BOOST_AUTO_TEST_CASE( test_filter_frontend_net_2 ) try { { - yp2::RouterChain router; + mp::RouterChain router; FilterInit tf; - router.rule(tf); + router.append(tf); // Create package with Z39.50 init request in it - yp2::Package pack; + mp::Package pack; - ODR odr = odr_createmem(ODR_ENCODE); + mp::odr odr; Z_APDU *apdu = zget_APDU(odr, Z_APDU_initRequest); pack.request() = apdu; - odr_destroy(odr); // Done creating query. // Put it in router @@ -98,19 +124,22 @@ BOOST_AUTO_TEST_CASE( test_filter_frontend_net_3 ) try { { - yp2::RouterChain router; + mp::RouterChain router; // put in frontend first - yp2::FilterFrontendNet filter_front; - filter_front.listen_address() = "unix:socket"; + mp::filter::FrontendNet 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.rule(filter_front); + router.append(filter_front); // put in a backend FilterInit filter_init; - router.rule(filter_init); + router.append(filter_init); - yp2::Package pack; + mp::Package pack; pack.router(router).move(); } @@ -125,6 +154,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 */