#ifdef WIN32 #include #include #endif #define BOOST_TEST_MODULE AuthLoginExecutors #include #include #include "./../../src/endpoints_handlers/AuthLogoutExecutor.h" #include "../../src/DAO/MemoryAuthDAO.h" #include "./../../src/DAO/MySQLUserDAO.h" #include "./../../src/db/mysql_connector.h" #include "./../../src/exceptions/session_exception.h" #include "./../../src/helpers/helpers.h" const std::string kUUID = std::to_string(uad::Random()); using namespace std; using namespace uad; using namespace boost; using namespace beast; using namespace json; using RouteAuthLogoutExecutor = AuthLogoutExecutor, beast::http::string_body>; using Request = boost::beast::http::request>>; BOOST_AUTO_TEST_CASE(AuthRegistrationExecutor_Cant_Find_User_Token) { auto& argv = boost::unit_test::framework::master_test_suite().argv; const std::string mysql_credentials = argv[1]; mysqlx::Session* mysql_session = new mysqlx::Session(mysql_credentials); uad::SetMySqlSession(mysql_session); auto auth_dao = make_shared(GetMySqlSession()); auto executor = RouteAuthLogoutExecutor(GetMySqlSession(), auth_dao); Request req; value req_body; req_body.emplace_object(); req_body.as_object().emplace("token", "1234567890"); req.body() = "{ \"token\": abcde }"; req.content_length(req.body().size()); BOOST_CHECK_EXCEPTION(executor(std::move(req)), session_exception, [](const session_exception& e) -> bool { return e.code == beast::http::status::internal_server_error; }); mysql_session->close(); delete mysql_session; }