diff options
author | Daniil Cherednik <[email protected]> | 2022-11-24 13:14:34 +0300 |
---|---|---|
committer | Daniil Cherednik <[email protected]> | 2022-11-24 14:46:00 +0300 |
commit | 87f7fceed34bcafb8aaff351dd493a35c916986f (patch) | |
tree | 26809ec8f550aba8eb019e59adc3d48e51913eb2 /library/cpp/testing/mock_server | |
parent | 11bc4015b8010ae201bf3eb33db7dba425aca35e (diff) |
Ydb stable 22-4-4322.4.43
x-stable-origin-commit: 8d49d46cc834835bf3e50870516acd7376a63bcf
Diffstat (limited to 'library/cpp/testing/mock_server')
-rw-r--r-- | library/cpp/testing/mock_server/server.cpp | 70 | ||||
-rw-r--r-- | library/cpp/testing/mock_server/server.h | 52 |
2 files changed, 122 insertions, 0 deletions
diff --git a/library/cpp/testing/mock_server/server.cpp b/library/cpp/testing/mock_server/server.cpp new file mode 100644 index 00000000000..d310c76ad32 --- /dev/null +++ b/library/cpp/testing/mock_server/server.cpp @@ -0,0 +1,70 @@ +#include "server.h" + +#include <util/system/thread.h> + +namespace NMock { + class TMockServer::TCallBack: public THttpServer::ICallBack { + TGenerator Generator_; + + TClientRequest* CreateClient() override { + return Generator_(); + } + + public: + void SetGenerator(TGenerator generator) { + Generator_ = generator; + } + + TCallBack(TGenerator& generator) + : Generator_(generator) + { + } + }; + + static THttpServerOptions createDefaultOptions(ui16 port) { + THttpServerOptions o; + o.AddBindAddress("localhost", port); + o.SetThreads(1); + o.SetMaxConnections(300); + o.SetMaxQueueSize(30); + return o; + } + + TMockServer::TMockServer(ui16 port, TGenerator generator) + : TMockServer(createDefaultOptions(port), generator) + { + } + + TMockServer::TMockServer(const THttpServerOptions& options, TGenerator generator) + : Cb_(MakeHolder<TCallBack>(generator)) + , Server_(MakeHolder<THttpServer>(Cb_.Get(), options)) + , Thread_(MakeHolder<TThread>(Worker, this)) + , Ev_(MakeHolder<TAutoEvent>()) + { + Thread_->Start(); + Ev_->Wait(); + } + + TMockServer::~TMockServer() { + Server_->Stop(); + Thread_->Join(); + } + + size_t TMockServer::GetClientCount() const { + return Server_->GetClientCount(); + } + + void TMockServer::SetGenerator(TMockServer::TGenerator generator) { + Cb_->SetGenerator(generator); + } + + void* TMockServer::Worker(void* arg) { + TMockServer& this_ = *static_cast<TMockServer*>(arg); + + this_.Server_->Start(); + this_.Ev_->Signal(); + this_.Server_->Wait(); + + return nullptr; + } +} diff --git a/library/cpp/testing/mock_server/server.h b/library/cpp/testing/mock_server/server.h new file mode 100644 index 00000000000..6d57cebf401 --- /dev/null +++ b/library/cpp/testing/mock_server/server.h @@ -0,0 +1,52 @@ +#pragma once + +#include <library/cpp/http/misc/parsed_request.h> +#include <library/cpp/http/server/http.h> +#include <library/cpp/http/server/response.h> +#include <library/cpp/testing/unittest/tests_data.h> + +#include <util/system/event.h> + +#include <functional> + +class TAutoEvent; +class TThread; + +namespace NMock { + class TMockServer { + public: + using TGenerator = std::function<TRequestReplier*()>; + + TMockServer(ui16 port, TGenerator generator); + TMockServer(const THttpServerOptions& options, TGenerator generator); + + ~TMockServer(); + + size_t GetClientCount() const; + void SetGenerator(TGenerator generator); + + private: + static void* Worker(void* arg); + + class TCallBack; + + THolder<TCallBack> Cb_; + THolder<THttpServer> Server_; + THolder<TThread> Thread_; + THolder<TAutoEvent> Ev_; + }; + + class TPong: public TRequestReplier { + public: + bool DoReply(const TReplyParams& params) override { + const TParsedHttpFull parsed(params.Input.FirstLine()); + + const HttpCodes code = parsed.Path == "/ping" ? HTTP_OK : HTTP_NOT_FOUND; + + THttpResponse resp(code); + resp.OutTo(params.Output); + + return true; + } + }; +} |