blob: 425485ad1ab164b19c2cee9b611a10a6152bb0e8 [file] [log] [blame]
// (C) Copyright 2008 CodeRage, LLC (turkanis at coderage dot com)
// (C) Copyright 2004-2007 Jonathan Turkanis
// Distributed under 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/libs/iostreams for documentation.
#include <boost/iostreams/detail/config/wide_streams.hpp>
#ifdef BOOST_IOSTREAMS_NO_WIDE_STREAMS
# error wide streams not supported on this platform
#endif
#include <sstream>
#include <vector>
#include <boost/iostreams/device/back_inserter.hpp>
#include <boost/iostreams/filtering_stream.hpp>
#include <boost/test/test_tools.hpp>
#include <boost/test/unit_test.hpp>
#include "../example/container_device.hpp" // We use container_device instead
#include "detail/filters.hpp" // of make_iterator_range to
#include "detail/sequence.hpp" // reduce dependence on Boost.Range
#include "detail/temp_file.hpp"
#include "detail/verification.hpp"
using boost::unit_test::test_suite;
void read_wide_input_test()
{
using namespace std;
using namespace boost;
using namespace boost::iostreams;
using namespace boost::iostreams::example;
using namespace boost::iostreams::test;
test_sequence<wchar_t> seq;
container_device< test_sequence<wchar_t> > source(seq);
{
filtering_wistream first(source, 0);
basic_istringstream<wchar_t> second(
basic_string<wchar_t>(seq.begin(), seq.end())
);
BOOST_CHECK_MESSAGE(
compare_streams_in_chars(first, second),
"failed reading from a filter_wistream in chars with no buffer"
);
}
{
filtering_wistream first(source, 0);
basic_istringstream<wchar_t> second(
basic_string<wchar_t>(seq.begin(), seq.end())
);
BOOST_CHECK_MESSAGE(
compare_streams_in_chunks(first, second),
"failed reading from a filter_wistream in chunks with no buffer"
);
}
{
filtering_wistream first(source);
basic_istringstream<wchar_t> second(
basic_string<wchar_t>(seq.begin(), seq.end())
);
BOOST_CHECK_MESSAGE(
compare_streams_in_chars(first, second),
"failed reading from a filter_wistream in chars with large buffer"
);
}
{
filtering_wistream first(source);
basic_istringstream<wchar_t> second(
basic_string<wchar_t>(seq.begin(), seq.end())
);
BOOST_CHECK_MESSAGE(
compare_streams_in_chunks(first, second),
"failed reading from a filter_wistream in chunks with large buffer"
);
}
}
void write_wide_output_test()
{
using namespace std;
using namespace boost;
using namespace boost::iostreams;
using namespace boost::iostreams::test;
{
vector<wchar_t> first;
test_sequence<wchar_t> second;
filtering_wostream out(iostreams::back_inserter(first), 0);
write_data_in_chars(out);
BOOST_CHECK_MESSAGE(
first.size() == second.size() &&
std::equal(first.begin(), first.end(), second.begin()),
"failed writing to filtering_wostream in chars with no buffer"
);
}
{
vector<wchar_t> first;
test_sequence<wchar_t> second;
filtering_wostream out(iostreams::back_inserter(first), 0);
write_data_in_chunks(out);
BOOST_CHECK_MESSAGE(
first.size() == second.size() &&
std::equal(first.begin(), first.end(), second.begin()),
"failed writing to filtering_wostream in chunks with no buffer"
);
}
{
vector<wchar_t> first;
test_sequence<wchar_t> second;
filtering_wostream out(iostreams::back_inserter(first), 0);
write_data_in_chars(out);
BOOST_CHECK_MESSAGE(
first.size() == second.size() &&
std::equal(first.begin(), first.end(), second.begin()),
"failed writing to filtering_wostream in chars with large buffer"
);
}
{
vector<wchar_t> first;
test_sequence<wchar_t> second;
filtering_wostream out(iostreams::back_inserter(first));
write_data_in_chunks(out);
BOOST_CHECK_MESSAGE(
first.size() == second.size() &&
std::equal(first.begin(), first.end(), second.begin()),
"failed writing to filtering_wostream in chunks with large buffer"
);
}
}
test_suite* init_unit_test_suite(int, char* [])
{
test_suite* test = BOOST_TEST_SUITE("wide stream test");
test->add(BOOST_TEST_CASE(&read_wide_input_test));
test->add(BOOST_TEST_CASE(&write_wide_output_test));
return test;
}