2019-01-20 12:25:30 -08:00
|
|
|
|
|
|
|
|
// Copyright (c) 2016-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)
|
|
|
|
|
//
|
|
|
|
|
// Official repository: https://github.com/boostorg/beast
|
|
|
|
|
//
|
|
|
|
|
|
|
|
|
|
// Test that header file is self-contained.
|
|
|
|
|
#include <boost/beast/websocket/stream.hpp>
|
|
|
|
|
|
2019-02-19 17:14:34 -08:00
|
|
|
#include <boost/beast/_experimental/test/stream.hpp>
|
|
|
|
|
#include <boost/beast/_experimental/test/tcp.hpp>
|
|
|
|
|
#include <boost/beast/_experimental/unit_test/suite.hpp>
|
|
|
|
|
#include <boost/beast/core/flat_buffer.hpp>
|
2019-01-20 12:25:30 -08:00
|
|
|
#include <boost/asio/ip/tcp.hpp>
|
|
|
|
|
|
|
|
|
|
namespace boost {
|
|
|
|
|
namespace beast {
|
|
|
|
|
namespace websocket {
|
|
|
|
|
|
2019-02-19 17:14:34 -08:00
|
|
|
struct timer_test : unit_test::suite
|
2019-01-20 12:25:30 -08:00
|
|
|
{
|
|
|
|
|
using tcp = boost::asio::ip::tcp;
|
|
|
|
|
|
2019-02-19 17:14:34 -08:00
|
|
|
void
|
|
|
|
|
testIdlePing()
|
|
|
|
|
{
|
|
|
|
|
net::io_context ioc;
|
|
|
|
|
|
|
|
|
|
// idle ping, no timeout
|
|
|
|
|
|
|
|
|
|
{
|
|
|
|
|
stream<tcp::socket> ws1(ioc);
|
|
|
|
|
stream<tcp::socket> ws2(ioc);
|
|
|
|
|
test::connect(ws1.next_layer(), ws2.next_layer());
|
|
|
|
|
ws1.async_accept(test::success_handler());
|
|
|
|
|
ws2.async_handshake("test", "/", test::success_handler());
|
|
|
|
|
test::run(ioc);
|
|
|
|
|
|
|
|
|
|
ws2.set_option(stream_base::timeout{
|
|
|
|
|
stream_base::none(),
|
|
|
|
|
std::chrono::milliseconds(50),
|
|
|
|
|
true});
|
|
|
|
|
flat_buffer b1;
|
|
|
|
|
flat_buffer b2;
|
|
|
|
|
bool received = false;
|
|
|
|
|
ws1.control_callback(
|
|
|
|
|
[&received](frame_type ft, string_view)
|
|
|
|
|
{
|
|
|
|
|
received = true;
|
|
|
|
|
BEAST_EXPECT(ft == frame_type::ping);
|
|
|
|
|
});
|
|
|
|
|
ws1.async_read(b1, test::fail_handler(
|
|
|
|
|
net::error::operation_aborted));
|
|
|
|
|
ws2.async_read(b2, test::fail_handler(
|
|
|
|
|
net::error::operation_aborted));
|
|
|
|
|
test::run_for(ioc, std::chrono::milliseconds(100));
|
|
|
|
|
BEAST_EXPECT(received);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
test::run(ioc);
|
|
|
|
|
|
|
|
|
|
// idle ping, timeout
|
|
|
|
|
|
|
|
|
|
{
|
|
|
|
|
stream<tcp::socket> ws1(ioc);
|
|
|
|
|
stream<tcp::socket> ws2(ioc);
|
|
|
|
|
test::connect(ws1.next_layer(), ws2.next_layer());
|
|
|
|
|
ws1.async_accept(test::success_handler());
|
|
|
|
|
ws2.async_handshake("test", "/", test::success_handler());
|
|
|
|
|
test::run(ioc);
|
|
|
|
|
|
|
|
|
|
ws2.set_option(stream_base::timeout{
|
|
|
|
|
stream_base::none(),
|
|
|
|
|
std::chrono::milliseconds(50),
|
|
|
|
|
true});
|
|
|
|
|
flat_buffer b;
|
|
|
|
|
ws2.async_read(b,
|
|
|
|
|
test::fail_handler(beast::error::timeout));
|
|
|
|
|
test::run(ioc);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
test::run(ioc);
|
|
|
|
|
}
|
|
|
|
|
|
2019-01-20 12:25:30 -08:00
|
|
|
void
|
|
|
|
|
run() override
|
|
|
|
|
{
|
2019-02-19 17:14:34 -08:00
|
|
|
testIdlePing();
|
2019-01-20 12:25:30 -08:00
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
BEAST_DEFINE_TESTSUITE(beast,websocket,timer);
|
|
|
|
|
|
|
|
|
|
} // websocket
|
|
|
|
|
} // beast
|
|
|
|
|
} // boost
|