X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Utils%2FException.test.cc;h=0f0db829c1022ef40ac81b52cbd2e8751a970cbe;hb=532240d72e09e19e57fac9bb55c2560b9c9e5b97;hp=50e3c97712a7e00afc4c696d7edd4e8e60356c77;hpb=34378cabd0ef59515f60b8e535d50fd5488c84e2;p=senf.git diff --git a/Utils/Exception.test.cc b/Utils/Exception.test.cc index 50e3c97..0f0db82 100644 --- a/Utils/Exception.test.cc +++ b/Utils/Exception.test.cc @@ -1,8 +1,8 @@ // $Id$ // -// Copyright (C) 2007 -// Fraunhofer Institut fuer offene Kommunikationssysteme (FOKUS) -// Kompetenzzentrum fuer Satelitenkommunikation (SatCom) +// Copyright (C) 2007 +// Fraunhofer Institute for Open Communication Systems (FOKUS) +// Competence Center NETwork research (NET), St. Augustin, GERMANY // Stefan Bund // // This program is free software; you can redistribute it and/or modify @@ -21,41 +21,75 @@ // 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. /** \file - \brief Exception.test unit tests */ + \brief Exception unit tests */ //#include "Exception.test.hh" //#include "Exception.test.ih" // Custom includes #include "Exception.hh" +#include +#include #include "../Utils/auto_unit_test.hh" #include -#include -#include #define prefix_ ///////////////////////////////cc.p//////////////////////////////////////// -BOOST_AUTO_UNIT_TEST(errnoException) +BOOST_AUTO_UNIT_TEST(wrapException) { - BOOST_CHECK_THROW( senf::throwErrno(), senf::SystemException ); - BOOST_CHECK_THROW( senf::throwErrno(ENOENT), senf::SystemException ); - BOOST_CHECK_THROW( senf::throwErrno(""), senf::SystemException ); - BOOST_CHECK_THROW( senf::throwErrno("", ENOENT), senf::SystemException ); + bool bad_cast (false); + + try { + try { + try { + try { + try { + throw std::bad_cast(); + } + SENF_WRAP_EXC(std::bad_cast) + } + SENF_WRAP_EXC(std::bad_cast) + } + catch (senf::ExceptionMixin & ex) { + ex << "\nspecial exception"; + throw; + } + } + catch (std::exception const & ex) { +#ifdef SENF_DEBUG + BOOST_CHECK( std::string(ex.what()).find("-- \n") != std::string::npos ); +#endif + BOOST_CHECK( std::string(ex.what()).find("special exception") != std::string::npos ); + throw; + } + } + catch (std::bad_cast &) { + bad_cast = true; + } + BOOST_CHECK( bad_cast ); +} +BOOST_AUTO_UNIT_TEST(errnoException) +{ try { try { - senf::throwErrno("::open()", ENOENT); + throw senf::SystemException("::open()", ENOENT) << "\nmore"; } - catch(senf::SystemException & e) { - e << ": x=" << 1 << boost::format(", y=%d") % 2; + catch(senf::Exception & e) { + e << "\nx=" << 1 << boost::format("\ny=%d") % 2; throw; } } catch (senf::SystemException & e) { - BOOST_CHECK_EQUAL( e.code(), ENOENT ); - BOOST_CHECK_EQUAL( e.what(), "::open(): (2) No such file or directory: x=1, y=2" ); + BOOST_CHECK_EQUAL( e.errorNumber(), ENOENT ); + BOOST_CHECK_EQUAL( e.errorString(), "No such file or directory" ); + std::string what (e.what()); + std::string::size_type pos (what.find("-- \n")); + if (pos != std::string::npos) + what = std::string(what, pos+4); + BOOST_CHECK_EQUAL( what, "[No such file or directory] ::open()\nmore\nx=1\ny=2" ); } }