#ifndef TEST_TOOLS_H #define TEST_TOOLS_H /* * * Copyright (c) 2006 The Apache Software Foundation * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * */ #include "qpid/log/Logger.h" #include // Include before boost/test headers. #include #include #include #include #include #include // Print a sequence template std::ostream& seqPrint(std::ostream& o, const T& seq) { std::copy(seq.begin(), seq.end(), std::ostream_iterator(o, " ")); return o; } // Compare sequences template bool seqEqual(const T& a, const U& b) { typename T::const_iterator i = a.begin(); typename U::const_iterator j = b.begin(); while (i != a.end() && j != b.end() && *i == *j) { ++i; ++j; } return (i == a.end()) && (j == b.end()); } // ostream and == operators so we can compare vectors and boost::assign::list_of // with BOOST_CHECK_EQUALS namespace std { // In namespace std so boost can find them. template ostream& operator<<(ostream& o, const vector& v) { return seqPrint(o, v); } template ostream& operator<<(ostream& o, const boost::assign_detail::generic_list& l) { return seqPrint(o, l); } template bool operator == (const vector& a, const boost::assign_detail::generic_list& b) { return seqEqual(a, b); } template bool operator == (const boost::assign_detail::generic_list& b, const vector& a) { return seqEqual(a, b); } } /** NB: order of parameters is regex first, in line with * CHECK(expected, actual) convention. */ inline bool regexPredicate(const std::string& re, const std::string& text) { return boost::regex_match(text, boost::regex(re)); } /** Check for regular expression match. You must #include */ #if (BOOST_VERSION < 103300) #define BOOST_CHECK_REGEX(re, text) #else #define BOOST_CHECK_REGEX(re, text) \ BOOST_CHECK_PREDICATE(regexPredicate, (re)(text)) #endif /** Check if types of two objects (as given by typeinfo::name()) match. */ #define BOOST_CHECK_TYPEID_EQUAL(a,b) BOOST_CHECK_EQUAL(typeid(a).name(),typeid(b).name()) /** * Supress all logging in a scope, restore to previous configuration in destructor. */ struct ScopedSuppressLogging { typedef qpid::log::Logger Logger; ScopedSuppressLogging(Logger& l=Logger::instance()) : logger(l), opts(l.getOptions()) { l.clear(); } ~ScopedSuppressLogging() { logger.configure(opts); } Logger& logger; qpid::log::Options opts; }; #endif /*!TEST_TOOLS_H*/