X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=src%2Ftest_filter_log.cpp;h=38881e27e467720885b7d5dc29e9c9479801fe7d;hb=586d78659d671683f33ec55f4a7d32b28e345ccd;hp=d8969957e6e391a75555d2f31cfcbeabecfe65bc;hpb=474111be67deb87130a5f0add13df89c89df346a;p=metaproxy-moved-to-github.git diff --git a/src/test_filter_log.cpp b/src/test_filter_log.cpp index d896995..38881e2 100644 --- a/src/test_filter_log.cpp +++ b/src/test_filter_log.cpp @@ -1,54 +1,65 @@ -/* $Id: test_filter_log.cpp,v 1.7 2005-10-31 09:40:18 marc Exp $ - Copyright (c) 2005, Index Data. +/* This file is part of Metaproxy. + Copyright (C) Index Data -%LICENSE% - */ +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 this program; if not, write to the Free Software +Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA +*/ #include "config.hpp" #include #include #include "filter_log.hpp" -#include "util.hpp" -#include "router_chain.hpp" -#include "session.hpp" -#include "package.hpp" +#include +#include +#include #define BOOST_AUTO_TEST_MAIN +#define BOOST_TEST_DYN_LINK #include using namespace boost::unit_test; +namespace mp = metaproxy_1; -class FilterBounceInit: public yp2::filter::Base { +class FilterBounceInit: 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"; } - + Z_GDU *gdu = package.request().get(); - if (gdu) + if (gdu && gdu->which == Z_GDU_Z3950) { // std::cout << "Got PDU. Sending init response\n"; - yp2::odr odr; - Z_APDU *apdu = zget_APDU(odr, Z_APDU_initResponse); - - apdu->u.initResponse->implementationName = "YP2/YAZ"; - + mp::odr odr; + Z_APDU *apdu = odr.create_initResponse(gdu->u.z3950, 0, 0); package.response() = apdu; } return package.move(); }; + void configure(const xmlNode* ptr, bool test_only, const char *path) {}; }; BOOST_AUTO_TEST_CASE( test_filter_log_1 ) { - try + try { - yp2::filter::Log lf; + mp::filter::Log lf; } catch ( ... ) { BOOST_CHECK (false); @@ -57,31 +68,31 @@ BOOST_AUTO_TEST_CASE( test_filter_log_1 ) BOOST_AUTO_TEST_CASE( test_filter_log_2 ) { - try + try { - yp2::RouterChain router; - - yp2::filter::Log lf; + mp::RouterChain router; + + mp::filter::Log lf; FilterBounceInit bf; - + router.append(lf); router.append(bf); - + // Create package with Z39.50 init request in it - yp2::Package pack; - - yp2::odr odr; + mp::Package pack; + + mp::odr odr; Z_APDU *apdu = zget_APDU(odr, Z_APDU_initRequest); - + pack.request() = apdu; - // Done creating query. - + // Done creating query. + // Put it in router - pack.router(router).move(); - + 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) { @@ -97,8 +108,9 @@ BOOST_AUTO_TEST_CASE( test_filter_log_2 ) /* * Local variables: * c-basic-offset: 4 + * c-file-style: "Stroustrup" * indent-tabs-mode: nil - * c-file-style: "stroustrup" * End: * vim: shiftwidth=4 tabstop=8 expandtab */ +