Files
boost_beast/test/beast/websocket/timer.cpp

100 lines
2.8 KiB
C++
Raw Normal View History

2019-01-20 12:25:30 -08:00
2019-02-21 07:00:31 -08:00
// Copyright (c) 2016-2019 Vinnie Falco (vinnie dot falco at gmail dot com)
2019-01-20 12:25:30 -08:00
//
// 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(),
2019-02-27 18:15:01 -08:00
std::chrono::milliseconds(100),
2019-02-19 17:14:34 -08:00
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));
2019-02-27 18:15:01 -08:00
test::run_for(ioc, std::chrono::milliseconds(500));
2019-02-19 17:14:34 -08:00
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