X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=src%2Ftest_filter_frontend_net.cpp;h=49001d708a8c5ce409c8a94ff03331314e898c97;hb=489bd9188aed44d93c29f996311e0477152d592a;hp=f61694128dab1751ecee1b0b9fe3d863879a7e35;hpb=85189f2d04df4cfc8b16ee78187fb89d00dfe3ff;p=metaproxy-moved-to-github.git diff --git a/src/test_filter_frontend_net.cpp b/src/test_filter_frontend_net.cpp index f616941..49001d7 100644 --- a/src/test_filter_frontend_net.cpp +++ b/src/test_filter_frontend_net.cpp @@ -1,7 +1,5 @@ -/* $Id: test_filter_frontend_net.cpp,v 1.20 2008-02-20 15:07:53 adam Exp $ - Copyright (c) 2005-2007, Index Data. - -This file is part of Metaproxy. +/* This file is part of Metaproxy. + Copyright (C) 2005-2013 Index Data 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 @@ -14,26 +12,19 @@ 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.20 2008-02-20 15:07:53 adam Exp $ - Copyright (c) 2005-2007, Index Data. - - See the LICENSE file for details - */ +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 "util.hpp" +#include #include "filter_frontend_net.hpp" -#include "router_chain.hpp" -#include "session.hpp" -#include "package.hpp" +#include +#include #define BOOST_AUTO_TEST_MAIN #define BOOST_TEST_DYN_LINK @@ -45,36 +36,38 @@ namespace mp = metaproxy_1; class FilterInit: public mp::filter::Base { public: 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"; mp::odr odr; - Z_APDU *apdu = zget_APDU(odr, Z_APDU_initResponse); - - apdu->u.initResponse->implementationName = "YP2/YAZ"; - + 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_frontend_net_1 ) { - try + try { { mp::filter::FrontendNet nf; } } + catch (std::runtime_error &e) { + std::cerr << "std::runtime error: " << e.what() << std::endl; + BOOST_CHECK(false); + } catch ( ... ) { BOOST_CHECK (false); } @@ -82,7 +75,7 @@ BOOST_AUTO_TEST_CASE( test_filter_frontend_net_1 ) BOOST_AUTO_TEST_CASE( test_filter_frontend_net_2 ) { - try + try { { mp::RouterChain router; @@ -96,12 +89,12 @@ BOOST_AUTO_TEST_CASE( test_filter_frontend_net_2 ) 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(); @@ -114,6 +107,10 @@ BOOST_AUTO_TEST_CASE( test_filter_frontend_net_2 ) } } } + catch (std::runtime_error &e) { + std::cerr << "std::runtime error: " << e.what() << std::endl; + BOOST_CHECK(false); + } catch ( ... ) { BOOST_CHECK (false); } @@ -121,7 +118,7 @@ BOOST_AUTO_TEST_CASE( test_filter_frontend_net_2 ) BOOST_AUTO_TEST_CASE( test_filter_frontend_net_3 ) { - try + try { { mp::RouterChain router; @@ -140,11 +137,15 @@ BOOST_AUTO_TEST_CASE( test_filter_frontend_net_3 ) router.append(filter_init); mp::Package pack; - - pack.router(router).move(); + + pack.router(router).move(); } BOOST_CHECK(true); } + catch (std::runtime_error &e) { + std::cerr << "std::runtime error: " << e.what() << std::endl; + BOOST_CHECK(false); + } catch ( ... ) { BOOST_CHECK (false); } @@ -153,8 +154,9 @@ BOOST_AUTO_TEST_CASE( test_filter_frontend_net_3 ) /* * 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 */ +