2
0
mirror of https://github.com/boostorg/mysql.git synced 2026-02-17 13:52:18 +00:00
Files
mysql/test/integration/utils/src/async_callback_noerrinfo.cpp
2022-10-14 17:44:57 +02:00

200 lines
6.1 KiB
C++

//
// Copyright (c) 2019-2022 Ruben Perez Hidalgo (rubenperez038 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)
//
#include <boost/mysql/connection.hpp>
#include <boost/mysql/errc.hpp>
#include <boost/mysql/error.hpp>
#include <boost/mysql/execute_params.hpp>
#include <boost/mysql/handshake_params.hpp>
#include <boost/mysql/resultset_base.hpp>
#include <boost/mysql/row.hpp>
#include <boost/mysql/row_view.hpp>
#include <boost/mysql/rows_view.hpp>
#include <boost/mysql/statement_base.hpp>
#include <memory>
#include "er_connection.hpp"
#include "er_impl_common.hpp"
#include "er_network_variant.hpp"
#include "er_resultset.hpp"
#include "er_statement.hpp"
#include "get_endpoint.hpp"
#include "handler_call_tracker.hpp"
#include "network_result.hpp"
#include "streams.hpp"
using namespace boost::mysql::test;
using boost::mysql::error_code;
using boost::mysql::error_info;
using boost::mysql::field_view;
using boost::mysql::handshake_params;
using boost::mysql::row;
using boost::mysql::row_view;
using boost::mysql::rows_view;
namespace {
template <class R>
struct handler
{
std::promise<network_result<R>>& prom_;
handler_call_tracker& call_tracker_;
// For operations with a return type
void operator()(error_code code, R retval)
{
call_tracker_.register_call();
prom_.set_value(network_result<R>(code, std::move(retval)));
}
// For operations without a return type (R=no_result)
void operator()(error_code code)
{
call_tracker_.register_call();
prom_.set_value(network_result<R>(code));
}
};
template <class R, class Callable>
network_result<R> impl(Callable&& cb)
{
handler_call_tracker call_tracker;
std::promise<network_result<R>> prom;
cb(handler<R>{prom, call_tracker});
return prom.get_future().get();
}
template <class Stream>
class async_callback_noerrinfo_resultset : public er_resultset_base<Stream>
{
public:
network_result<row_view> read_one() override
{
return impl<row_view>([&](handler<row_view> h) {
return this->obj().async_read_one(std::move(h));
});
}
network_result<rows_view> read_some() override
{
return impl<rows_view>([&](handler<rows_view> h) {
return this->obj().async_read_some(std::move(h));
});
}
network_result<rows_view> read_all() override
{
return impl<rows_view>([&](handler<rows_view> h) {
return this->obj().async_read_all(std::move(h));
});
}
};
template <class Stream>
class async_callback_noerrinfo_statement : public er_statement_base<Stream>
{
public:
network_result<no_result> execute_params(
const boost::mysql::execute_params<value_list_it>& params,
er_resultset& result
) override
{
return impl<no_result>([&](handler<no_result> h) {
return this->obj().async_execute(params, this->cast(result), std::move(h));
});
}
network_result<no_result> execute_collection(
const std::vector<field_view>& values,
er_resultset& result
) override
{
return impl<no_result>([&](handler<no_result> h) {
return this->obj().async_execute(values, this->cast(result), std::move(h));
});
}
network_result<no_result> close() override
{
return impl<no_result>([&](handler<no_result> h) {
return this->obj().async_close(std::move(h));
});
}
};
template <class Stream>
class async_callback_noerrinfo_connection : public er_connection_base<Stream>
{
public:
using er_connection_base<Stream>::er_connection_base;
network_result<no_result> physical_connect(er_endpoint kind) override
{
return impl<no_result>([&](handler<no_result> h) {
return this->conn_.stream().lowest_layer().async_connect(
get_endpoint<Stream>(kind),
std::move(h)
);
});
}
network_result<no_result> connect(er_endpoint kind, const handshake_params& params) override
{
return impl<no_result>([&](handler<no_result> h) {
return this->conn_.async_connect(get_endpoint<Stream>(kind), params, std::move(h));
});
}
network_result<no_result> handshake(const handshake_params& params) override
{
return impl<no_result>([&](handler<no_result> h) {
return this->conn_.async_handshake(params, std::move(h));
});
}
network_result<no_result> query(boost::string_view query, er_resultset& result) override
{
return impl<no_result>([&](handler<no_result> h) {
return this->conn_.async_query(query, this->cast(result), std::move(h));
});
}
network_result<no_result> prepare_statement(boost::string_view statement, er_statement& stmt)
override
{
return impl<no_result>([&](handler<no_result> h) {
return this->conn_.async_prepare_statement(statement, this->cast(stmt), std::move(h));
});
}
network_result<no_result> quit() override
{
return impl<no_result>([&](handler<no_result> h) {
return this->conn_.async_quit(std::move(h));
});
}
network_result<no_result> close() override
{
return impl<no_result>([&](handler<no_result> h) {
return this->conn_.async_close(std::move(h));
});
}
};
template <class Stream>
class async_callback_noerrinfo_variant : public er_network_variant_base<
Stream,
async_callback_noerrinfo_connection,
async_callback_noerrinfo_statement,
async_callback_noerrinfo_resultset>
{
public:
const char* variant_name() const override { return "async_callback_noerrinfo"; }
};
async_callback_noerrinfo_variant<tcp_socket> tcp;
async_callback_noerrinfo_variant<tcp_ssl_socket> tcp_ssl;
} // namespace
void boost::mysql::test::add_async_callback_noerrinfo(std::vector<er_network_variant*>& output)
{
output.push_back(&tcp);
output.push_back(&tcp_ssl);
}