2004-02-15 02:58:56 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: wx/cppunit.h
|
|
|
|
// Purpose: wrapper header for CppUnit headers
|
|
|
|
// Author: Vadim Zeitlin
|
|
|
|
// Created: 15.02.04
|
|
|
|
// RCS-ID: $Id$
|
|
|
|
// Copyright: (c) 2004 Vadim Zeitlin
|
2005-05-04 18:57:50 +00:00
|
|
|
// Licence: wxWindows Licence
|
2004-02-15 02:58:56 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
#ifndef _WX_CPPUNIT_H_
|
|
|
|
#define _WX_CPPUNIT_H_
|
|
|
|
|
2004-04-11 20:59:26 +00:00
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
2004-02-15 02:58:56 +00:00
|
|
|
// using CPPUNIT_TEST() macro results in this warning, disable it as there is
|
|
|
|
// no other way to get rid of it and it's not very useful anyhow
|
|
|
|
#ifdef __VISUALC__
|
|
|
|
// typedef-name 'foo' used as synonym for class-name 'bar'
|
|
|
|
#pragma warning(disable:4097)
|
|
|
|
|
|
|
|
// unreachable code: we don't care about warnings in CppUnit headers
|
|
|
|
#pragma warning(disable:4702)
|
|
|
|
|
|
|
|
// 'id': identifier was truncated to 'num' characters in the debug info
|
|
|
|
#pragma warning(disable:4786)
|
|
|
|
#endif // __VISUALC__
|
|
|
|
|
2004-04-01 07:17:50 +00:00
|
|
|
#ifdef __BORLANDC__
|
|
|
|
#pragma warn -8022
|
|
|
|
#endif
|
2007-07-21 23:41:07 +00:00
|
|
|
|
2007-10-02 14:56:09 +00:00
|
|
|
#ifndef CPPUNIT_STD_NEED_ALLOCATOR
|
|
|
|
#define CPPUNIT_STD_NEED_ALLOCATOR 0
|
|
|
|
#endif
|
|
|
|
|
2005-05-01 20:04:47 +00:00
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Set the default format for the errors, which can be used by an IDE to jump
|
|
|
|
// to the error location. This default gets overridden by the cppunit headers
|
|
|
|
// for some compilers (e.g. VC++).
|
|
|
|
|
2007-07-21 23:41:07 +00:00
|
|
|
#ifndef CPPUNIT_COMPILER_LOCATION_FORMAT
|
2005-05-01 20:04:47 +00:00
|
|
|
#define CPPUNIT_COMPILER_LOCATION_FORMAT "%p:%l:"
|
|
|
|
#endif
|
2004-04-01 07:17:50 +00:00
|
|
|
|
2004-04-11 20:59:26 +00:00
|
|
|
|
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Include all needed cppunit headers.
|
|
|
|
//
|
|
|
|
|
2004-02-15 02:58:56 +00:00
|
|
|
#include "wx/beforestd.h"
|
|
|
|
#include <cppunit/extensions/TestFactoryRegistry.h>
|
|
|
|
#include <cppunit/ui/text/TestRunner.h>
|
|
|
|
#include <cppunit/TestCase.h>
|
|
|
|
#include <cppunit/extensions/HelperMacros.h>
|
2005-05-01 20:04:47 +00:00
|
|
|
#include <cppunit/CompilerOutputter.h>
|
2004-02-15 02:58:56 +00:00
|
|
|
#include "wx/afterstd.h"
|
|
|
|
|
2008-07-18 23:33:19 +00:00
|
|
|
#include "wx/string.h"
|
|
|
|
|
2004-04-11 20:59:26 +00:00
|
|
|
|
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Set of helpful test macros.
|
|
|
|
//
|
|
|
|
|
|
|
|
// Base macro for wrapping CPPUNIT_TEST macros and so making them conditional
|
|
|
|
// tests, meaning that the test only get registered and thus run when a given
|
2004-09-10 12:56:07 +00:00
|
|
|
// runtime condition is true.
|
2004-04-11 20:59:26 +00:00
|
|
|
// In case the condition is evaluated as false a skip message is logged
|
|
|
|
// (the message will only be shown in verbose mode).
|
|
|
|
#define WXTEST_ANY_WITH_CONDITION(suiteName, Condition, testMethod, anyTest) \
|
|
|
|
if (Condition) \
|
|
|
|
{ anyTest; } \
|
|
|
|
else \
|
|
|
|
wxLogInfo(wxString::Format(_T("skipping: %s.%s\n reason: %s equals false\n"), \
|
|
|
|
wxString(suiteName, wxConvUTF8).c_str(), \
|
|
|
|
wxString(#testMethod, wxConvUTF8).c_str(), \
|
|
|
|
wxString(#Condition, wxConvUTF8).c_str()))
|
|
|
|
|
|
|
|
// Conditional CPPUNIT_TEST macro.
|
|
|
|
#define WXTEST_WITH_CONDITION(suiteName, Condition, testMethod) \
|
|
|
|
WXTEST_ANY_WITH_CONDITION(suiteName, Condition, testMethod, CPPUNIT_TEST(testMethod))
|
|
|
|
// Conditional CPPUNIT_TEST_FAIL macro.
|
|
|
|
#define WXTEST_FAIL_WITH_CONDITION(suiteName, Condition, testMethod) \
|
|
|
|
WXTEST_ANY_WITH_CONDITION(suiteName, Condition, testMethod, CPPUNIT_TEST_FAIL(testMethod))
|
|
|
|
|
2008-07-18 23:07:23 +00:00
|
|
|
CPPUNIT_NS_BEGIN
|
|
|
|
|
|
|
|
// provide an overload of cppunit assertEquals(T, T) which can be used to
|
|
|
|
// compare wxStrings directly with C strings
|
2009-04-04 23:55:05 +00:00
|
|
|
inline void
|
|
|
|
assertEquals(const char *expected,
|
|
|
|
const char *actual,
|
|
|
|
CppUnit::SourceLine sourceLine,
|
|
|
|
const std::string& message)
|
|
|
|
{
|
|
|
|
assertEquals(wxString(expected), wxString(actual), sourceLine, message);
|
|
|
|
}
|
|
|
|
|
2008-07-18 23:07:23 +00:00
|
|
|
inline void
|
|
|
|
assertEquals(const char *expected,
|
|
|
|
const wxString& actual,
|
|
|
|
CppUnit::SourceLine sourceLine,
|
|
|
|
const std::string& message)
|
|
|
|
{
|
|
|
|
assertEquals(wxString(expected), actual, sourceLine, message);
|
|
|
|
}
|
|
|
|
|
2009-04-04 16:43:36 +00:00
|
|
|
inline void
|
|
|
|
assertEquals(const wxString& expected,
|
|
|
|
const char *actual,
|
|
|
|
CppUnit::SourceLine sourceLine,
|
|
|
|
const std::string& message)
|
|
|
|
{
|
|
|
|
assertEquals(expected, wxString(actual), sourceLine, message);
|
|
|
|
}
|
|
|
|
|
2008-07-18 23:07:23 +00:00
|
|
|
inline void
|
|
|
|
assertEquals(const wchar_t *expected,
|
|
|
|
const wxString& actual,
|
|
|
|
CppUnit::SourceLine sourceLine,
|
|
|
|
const std::string& message)
|
|
|
|
{
|
|
|
|
assertEquals(wxString(expected), actual, sourceLine, message);
|
|
|
|
}
|
|
|
|
|
2009-04-04 16:43:36 +00:00
|
|
|
inline void
|
|
|
|
assertEquals(const wxString& expected,
|
|
|
|
const wchar_t *actual,
|
|
|
|
CppUnit::SourceLine sourceLine,
|
|
|
|
const std::string& message)
|
|
|
|
{
|
|
|
|
assertEquals(expected, wxString(actual), sourceLine, message);
|
|
|
|
}
|
|
|
|
|
2009-01-04 16:04:22 +00:00
|
|
|
CPPUNIT_NS_END
|
|
|
|
|
|
|
|
// define an assertEquals() overload for the given types, this is a helper and
|
|
|
|
// shouldn't be used directly because of VC6 complications, see below
|
2008-11-03 00:31:16 +00:00
|
|
|
#define WX_CPPUNIT_ASSERT_EQUALS(T1, T2) \
|
|
|
|
inline void \
|
|
|
|
assertEquals(T1 expected, \
|
|
|
|
T2 actual, \
|
|
|
|
CppUnit::SourceLine sourceLine, \
|
|
|
|
const std::string& message) \
|
|
|
|
{ \
|
|
|
|
if ( !assertion_traits<T1>::equal(expected,actual) ) \
|
|
|
|
{ \
|
|
|
|
Asserter::failNotEqual( assertion_traits<T1>::toString(expected), \
|
|
|
|
assertion_traits<T2>::toString(actual), \
|
|
|
|
sourceLine, \
|
|
|
|
message ); \
|
|
|
|
} \
|
|
|
|
}
|
|
|
|
|
2009-01-04 16:04:22 +00:00
|
|
|
// this macro allows us to specify (usually literal) ints as expected values
|
|
|
|
// for functions returning integral types different from "int"
|
|
|
|
//
|
|
|
|
// FIXME-VC6: due to incorrect resolution of overloaded/template functions in
|
|
|
|
// this compiler (it basically doesn't use the template version at
|
|
|
|
// all if any overloaded function matches partially even if none of
|
|
|
|
// them matches fully) we also need to provide extra overloads
|
2008-11-02 02:34:12 +00:00
|
|
|
|
2009-01-04 16:04:22 +00:00
|
|
|
#ifdef __VISUALC6__
|
|
|
|
#define WX_CPPUNIT_ALLOW_EQUALS_TO_INT(T) \
|
|
|
|
CPPUNIT_NS_BEGIN \
|
|
|
|
WX_CPPUNIT_ASSERT_EQUALS(int, T) \
|
2009-04-04 16:43:36 +00:00
|
|
|
WX_CPPUNIT_ASSERT_EQUALS(T, int) \
|
2009-01-04 16:04:22 +00:00
|
|
|
WX_CPPUNIT_ASSERT_EQUALS(T, T) \
|
|
|
|
CPPUNIT_NS_END
|
|
|
|
|
|
|
|
CPPUNIT_NS_BEGIN
|
|
|
|
WX_CPPUNIT_ASSERT_EQUALS(int, int)
|
|
|
|
CPPUNIT_NS_END
|
|
|
|
#else // !VC6
|
|
|
|
#define WX_CPPUNIT_ALLOW_EQUALS_TO_INT(T) \
|
|
|
|
CPPUNIT_NS_BEGIN \
|
|
|
|
WX_CPPUNIT_ASSERT_EQUALS(int, T) \
|
2009-04-04 16:43:36 +00:00
|
|
|
WX_CPPUNIT_ASSERT_EQUALS(T, int) \
|
2009-01-04 16:04:22 +00:00
|
|
|
CPPUNIT_NS_END
|
|
|
|
#endif // VC6/!VC6
|
|
|
|
|
|
|
|
WX_CPPUNIT_ALLOW_EQUALS_TO_INT(long)
|
|
|
|
WX_CPPUNIT_ALLOW_EQUALS_TO_INT(short)
|
2009-03-17 22:02:56 +00:00
|
|
|
WX_CPPUNIT_ALLOW_EQUALS_TO_INT(unsigned)
|
|
|
|
WX_CPPUNIT_ALLOW_EQUALS_TO_INT(unsigned long)
|
2004-04-11 20:59:26 +00:00
|
|
|
|
2009-05-03 09:59:31 +00:00
|
|
|
#if defined(wxLongLong_t) && !defined(wxLongLongIsLong)
|
|
|
|
WX_CPPUNIT_ALLOW_EQUALS_TO_INT(wxLongLong_t)
|
|
|
|
WX_CPPUNIT_ALLOW_EQUALS_TO_INT(unsigned wxLongLong_t)
|
|
|
|
#endif
|
|
|
|
|
2008-04-12 17:03:09 +00:00
|
|
|
// Use this macro to compare a wxArrayString with the pipe-separated elements
|
|
|
|
// of the given string
|
|
|
|
//
|
|
|
|
// NB: it's a macro and not a function to have the correct line numbers in the
|
|
|
|
// test failure messages
|
|
|
|
#define WX_ASSERT_STRARRAY_EQUAL(s, a) \
|
|
|
|
{ \
|
|
|
|
wxArrayString expected(wxSplit(s, '|', '\0')); \
|
|
|
|
\
|
|
|
|
CPPUNIT_ASSERT_EQUAL( expected.size(), a.size() ); \
|
|
|
|
\
|
|
|
|
for ( size_t n = 0; n < a.size(); n++ ) \
|
|
|
|
{ \
|
|
|
|
CPPUNIT_ASSERT_EQUAL( expected[n], a[n] ); \
|
|
|
|
} \
|
|
|
|
}
|
2008-01-06 22:57:09 +00:00
|
|
|
|
|
|
|
// Use this macro to assert with the given formatted message (it should contain
|
|
|
|
// the format string and arguments in a separate pair of parentheses)
|
|
|
|
#define WX_ASSERT_MESSAGE(msg, cond) \
|
|
|
|
CPPUNIT_ASSERT_MESSAGE(std::string(wxString::Format msg .mb_str()), (cond))
|
|
|
|
|
2008-11-19 11:51:21 +00:00
|
|
|
#define WX_ASSERT_EQUAL_MESSAGE(msg, expected, actual) \
|
|
|
|
CPPUNIT_ASSERT_EQUAL_MESSAGE(std::string(wxString::Format msg .mb_str()), \
|
|
|
|
(expected), (actual))
|
|
|
|
|
2006-08-30 08:37:39 +00:00
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
2007-10-09 00:01:20 +00:00
|
|
|
// define stream inserter for wxString if it's not defined in the main library,
|
|
|
|
// we need it to output the test failures involving wxString
|
|
|
|
#if !wxUSE_STD_IOSTREAM
|
2006-08-30 08:37:39 +00:00
|
|
|
|
2006-09-16 08:01:17 +00:00
|
|
|
#include "wx/string.h"
|
|
|
|
|
2008-01-13 01:13:03 +00:00
|
|
|
#include <iostream>
|
|
|
|
|
2006-08-30 08:37:39 +00:00
|
|
|
inline std::ostream& operator<<(std::ostream& o, const wxString& s)
|
|
|
|
{
|
2007-10-08 23:50:32 +00:00
|
|
|
#if wxUSE_UNICODE
|
|
|
|
return o << (const char *)wxSafeConvertWX2MB(s.wc_str());
|
|
|
|
#else
|
|
|
|
return o << s.c_str();
|
|
|
|
#endif
|
2006-08-30 08:37:39 +00:00
|
|
|
}
|
|
|
|
|
2008-11-03 12:44:07 +00:00
|
|
|
#endif // !wxUSE_STD_IOSTREAM
|
|
|
|
|
2008-01-23 23:32:12 +00:00
|
|
|
// VC6 doesn't provide overloads for operator<<(__int64) in its stream classes
|
|
|
|
// so do it ourselves
|
|
|
|
#if defined(__VISUALC6__) && defined(wxLongLong_t)
|
2008-01-13 01:13:03 +00:00
|
|
|
|
|
|
|
#include "wx/longlong.h"
|
|
|
|
|
|
|
|
inline std::ostream& operator<<(std::ostream& ostr, wxLongLong_t ll)
|
|
|
|
{
|
|
|
|
ostr << wxLongLong(ll).ToString();
|
|
|
|
|
|
|
|
return ostr;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline std::ostream& operator<<(std::ostream& ostr, unsigned wxLongLong_t llu)
|
|
|
|
{
|
|
|
|
ostr << wxULongLong(llu).ToString();
|
|
|
|
|
|
|
|
return ostr;
|
|
|
|
}
|
|
|
|
|
2008-01-23 23:32:12 +00:00
|
|
|
#endif // VC6 && wxLongLong_t
|
2008-01-13 01:13:03 +00:00
|
|
|
|
2004-04-11 20:59:26 +00:00
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Some more compiler warning tweaking and auto linking.
|
|
|
|
//
|
|
|
|
|
2004-04-01 07:17:50 +00:00
|
|
|
#ifdef __BORLANDC__
|
|
|
|
#pragma warn .8022
|
|
|
|
#endif
|
|
|
|
|
2004-02-15 02:58:56 +00:00
|
|
|
#ifdef _MSC_VER
|
|
|
|
#pragma warning(default:4702)
|
|
|
|
#endif // _MSC_VER
|
|
|
|
|
|
|
|
// for VC++ automatically link in cppunit library
|
|
|
|
#ifdef __VISUALC__
|
|
|
|
#ifdef NDEBUG
|
|
|
|
#pragma comment(lib, "cppunit.lib")
|
|
|
|
#else // Debug
|
|
|
|
#pragma comment(lib, "cppunitd.lib")
|
|
|
|
#endif // Release/Debug
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif // _WX_CPPUNIT_H_
|
|
|
|
|