1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181
|
//
// stream_file.cpp
// ~~~~~~~~~~~~~~~
//
// Copyright (c) 2003-2023 Christopher M. Kohlhoff (chris at kohlhoff dot com)
//
// 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)
//
// Disable autolinking for unit tests.
#if !defined(BOOST_ALL_NO_LIB)
#define BOOST_ALL_NO_LIB 1
#endif // !defined(BOOST_ALL_NO_LIB)
// Test that header file is self-contained.
#include <boost/asio/stream_file.hpp>
#include "archetypes/async_result.hpp"
#include <boost/asio/io_context.hpp>
#include "unit_test.hpp"
// stream_file_compile test
// ~~~~~~~~~~~~~~~~~~~~~~~~
// The following test checks that all public member functions on the class
// stream_file compile and link correctly. Runtime failures are ignored.
namespace stream_file_compile {
struct write_some_handler
{
write_some_handler() {}
void operator()(const boost::system::error_code&, std::size_t) {}
#if defined(BOOST_ASIO_HAS_MOVE)
write_some_handler(write_some_handler&&) {}
private:
write_some_handler(const write_some_handler&);
#endif // defined(BOOST_ASIO_HAS_MOVE)
};
struct read_some_handler
{
read_some_handler() {}
void operator()(const boost::system::error_code&, std::size_t) {}
#if defined(BOOST_ASIO_HAS_MOVE)
read_some_handler(read_some_handler&&) {}
private:
read_some_handler(const read_some_handler&);
#endif // defined(BOOST_ASIO_HAS_MOVE)
};
void test()
{
#if defined(BOOST_ASIO_HAS_FILE)
using namespace boost::asio;
try
{
io_context ioc;
const io_context::executor_type ioc_ex = ioc.get_executor();
char mutable_char_buffer[128] = "";
const char const_char_buffer[128] = "";
archetypes::lazy_handler lazy;
boost::system::error_code ec;
const std::string path;
// basic_stream_file constructors.
stream_file file1(ioc);
stream_file file2(ioc, "", stream_file::read_only);
stream_file file3(ioc, path, stream_file::read_only);
stream_file::native_handle_type native_file1 = file1.native_handle();
stream_file file4(ioc, native_file1);
stream_file file5(ioc_ex);
stream_file file6(ioc_ex, "", stream_file::read_only);
stream_file file7(ioc_ex, path, stream_file::read_only);
stream_file::native_handle_type native_file2 = file1.native_handle();
stream_file file8(ioc_ex, native_file2);
#if defined(BOOST_ASIO_HAS_MOVE)
stream_file file9(std::move(file8));
basic_stream_file<io_context::executor_type> file10(ioc);
stream_file file11(std::move(file10));
#endif // defined(BOOST_ASIO_HAS_MOVE)
// basic_stream_file operators.
#if defined(BOOST_ASIO_HAS_MOVE)
file1 = stream_file(ioc);
file1 = std::move(file2);
file1 = std::move(file10);
#endif // defined(BOOST_ASIO_HAS_MOVE)
// basic_io_object functions.
stream_file::executor_type ex = file1.get_executor();
(void)ex;
// basic_stream_file functions.
file1.open("", stream_file::read_only);
file1.open("", stream_file::read_only, ec);
file1.open(path, stream_file::read_only);
file1.open(path, stream_file::read_only, ec);
stream_file::native_handle_type native_file3 = file1.native_handle();
file1.assign(native_file3);
stream_file::native_handle_type native_file4 = file1.native_handle();
file1.assign(native_file4, ec);
bool is_open = file1.is_open();
(void)is_open;
file1.close();
file1.close(ec);
stream_file::native_handle_type native_file5 = file1.native_handle();
(void)native_file5;
stream_file::native_handle_type native_file6 = file1.release();
(void)native_file6;
stream_file::native_handle_type native_file7 = file1.release(ec);
(void)native_file7;
file1.cancel();
file1.cancel(ec);
boost::asio::uint64_t s1 = file1.size();
(void)s1;
boost::asio::uint64_t s2 = file1.size(ec);
(void)s2;
file1.resize(boost::asio::uint64_t(0));
file1.resize(boost::asio::uint64_t(0), ec);
file1.sync_all();
file1.sync_all(ec);
file1.sync_data();
file1.sync_data(ec);
boost::asio::uint64_t s3 = file1.seek(0, stream_file::seek_set);
(void)s3;
boost::asio::uint64_t s4 = file1.seek(0, stream_file::seek_set, ec);
(void)s4;
file1.write_some(buffer(mutable_char_buffer));
file1.write_some(buffer(const_char_buffer));
file1.write_some(buffer(mutable_char_buffer), ec);
file1.write_some(buffer(const_char_buffer), ec);
file1.async_write_some(buffer(mutable_char_buffer), write_some_handler());
file1.async_write_some(buffer(const_char_buffer), write_some_handler());
int i1 = file1.async_write_some(buffer(mutable_char_buffer), lazy);
(void)i1;
int i2 = file1.async_write_some(buffer(const_char_buffer), lazy);
(void)i2;
file1.read_some(buffer(mutable_char_buffer));
file1.read_some(buffer(mutable_char_buffer), ec);
file1.async_read_some(buffer(mutable_char_buffer), read_some_handler());
int i3 = file1.async_read_some(buffer(mutable_char_buffer), lazy);
(void)i3;
}
catch (std::exception&)
{
}
#endif // defined(BOOST_ASIO_HAS_FILE)
}
} // namespace stream_file_compile
BOOST_ASIO_TEST_SUITE
(
"stream_file",
BOOST_ASIO_COMPILE_TEST_CASE(stream_file_compile::test)
)
|