summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorOleg Morozenkov <m@oleg.rocks>2023-12-02 12:30:31 +0300
committerGitHub <noreply@github.com>2023-12-02 12:30:31 +0300
commitf1c2dbad1c9674f82e61b7cf76cdc618a2dba852 (patch)
tree66f31434af61a5b4dda9a3591d67fc528273b505 /test
parent782596206764e663b9b45401b447871f21ce62b2 (diff)
parent658f37f93d1a0c31c447adb3022cfd6cee4a1876 (diff)
Merge pull request #289 from Temomik/master
Added ability to handle error codes from all Api requests
Diffstat (limited to 'test')
-rw-r--r--test/CMakeLists.txt1
-rw-r--r--test/tgbot/Api.cpp64
2 files changed, 65 insertions, 0 deletions
diff --git a/test/CMakeLists.txt b/test/CMakeLists.txt
index 0cce236..899035f 100644
--- a/test/CMakeLists.txt
+++ b/test/CMakeLists.txt
@@ -1,5 +1,6 @@
set(TEST_SRC_LIST
main.cpp
+ tgbot/Api.cpp
tgbot/net/Url.cpp
tgbot/net/HttpParser.cpp
tgbot/tools/StringTools.cpp
diff --git a/test/tgbot/Api.cpp b/test/tgbot/Api.cpp
new file mode 100644
index 0000000..2575865
--- /dev/null
+++ b/test/tgbot/Api.cpp
@@ -0,0 +1,64 @@
+#include <string>
+#include <vector>
+
+#include <boost/test/unit_test.hpp>
+
+#include "tgbot/net/HttpClient.h"
+#include "tgbot/Api.h"
+#include "tgbot/TgException.h"
+
+using namespace std;
+using namespace TgBot;
+
+typedef TgException::ErrorCode TgErrorCode;
+
+class TestableApi : public Api {
+public:
+ using Api::Api;
+ using Api::sendRequest;
+};
+
+class HttpClientMock : public HttpClient {
+public:
+ std::string makeRequest(const Url& url, const std::vector<HttpReqArg>& args) const override
+ {return response;};
+
+ int getRequestMaxRetries() const override { return 0;};
+ int getRequestBackoff() const override {return 1;};
+
+ string response;
+};
+
+bool Request(TgErrorCode expectedCode, const string& response) {
+ HttpClientMock httpClientMock;
+ httpClientMock.response = response;
+
+ TestableApi api("token", httpClientMock, "url");
+
+ try {
+ api.sendRequest("", vector<HttpReqArg>());
+ } catch (TgException& exception) {
+ return exception.errorCode == expectedCode;
+ }
+
+ return false;
+}
+
+BOOST_AUTO_TEST_SUITE(tApi)
+
+BOOST_AUTO_TEST_CASE(sendRequest) {
+ BOOST_CHECK(Request(TgErrorCode::HtmlResponse, "<html>"));
+ BOOST_CHECK(Request(TgErrorCode::Undefined, "{\"ok\": false}"));
+ BOOST_CHECK(Request(TgErrorCode::Undefined, "{\"ok\": false, \"error_code\":0}"));
+
+ BOOST_CHECK(Request(TgErrorCode::BadRequest, "{\"ok\": false, \"error_code\":400}"));
+ BOOST_CHECK(Request(TgErrorCode::Unauthorized, "{\"ok\": false, \"error_code\":401}"));
+ BOOST_CHECK(Request(TgErrorCode::Forbidden, "{\"ok\": false, \"error_code\":403}"));
+ BOOST_CHECK(Request(TgErrorCode::NotFound, "{\"ok\": false, \"error_code\":404}"));
+ BOOST_CHECK(Request(TgErrorCode::Flood, "{\"ok\": false, \"error_code\":402}"));
+ BOOST_CHECK(Request(TgErrorCode::Internal, "{\"ok\": false, \"error_code\":500}"));
+
+ BOOST_CHECK(Request(TgErrorCode::InvalidJson, "error_code:101"));
+}
+
+BOOST_AUTO_TEST_SUITE_END()