X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=senf%2FUtils%2FLogger%2FLog.test.cc;fp=senf%2FUtils%2FLogger%2FLog.test.cc;h=64e6df59b3250e988f5b6af12cbba9c542ad509f;hb=601d1f509f5bb24df167a4dd5a20da67a0af9af8;hp=0000000000000000000000000000000000000000;hpb=164fe477094d42463722584e527a02379ab5d985;p=senf.git diff --git a/senf/Utils/Logger/Log.test.cc b/senf/Utils/Logger/Log.test.cc new file mode 100644 index 0000000..64e6df5 --- /dev/null +++ b/senf/Utils/Logger/Log.test.cc @@ -0,0 +1,98 @@ +// $Id$ +// +// 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 +// it under the terms of the GNU General Public License as published by +// the Free Software Foundation; either version 2 of the License, or +// (at your option) any later version. +// +// This program 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., +// 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. + +/** \file + \brief Log unit tests */ + +//#include "Log.test.hh" +//#include "Log.test.ih" + +// Custom includes +#include "main.test.hh" + +#include "../../Utils/auto_unit_test.hh" +#include + +#define prefix_ +///////////////////////////////cc.p//////////////////////////////////////// + +BOOST_AUTO_UNIT_TEST(logger) +{ + senf::log::StringTarget target; + + target.route(); + + // We cannot easily check the exact log string since that includes the current date/time + + SENF_LOG_DEFAULT_STREAM(senf::log::Debug); + SENF_LOG_DEFAULT_AREA(senf::log::DefaultArea); + SENF_LOG_DEFAULT_LEVEL(senf::log::VERBOSE); + + SENF_LOG(("Log message")); + BOOST_CHECK( target.str().empty() ); + target.clear(); + + SENF_LOG((senf::log::VERBOSE)("Log message 2")); + BOOST_CHECK( target.str().empty() ); + target.clear(); + + SENF_LOG((senf::log::IMPORTANT)("Important message")); + std::cerr << target.str(); + BOOST_CHECK( ! target.str().empty() ); + target.clear(); + + SENF_LOG((senf::log::test::LogCritical) ("Another log message: " << 10)); + std::cerr << target.str(); + BOOST_CHECK( ! target.str().empty() ); + target.clear(); + + SENF_LOG_BLOCK((senf::log::Debug) (senf::log::IMPORTANT) ({ + log << "Last message"; + log << " continued here"; + })); + std::cerr << target.str(); + BOOST_CHECK( ! target.str().empty() ); + target.clear(); + + senf::log::test::Foo::log(); + std::cerr << target.str(); + BOOST_CHECK( ! target.str().empty() ); + target.clear(); + + SENF_LOG((senf::log::test::Foo)("Foo area")); + BOOST_CHECK( target.str().empty() ); + target.clear(); +} + +///////////////////////////////cc.e//////////////////////////////////////// +#undef prefix_ + + +// Local Variables: +// mode: c++ +// fill-column: 100 +// c-file-style: "senf" +// indent-tabs-mode: nil +// ispell-local-dictionary: "american" +// compile-command: "scons -u test" +// comment-column: 40 +// End: