mirror of
https://github.com/Xahau/xahaud.git
synced 2025-12-06 17:27:52 +00:00
6d5547a Set version to 1.0.0-b34 6fab138 Fix and tidy up CMake build scripts: ccefa54 Set version to 1.0.0-b33 32afe41 Set internal state correctly when writing frames: fe3e20b Add write_frames unit test 578dcd0 Add decorator unit test aaa3733 Use fwrite return value in file_body df66165 Require Visual Studio 2015 Update 3 or later b8e5a21 Set version to 1.0.0-b32 ffb1758 Update CMake scripts for finding packages: b893749 Remove http Writer suspend and resume feature (API Change): 27864fb Add io_service completion invariants tests eba05a7 Set version to 1.0.0-b31 484bcef Fix badge markdown in README.md 5663bea Add missing dynabuf_readstream member 0d7a551 Tidy up build settings 0fd4030 Move the handler, don't copy it git-subtree-dir: src/beast git-subtree-split: 6d5547a32c50ec95832c4779311502555ab0ee1f
191 lines
6.0 KiB
C++
191 lines
6.0 KiB
C++
//
|
|
// Copyright (c) 2013-2017 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 <beast/core/buffers_adapter.hpp>
|
|
|
|
#include <beast/core/streambuf.hpp>
|
|
#include <beast/unit_test/suite.hpp>
|
|
#include <boost/asio/buffer.hpp>
|
|
#include <boost/asio/streambuf.hpp>
|
|
#include <iterator>
|
|
|
|
namespace beast {
|
|
|
|
class buffers_adapter_test : public unit_test::suite
|
|
{
|
|
public:
|
|
template<class ConstBufferSequence>
|
|
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<char const*>(b),
|
|
buffer_size(b));
|
|
return s;
|
|
}
|
|
|
|
void testBuffersAdapter()
|
|
{
|
|
using boost::asio::buffer;
|
|
using boost::asio::buffer_cast;
|
|
using boost::asio::buffer_size;
|
|
using boost::asio::const_buffer;
|
|
using boost::asio::mutable_buffer;
|
|
char buf[12];
|
|
std::string const s = "Hello, world";
|
|
BEAST_EXPECT(s.size() == sizeof(buf));
|
|
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) {
|
|
for(std::size_t t = 1; t < 4; ++ t) {
|
|
for(std::size_t u = 1; u < 4; ++ u) {
|
|
std::size_t k = sizeof(buf) - (i + j);
|
|
std::size_t z = sizeof(buf) - (x + y);
|
|
std::size_t v = sizeof(buf) - (t + u);
|
|
{
|
|
std::memset(buf, 0, sizeof(buf));
|
|
std::array<mutable_buffer, 3> bs{{
|
|
mutable_buffer{&buf[0], i},
|
|
mutable_buffer{&buf[i], j},
|
|
mutable_buffer{&buf[i+j], k}}};
|
|
buffers_adapter<decltype(bs)> ba(std::move(bs));
|
|
BEAST_EXPECT(ba.max_size() == sizeof(buf));
|
|
{
|
|
auto d = ba.prepare(z);
|
|
BEAST_EXPECT(buffer_size(d) == z);
|
|
}
|
|
{
|
|
auto d = ba.prepare(0);
|
|
BEAST_EXPECT(buffer_size(d) == 0);
|
|
}
|
|
{
|
|
auto d = ba.prepare(y);
|
|
BEAST_EXPECT(buffer_size(d) == y);
|
|
}
|
|
{
|
|
auto d = ba.prepare(x);
|
|
BEAST_EXPECT(buffer_size(d) == x);
|
|
ba.commit(buffer_copy(d, buffer(s.data(), x)));
|
|
}
|
|
BEAST_EXPECT(ba.size() == x);
|
|
BEAST_EXPECT(ba.max_size() == sizeof(buf) - x);
|
|
BEAST_EXPECT(buffer_size(ba.data()) == ba.size());
|
|
{
|
|
auto d = ba.prepare(x);
|
|
BEAST_EXPECT(buffer_size(d) == x);
|
|
}
|
|
{
|
|
auto d = ba.prepare(0);
|
|
BEAST_EXPECT(buffer_size(d) == 0);
|
|
}
|
|
{
|
|
auto d = ba.prepare(z);
|
|
BEAST_EXPECT(buffer_size(d) == z);
|
|
}
|
|
{
|
|
auto d = ba.prepare(y);
|
|
BEAST_EXPECT(buffer_size(d) == y);
|
|
ba.commit(buffer_copy(d, buffer(s.data()+x, y)));
|
|
}
|
|
ba.commit(1);
|
|
BEAST_EXPECT(ba.size() == x + y);
|
|
BEAST_EXPECT(ba.max_size() == sizeof(buf) - (x + y));
|
|
BEAST_EXPECT(buffer_size(ba.data()) == ba.size());
|
|
{
|
|
auto d = ba.prepare(x);
|
|
BEAST_EXPECT(buffer_size(d) == x);
|
|
}
|
|
{
|
|
auto d = ba.prepare(y);
|
|
BEAST_EXPECT(buffer_size(d) == y);
|
|
}
|
|
{
|
|
auto d = ba.prepare(0);
|
|
BEAST_EXPECT(buffer_size(d) == 0);
|
|
}
|
|
{
|
|
auto d = ba.prepare(z); BEAST_EXPECT(buffer_size(d) == z);
|
|
ba.commit(buffer_copy(d, buffer(s.data()+x+y, z)));
|
|
}
|
|
ba.commit(2);
|
|
BEAST_EXPECT(ba.size() == x + y + z);
|
|
BEAST_EXPECT(ba.max_size() == 0);
|
|
BEAST_EXPECT(buffer_size(ba.data()) == ba.size());
|
|
BEAST_EXPECT(to_string(ba.data()) == s);
|
|
ba.consume(t);
|
|
{
|
|
auto d = ba.prepare(0);
|
|
BEAST_EXPECT(buffer_size(d) == 0);
|
|
}
|
|
BEAST_EXPECT(to_string(ba.data()) == s.substr(t, std::string::npos));
|
|
ba.consume(u);
|
|
BEAST_EXPECT(to_string(ba.data()) == s.substr(t + u, std::string::npos));
|
|
ba.consume(v);
|
|
BEAST_EXPECT(to_string(ba.data()) == "");
|
|
ba.consume(1);
|
|
{
|
|
auto d = ba.prepare(0);
|
|
BEAST_EXPECT(buffer_size(d) == 0);
|
|
}
|
|
try
|
|
{
|
|
ba.prepare(1);
|
|
fail();
|
|
}
|
|
catch(...)
|
|
{
|
|
pass();
|
|
}
|
|
}
|
|
}}}}}}
|
|
}
|
|
void testCommit()
|
|
{
|
|
using boost::asio::buffer_size;
|
|
{
|
|
using sb_type = boost::asio::streambuf;
|
|
sb_type sb;
|
|
buffers_adapter<
|
|
sb_type::mutable_buffers_type> ba(sb.prepare(3));
|
|
BEAST_EXPECT(buffer_size(ba.prepare(3)) == 3);
|
|
ba.commit(2);
|
|
BEAST_EXPECT(buffer_size(ba.data()) == 2);
|
|
}
|
|
{
|
|
using sb_type = beast::streambuf;
|
|
sb_type sb(2);
|
|
sb.prepare(3);
|
|
buffers_adapter<
|
|
sb_type::mutable_buffers_type> ba(sb.prepare(8));
|
|
BEAST_EXPECT(buffer_size(ba.prepare(8)) == 8);
|
|
ba.commit(2);
|
|
BEAST_EXPECT(buffer_size(ba.data()) == 2);
|
|
ba.consume(1);
|
|
ba.commit(6);
|
|
ba.consume(2);
|
|
BEAST_EXPECT(buffer_size(ba.data()) == 5);
|
|
ba.consume(5);
|
|
}
|
|
}
|
|
void run() override
|
|
{
|
|
testBuffersAdapter();
|
|
testCommit();
|
|
}
|
|
};
|
|
|
|
BEAST_DEFINE_TESTSUITE(buffers_adapter,core,beast);
|
|
|
|
} // beast
|