component_access_test.cpp 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173
  1. // (C) Copyright 2008 CodeRage, LLC (turkanis at coderage dot com)
  2. // (C) Copyright 2004-2007 Jonathan Turkanis
  3. // Distributed under the Boost Software License, Version 1.0. (See accompanying
  4. // file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt.)
  5. // See http://www.boost.org/libs/iostreams for documentation.
  6. #include <stdexcept> // out_of_range.
  7. #include <utility> // pair.
  8. #include <boost/config.hpp> // BOOST_MSVC.
  9. #include <boost/detail/workaround.hpp>
  10. #include <boost/core/typeinfo.hpp>
  11. #include <boost/iostreams/device/file.hpp>
  12. #include <boost/iostreams/filtering_stream.hpp>
  13. #include <boost/iostreams/stream.hpp>
  14. #include <boost/iostreams/stream_buffer.hpp>
  15. #include <boost/test/test_tools.hpp>
  16. #include <boost/test/unit_test.hpp>
  17. #include "detail/constants.hpp"
  18. #include "detail/filters.hpp"
  19. #include "detail/temp_file.hpp"
  20. #include "detail/verification.hpp"
  21. namespace io = boost::iostreams;
  22. using boost::unit_test::test_suite;
  23. #define COMPARE_TYPE_ID(x, y) BOOST_IOSTREAMS_COMPARE_TYPE_ID(x, y)
  24. struct indirect_source : io::source {
  25. void foo() { }
  26. std::streamsize read(char*, std::streamsize) { return 0; }
  27. };
  28. struct direct_source {
  29. typedef char char_type;
  30. struct category
  31. : io::input, io::device_tag, io::direct_tag
  32. { };
  33. void foo() { }
  34. std::pair<char*, char*> input_sequence()
  35. {
  36. return std::pair<char*, char*>(static_cast<char*>(0), static_cast<char*>(0));;
  37. }
  38. };
  39. void compile_time_test()
  40. {
  41. using namespace io;
  42. stream_buffer<indirect_source> indirect_buf;
  43. indirect_buf.open(indirect_source());
  44. indirect_buf->foo();
  45. stream_buffer<direct_source> direct_buf;
  46. direct_buf.open(direct_source());
  47. direct_buf->foo();
  48. stream<indirect_source> indirect_stream;
  49. indirect_stream.open(indirect_source());
  50. indirect_stream->foo();
  51. stream<direct_source> direct_stream;
  52. direct_stream.open(direct_source());
  53. direct_stream->foo();
  54. }
  55. void component_type_test()
  56. {
  57. using namespace std;
  58. using namespace io;
  59. using namespace boost::iostreams::test;
  60. temp_file dest;
  61. lowercase_file lower;
  62. filtering_ostream out;
  63. out.push(tolower_filter());
  64. out.push(tolower_multichar_filter());
  65. out.push(file_sink(dest.name(), out_mode));
  66. // Check index 0.
  67. BOOST_CHECK(COMPARE_TYPE_ID(
  68. out.component_type(0),
  69. BOOST_CORE_TYPEID(tolower_filter)
  70. ));
  71. BOOST_CHECK(COMPARE_TYPE_ID(
  72. BOOST_IOSTREAMS_COMPONENT_TYPE(out, 0),
  73. BOOST_CORE_TYPEID(tolower_filter)
  74. ));
  75. BOOST_CHECK_NO_THROW((
  76. BOOST_IOSTREAMS_COMPONENT(out, 0, tolower_filter)
  77. ));
  78. #if !BOOST_WORKAROUND(BOOST_MSVC, < 1310)
  79. BOOST_CHECK_NO_THROW((
  80. out.component<tolower_filter>(0)
  81. ));
  82. BOOST_CHECK_NO_THROW((
  83. out.component<0, tolower_filter>()
  84. ));
  85. #endif
  86. // Check index 1.
  87. BOOST_CHECK(COMPARE_TYPE_ID(
  88. out.component_type(1),
  89. BOOST_CORE_TYPEID(tolower_multichar_filter)
  90. ));
  91. BOOST_CHECK(COMPARE_TYPE_ID(
  92. BOOST_IOSTREAMS_COMPONENT_TYPE(out, 1),
  93. BOOST_CORE_TYPEID(tolower_multichar_filter)
  94. ));
  95. BOOST_CHECK_NO_THROW((
  96. BOOST_IOSTREAMS_COMPONENT(out, 1, tolower_multichar_filter)
  97. ));
  98. #if !BOOST_WORKAROUND(BOOST_MSVC, < 1310)
  99. BOOST_CHECK_NO_THROW((
  100. out.component<tolower_multichar_filter>(1)
  101. ));
  102. BOOST_CHECK_NO_THROW((
  103. out.component<1, tolower_multichar_filter>()
  104. ));
  105. #endif
  106. // Check index 2.
  107. BOOST_CHECK(COMPARE_TYPE_ID(
  108. out.component_type(2),
  109. BOOST_CORE_TYPEID(file_sink)
  110. ));
  111. BOOST_CHECK(COMPARE_TYPE_ID(
  112. BOOST_IOSTREAMS_COMPONENT_TYPE(out, 2),
  113. BOOST_CORE_TYPEID(file_sink)
  114. ));
  115. BOOST_CHECK_NO_THROW((
  116. BOOST_IOSTREAMS_COMPONENT(out, 2, file_sink)
  117. ));
  118. #if !BOOST_WORKAROUND(BOOST_MSVC, < 1310)
  119. BOOST_CHECK_NO_THROW((
  120. out.component<file_sink>(2)
  121. ));
  122. BOOST_CHECK_NO_THROW((
  123. out.component<2, file_sink>()
  124. ));
  125. #endif
  126. // Check index 3.
  127. BOOST_CHECK_THROW(
  128. out.component_type(3),
  129. std::out_of_range
  130. );
  131. BOOST_CHECK_THROW(
  132. BOOST_IOSTREAMS_COMPONENT_TYPE(out, 3),
  133. std::out_of_range
  134. );
  135. // Check components.
  136. filtering_ostream out2;
  137. out2.push(*(BOOST_IOSTREAMS_COMPONENT(out, 0, tolower_filter)));
  138. out2.push(*(BOOST_IOSTREAMS_COMPONENT(out, 1, tolower_multichar_filter)));
  139. out2.push(*(BOOST_IOSTREAMS_COMPONENT(out, 2, file_sink)));
  140. write_data_in_chunks(out);
  141. out.reset();
  142. BOOST_CHECK_MESSAGE(
  143. compare_files(dest.name(), lower.name()),
  144. "failed accessing components of chain"
  145. );
  146. }
  147. test_suite* init_unit_test_suite(int, char* [])
  148. {
  149. test_suite* test = BOOST_TEST_SUITE("component_type test");
  150. test->add(BOOST_TEST_CASE(&component_type_test));
  151. return test;
  152. }