// // Copyright (c) 2013-2016 Vinnie Falco (vinnie dot falco at gmail 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) // // Test that header file is self-contained. #include #include #include #include namespace beast { class consuming_buffers_test : public beast::detail::unit_test::suite { public: template static std::string to_string(ConstBufferSequence const& bs) { using boost::asio::buffer_cast; using boost::asio::buffer_size; std::string s; s.reserve(buffer_size(bs)); for(auto const& b : bs) s.append(buffer_cast(b), buffer_size(b)); return s; } void testBuffers() { using boost::asio::buffer; using boost::asio::const_buffer; char buf[12]; std::string const s = "Hello, world"; expect(s.size() == sizeof(buf)); buffer_copy(buffer(buf), buffer(s)); expect(to_string(buffer(buf)) == s); for(std::size_t i = 1; i < 4; ++i) { for(std::size_t j = 1; j < 4; ++j) { for(std::size_t x = 1; x < 4; ++x) { for(std::size_t y = 1; y < 4; ++y) { std::size_t k = sizeof(buf) - (i + j); std::size_t z = sizeof(buf) - (x + y); { std::array bs{{ const_buffer{&buf[0], i}, const_buffer{&buf[i], j}, const_buffer{&buf[i+j], k}}}; consuming_buffers cb(bs); expect(to_string(cb) == s); cb.consume(0); expect(to_string(cb) == s); cb.consume(x); expect(to_string(cb) == s.substr(x)); cb.consume(y); expect(to_string(cb) == s.substr(x+y)); cb.consume(z); expect(to_string(cb) == ""); cb.consume(1); expect(to_string(cb) == ""); } }}}} } void testNullBuffers() { using boost::asio::buffer_copy; using boost::asio::buffer_size; using boost::asio::null_buffers; consuming_buffers cb( null_buffers{}); expect(buffer_size(cb) == 0); consuming_buffers cb2( null_buffers{}); expect(buffer_copy(cb2, cb) == 0); } void run() override { testBuffers(); testNullBuffers(); } }; BEAST_DEFINE_TESTSUITE(consuming_buffers,core,beast); } // beast