serialization/test/test_tools.hpp

265 lines
7.4 KiB
C++

#ifndef BOOST_SERIALIZATION_TEST_TOOLS_HPP
#define BOOST_SERIALIZATION_TEST_TOOLS_HPP
// MS compatible compilers support #pragma once
#if defined(_MSC_VER)
# pragma once
#endif
#define BOOST_FILESYSTEM_VERSION 3
#include <boost/filesystem/operations.hpp> // unique_path
/////////1/////////2/////////3/////////4/////////5/////////6/////////7/////////8
// test_tools.hpp
//
// (C) Copyright 2002 Robert Ramey - http://www.rrsd.com .
// Use, modification and distribution is subject to the Boost Software
// License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
// http://www.boost.org/LICENSE_1_0.txt)
// See http://www.boost.org for updates, documentation, and revision history.
#include <boost/config.hpp>
#ifndef BOOST_NO_EXCEPTION_STD_NAMESPACE
#include <exception>
#endif
#include <boost/detail/no_exceptions_support.hpp>
#if defined(UNDER_CE)
// Windows CE does not supply the tmpnam function in its CRT.
// Substitute a primitive implementation here.
namespace boost {
namespace archive {
const char * tmpnam(char * buffer){
static char ibuffer [512];
if(NULL == buffer)
buffer = ibuffer;
static unsigned short index = 0;
std::sprintf(buffer, "\\tmpfile%05X.tmp", index++);
return buffer;
}
} // archive
} // boost
#elif defined(_WIN32) || defined(__WIN32__) || defined(WIN32)
// win32 has a brain-dead tmpnam implementation.
// which leaves temp files in root directory
// regardless of environmental settings
#include <cstdlib>
#include <cstring>
#if defined(BOOST_NO_STDC_NAMESPACE)
namespace std{
using ::remove;
using ::strcpy;
using ::strcat;
using ::tmpnam;
}
#endif // defined(BOOST_NO_STDC_NAMESPACE)
#include <direct.h>
#include <boost/archive/tmpdir.hpp>
//#if defined(__COMO__)
#define chdir _chdir
//#endif // defined win32
#if defined(NDEBUG) && defined(__BORLANDC__)
#define STRCPY strcpy
#else
#define STRCPY std::strcpy
#endif
namespace boost {
namespace archive {
const char * test_filename(const char * dir = NULL, char *fname = NULL){
static char ibuffer [512];
ibuffer[0] = '\0';
if(NULL == dir){
dir = boost::archive::tmpdir();
}
STRCPY(ibuffer, dir);
std::strcat(ibuffer, "/");
if(NULL == fname){
char old_dir[256];
_getcwd(old_dir, sizeof(old_dir) - 1);
chdir(dir);
// (C) Copyright 2010 Dean Michael Berris. <mikhailberis@gmail.com>
// Instead of using std::tmpnam, we use Boost.Filesystem's unique_path
boost::filesystem::path tmp_path =
boost::filesystem::unique_path("%%%%%");
std::strcat(ibuffer, tmp_path.string().c_str());
chdir(old_dir);
}
else{
std::strcat(ibuffer, fname);
}
return ibuffer;
}
const char * tmpnam(char * buffer){
const char * name = test_filename(NULL, NULL);
if(NULL != buffer){
STRCPY(buffer, name);
}
return name;
}
} // archive
} // boost
#else // defined(_WIN32) || defined(__WIN32__) || defined(WIN32)
#if defined(__hpux)
// (C) Copyright 2006 Boris Gubenko.
// HP-UX has a restriction that for multi-thread applications, (i.e.
// the ones compiled -mt) if argument to tmpnam is a NULL pointer, then,
// citing the tmpnam(3S) manpage, "the operation is not performed and a
// NULL pointer is returned". tempnam does not have this restriction, so,
// let's use tempnam instead.
#define tmpnam(X) tempnam(NULL,X)
namespace boost {
namespace archive {
using ::tmpnam;
} // archive
} // boost
#else // defined(__hpux)
// (C) Copyright 2010 Dean Michael Berris.
// Instead of using the potentially dangrous tempnam function that's part
// of the C standard library, on Unix/Linux we use the more portable and
// "safe" unique_path function provided in the Boost.Filesystem library.
#include <boost/archive/tmpdir.hpp>
namespace boost {
namespace archive {
char const * tmpnam(char * buffer) {
static char name[512] = {0};
if (name[0] == 0) {
boost::filesystem::path tempdir(tmpdir());
boost::filesystem::path tempfilename =
boost::filesystem::unique_path("serialization-%%%%");
boost::filesystem::path temp = tempdir / tempfilename;
std::strcat(name, temp.string().c_str());
}
if (buffer != 0) std::strcpy(buffer, name);
return name;
}
} // archive
} // boost
#endif // defined(__hpux)
#endif // defined(_WIN32) || defined(__WIN32__) || defined(WIN32)
#include <boost/core/lightweight_test.hpp>
#define BOOST_CHECK( P ) \
BOOST_TEST( (P) )
#define BOOST_REQUIRE( P ) \
BOOST_TEST( (P) )
#define BOOST_CHECK_MESSAGE( P, M ) \
((P)? (void)0 : ::boost::detail::error_impl( (M) , __FILE__, __LINE__, BOOST_CURRENT_FUNCTION))
#define BOOST_REQUIRE_MESSAGE( P, M ) \
BOOST_CHECK_MESSAGE( (P), (M) )
#define BOOST_CHECK_EQUAL( A , B ) \
BOOST_TEST( (A) == (B) )
namespace boost { namespace detail {
inline void msg_impl(char const * msg, char const * file, int line, char const * function)
{
std::cerr << file << "(" << line << "): " << msg << " in function '" << function << "'" << std::endl;
}
} } // boost::detail
#define BOOST_WARN_MESSAGE( P, M ) \
((P)? (void)0 : ::boost::detail::msg_impl( (M) , __FILE__, __LINE__, BOOST_CURRENT_FUNCTION))
#define BOOST_MESSAGE( M ) \
BOOST_WARN_MESSAGE( true , (M) )
#define BOOST_CHECKPOINT( M ) \
BOOST_WARN_MESSAGE( true , (M) )
//#define BOOST_TEST_DONT_PRINT_LOG_VALUE( T )
#define BOOST_FAIL( M ) BOOST_REQUIRE_MESSAGE( false, (M) )
#define EXIT_SUCCESS 0
int test_main(int argc, char * argv[]);
#include <boost/serialization/singleton.hpp>
int
main(int argc, char * argv[]){
boost::serialization::get_singleton_module().lock();
int retval = 1;
BOOST_TRY{
retval = test_main(argc, argv);
}
#ifndef BOOST_NO_EXCEPTION_STD_NAMESPACE
BOOST_CATCH(const std::exception & e){
BOOST_ERROR(e.what());
}
#endif
BOOST_CATCH(...){
BOOST_ERROR("failed with uncaught exception:");
}
BOOST_CATCH_END
boost::serialization::get_singleton_module().unlock();
int error_count = boost::report_errors();
if(error_count > 0)
retval = error_count;
return retval;
}
// the following is to ensure that when one of the libraries changes
// BJAM rebuilds and relinks the test.
/*
#include "text_archive.hpp"
#include "text_warchive.hpp"
#include "binary_archive.hpp"
#include "xml_archive.hpp"
#include "xml_warchive.hpp"
#include "polymorphic_text_archive.hpp"
#include "polymorphic_text_warchive.hpp"
#include "polymorphic_binary_archive.hpp"
#include "polymorphic_xml_archive.hpp"
#include "polymorphic_xml_warchive.hpp"
*/
/////////////////////////////////////////////
// invoke header for a custom archive test.
/////////////////////////////////////////////
// invoke header for a custom archive test.
#if ! defined(BOOST_ARCHIVE_TEST)
#define BOOST_ARCHIVE_TEST text_archive.hpp
#endif
#include <boost/preprocessor/stringize.hpp>
#include BOOST_PP_STRINGIZE(BOOST_ARCHIVE_TEST)
#ifndef TEST_STREAM_FLAGS
#define TEST_STREAM_FLAGS (std::ios_base::openmode)0
#endif
#ifndef TEST_ARCHIVE_FLAGS
#define TEST_ARCHIVE_FLAGS 0
#endif
#ifndef TEST_DIRECTORY
#define TEST_DIRECTORY
#else
#define __x__ TEST_DIRECTORY
#undef TEST_DIRECTORY
#define TEST_DIRECTORY BOOST_PP_STRINGIZE(__x__)
#endif
#endif // BOOST_SERIALIZATION_TEST_TOOLS_HPP