summaryrefslogtreecommitdiff
path: root/test/tgbot
diff options
context:
space:
mode:
authorOleg Morozenkov <m@oleg.rocks>2018-07-23 02:35:50 +0300
committerOleg Morozenkov <m@oleg.rocks>2018-07-23 02:35:50 +0300
commit98b8b7e4338b71ee46c4301b0bf2ae667be9a99d (patch)
tree32f8b0d32048b2d83b57773c0efa3db9600b8701 /test/tgbot
parent1dd3affe306793d2129f121c11e43c45ae8690da (diff)
parent167e3e7607e43a0f06c7f87ced94f481e6525b0e (diff)
Merge branch 'master' into nicholascw-master
Diffstat (limited to 'test/tgbot')
-rw-r--r--test/tgbot/net/HttpParser.cpp167
-rw-r--r--test/tgbot/net/Url.cpp36
-rw-r--r--test/tgbot/tools/StringTools.cpp36
3 files changed, 118 insertions, 121 deletions
diff --git a/test/tgbot/net/HttpParser.cpp b/test/tgbot/net/HttpParser.cpp
index d0a3703..0d588ef 100644
--- a/test/tgbot/net/HttpParser.cpp
+++ b/test/tgbot/net/HttpParser.cpp
@@ -32,106 +32,103 @@ using namespace TgBot;
BOOST_AUTO_TEST_SUITE(tHttpParser)
BOOST_AUTO_TEST_CASE(generateRequest) {
- vector<HttpReqArg> args = { HttpReqArg("email", "test@example.com"), HttpReqArg("text", "Hello, world!") };
- string t = HttpParser::getInstance().generateRequest(Url("http://example.com/index.html"), args, true);
- string e = ""
- "POST /index.html HTTP/1.1\r\n"
- "Host: example.com\r\n"
- "Connection: keep-alive\r\n"
- "Content-Type: application/x-www-form-urlencoded\r\n"
- "Content-Length: 49\r\n"
- "\r\n"
- "email=test%40example.com&text=Hello%2C%20world%21";
- BOOST_CHECK_MESSAGE(t == e, diffS(t, e));
+ vector<HttpReqArg> args = { HttpReqArg("email", "test@example.com"), HttpReqArg("text", "Hello, world!") };
+ string t = HttpParser().generateRequest(Url("http://example.com/index.html"), args, true);
+ string e = ""
+ "POST /index.html HTTP/1.1\r\n"
+ "Host: example.com\r\n"
+ "Connection: keep-alive\r\n"
+ "Content-Type: application/x-www-form-urlencoded\r\n"
+ "Content-Length: 49\r\n"
+ "\r\n"
+ "email=test%40example.com&text=Hello%2C%20world%21";
+ BOOST_CHECK_MESSAGE(t == e, diffS(t, e));
}
BOOST_AUTO_TEST_CASE(generateMultipartFormData) {
- vector<HttpReqArg> args = { HttpReqArg("email", "test@example.com"), HttpReqArg("text", "Hello, world!", true) };
- string boundary = HttpParser::getInstance().generateMultipartBoundary(args);
- string t = HttpParser::getInstance().generateMultipartFormData(args, boundary);
- string e = ""
- "--" + boundary + "\r\n"
- "Content-Disposition: form-data; name=\"email\"\r\n"
- "\r\n"
- "test@example.com\r\n"
- "--" + boundary + "\r\n"
- "Content-Disposition: form-data; name=\"text\"; filename=\"\"\r\n"
- "Content-Type: text/plain\r\n"
- "\r\n"
- "Hello, world!\r\n"
- "--" + boundary + "--\r\n";
- BOOST_CHECK_MESSAGE(t == e, diffS(t, e));
+ vector<HttpReqArg> args = { HttpReqArg("email", "test@example.com"), HttpReqArg("text", "Hello, world!", true) };
+ string boundary = HttpParser().generateMultipartBoundary(args);
+ string t = HttpParser().generateMultipartFormData(args, boundary);
+ string e = ""
+ "--" + boundary + "\r\n"
+ "Content-Disposition: form-data; name=\"email\"\r\n"
+ "\r\n"
+ "test@example.com\r\n"
+ "--" + boundary + "\r\n"
+ "Content-Disposition: form-data; name=\"text\"; filename=\"\"\r\n"
+ "Content-Type: text/plain\r\n"
+ "\r\n"
+ "Hello, world!\r\n"
+ "--" + boundary + "--\r\n";
+ BOOST_CHECK_MESSAGE(t == e, diffS(t, e));
}
BOOST_AUTO_TEST_CASE(generateWwwFormUrlencoded) {
- vector<HttpReqArg> args = { HttpReqArg("email", "test@example.com"), HttpReqArg("text", "Hello, world!") };
- string t = HttpParser::getInstance().generateWwwFormUrlencoded(args);
- string e = "email=test%40example.com&text=Hello%2C%20world%21";
- BOOST_CHECK_MESSAGE(t == e, diffS(t, e));
+ vector<HttpReqArg> args = { HttpReqArg("email", "test@example.com"), HttpReqArg("text", "Hello, world!") };
+ string t = HttpParser().generateWwwFormUrlencoded(args);
+ string e = "email=test%40example.com&text=Hello%2C%20world%21";
+ BOOST_CHECK_MESSAGE(t == e, diffS(t, e));
}
BOOST_AUTO_TEST_CASE(generateResponse) {
- string t = HttpParser::getInstance().generateResponse("testdata");
- string e = ""
- "HTTP/1.1 200 OK\r\n"
- "Content-Type: text/plain\r\n"
- "Content-Length: 8\r\n"
- "\r\n"
- "testdata";
- BOOST_CHECK_MESSAGE(t == e, diffS(t, e));
+ string t = HttpParser().generateResponse("testdata", "text/plain", 200, "OK", false);
+ string e = ""
+ "HTTP/1.1 200 OK\r\n"
+ "Content-Type: text/plain\r\n"
+ "Content-Length: 8\r\n"
+ "Connection: close\r\n"
+ "\r\n"
+ "testdata";
+ BOOST_CHECK_MESSAGE(t == e, diffS(t, e));
}
BOOST_AUTO_TEST_CASE(parseRequest) {
- string data = ""
- "POST /index.html HTTP/1.1\r\n"
- "Host: example.com\r\n"
- "Connection: keep-alive\r\n"
- "Content-Type: text/plain\r\n"
- "Content-Length: 8\r\n"
- "\r\n"
- "testdata";
-
- unordered_map<string, string> tHeaders;
- string t = HttpParser::getInstance().parseRequest(data, tHeaders);
-
- unordered_map<string, string> eHeaders = {
- { "method", "POST" },
- { "path", "/index.html" },
- { "host", "example.com" },
- { "connection", "keep-alive" },
- { "content-type", "text/plain" },
- { "content-length", "8" }
- };
- string e = "testdata";
-
- BOOST_CHECK_MESSAGE(t == e, diffS(t, e));
- BOOST_CHECK_MESSAGE(tHeaders == eHeaders, diff(tHeaders, eHeaders, [](const pair<const string, string>& item) -> string {
- return item.first + '=' + item.second;
- }));
+ string data = ""
+ "POST /index.html HTTP/1.1\r\n"
+ "Host: example.com\r\n"
+ "Connection: keep-alive\r\n"
+ "Content-Type: text/plain\r\n"
+ "Content-Length: 8\r\n"
+ "\r\n"
+ "testdata";
+
+ unordered_map<string, string> tHeaders = HttpParser().parseHeader(data.substr(0, data.rfind("\r\n")), true);
+ string tBody = HttpParser().extractBody(data);
+
+ unordered_map<string, string> eHeaders = {
+ { "_method", "POST" },
+ { "_path", "/index.html" },
+ { "Host", "example.com" },
+ { "Connection", "keep-alive" },
+ { "Content-Type", "text/plain" },
+ { "Content-Length", "8" }
+ };
+ string eBody = "testdata";
+
+ BOOST_CHECK_MESSAGE(tBody == eBody, diffS(tBody, eBody));
+ BOOST_CHECK_MESSAGE(tHeaders == eHeaders, diffMSS(tHeaders, eHeaders));
}
BOOST_AUTO_TEST_CASE(parseResponse) {
- string data = ""
- "HTTP/1.1 200 OK\r\n"
- "Content-Type: text/plain\r\n"
- "Content-Length: 8\r\n"
- "\r\n"
- "testdata";
-
- unordered_map<string, string> tHeaders;
- string t = HttpParser::getInstance().parseResponse(data, tHeaders);
-
- unordered_map<string, string> eHeaders = {
- { "status", "200" },
- { "content-type", "text/plain" },
- { "content-length", "8" }
- };
- string e = "testdata";
-
- BOOST_CHECK_MESSAGE(t == e, diffS(t, e));
- BOOST_CHECK_MESSAGE(tHeaders == eHeaders, diff(tHeaders, eHeaders, [](const pair<const string, string>& item) -> string {
- return item.first + '=' + item.second;
- }));
+ string data = ""
+ "HTTP/1.1 200 OK\r\n"
+ "Content-Type: text/plain\r\n"
+ "Content-Length: 8\r\n"
+ "\r\n"
+ "testdata";
+
+ unordered_map<string, string> tHeaders = HttpParser().parseHeader(data.substr(0, data.rfind("\r\n")), false);
+ string tBody = HttpParser().extractBody(data);
+
+ unordered_map<string, string> eHeaders = {
+ { "_status", "200" },
+ { "Content-Type", "text/plain" },
+ { "Content-Length", "8" }
+ };
+ string eBody = "testdata";
+
+ BOOST_CHECK_MESSAGE(tBody == eBody, diffS(tBody, eBody));
+ BOOST_CHECK_MESSAGE(tHeaders == eHeaders, diffMSS(tHeaders, eHeaders));
}
BOOST_AUTO_TEST_SUITE_END()
diff --git a/test/tgbot/net/Url.cpp b/test/tgbot/net/Url.cpp
index abd90cb..0974ab6 100644
--- a/test/tgbot/net/Url.cpp
+++ b/test/tgbot/net/Url.cpp
@@ -29,30 +29,30 @@ using namespace TgBot;
BOOST_AUTO_TEST_SUITE(tUrl)
BOOST_AUTO_TEST_CASE(parsingUrlNoPath) {
- Url t("https://test.example.com?test=123&123=test#title");
- BOOST_CHECK_EQUAL(t.protocol, "https");
- BOOST_CHECK_EQUAL(t.host, "test.example.com");
- BOOST_CHECK_EQUAL(t.path, "/");
- BOOST_CHECK_EQUAL(t.query, "test=123&123=test");
- BOOST_CHECK_EQUAL(t.fragment, "title");
+ Url t("https://test.example.com?test=123&123=test#title");
+ BOOST_CHECK_EQUAL(t.protocol, "https");
+ BOOST_CHECK_EQUAL(t.host, "test.example.com");
+ BOOST_CHECK_EQUAL(t.path, "/");
+ BOOST_CHECK_EQUAL(t.query, "test=123&123=test");
+ BOOST_CHECK_EQUAL(t.fragment, "title");
}
BOOST_AUTO_TEST_CASE(parsingUrlNoPathAndQuery) {
- Url t("https://test.example.com#title");
- BOOST_CHECK_EQUAL(t.protocol, "https");
- BOOST_CHECK_EQUAL(t.host, "test.example.com");
- BOOST_CHECK_EQUAL(t.path, "/");
- BOOST_CHECK_EQUAL(t.query, "");
- BOOST_CHECK_EQUAL(t.fragment, "title");
+ Url t("https://test.example.com#title");
+ BOOST_CHECK_EQUAL(t.protocol, "https");
+ BOOST_CHECK_EQUAL(t.host, "test.example.com");
+ BOOST_CHECK_EQUAL(t.path, "/");
+ BOOST_CHECK_EQUAL(t.query, "");
+ BOOST_CHECK_EQUAL(t.fragment, "title");
}
BOOST_AUTO_TEST_CASE(parsingUrlFull) {
- Url t("https://test.example.com/example-page/index.html?test=123&123=test#title");
- BOOST_CHECK_EQUAL(t.protocol, "https");
- BOOST_CHECK_EQUAL(t.host, "test.example.com");
- BOOST_CHECK_EQUAL(t.path, "/example-page/index.html");
- BOOST_CHECK_EQUAL(t.query, "test=123&123=test");
- BOOST_CHECK_EQUAL(t.fragment, "title");
+ Url t("https://test.example.com/example-page/index.html?test=123&123=test#title");
+ BOOST_CHECK_EQUAL(t.protocol, "https");
+ BOOST_CHECK_EQUAL(t.host, "test.example.com");
+ BOOST_CHECK_EQUAL(t.path, "/example-page/index.html");
+ BOOST_CHECK_EQUAL(t.query, "test=123&123=test");
+ BOOST_CHECK_EQUAL(t.fragment, "title");
}
BOOST_AUTO_TEST_SUITE_END()
diff --git a/test/tgbot/tools/StringTools.cpp b/test/tgbot/tools/StringTools.cpp
index 969c3d8..d92fc86 100644
--- a/test/tgbot/tools/StringTools.cpp
+++ b/test/tgbot/tools/StringTools.cpp
@@ -35,36 +35,36 @@ using namespace std;
BOOST_AUTO_TEST_SUITE(tStringTools)
BOOST_AUTO_TEST_CASE(startsWith) {
- BOOST_CHECK(StringTools::startsWith("abc123", "abc"));
- BOOST_CHECK(!StringTools::startsWith("abc123", "aac"));
- BOOST_CHECK(!StringTools::startsWith("abc123", "Xabc"));
- BOOST_CHECK(!StringTools::startsWith("abc123", "abcX"));
- BOOST_CHECK(!StringTools::startsWith("abc", "abc123"));
+ BOOST_CHECK(StringTools::startsWith("abc123", "abc"));
+ BOOST_CHECK(!StringTools::startsWith("abc123", "aac"));
+ BOOST_CHECK(!StringTools::startsWith("abc123", "Xabc"));
+ BOOST_CHECK(!StringTools::startsWith("abc123", "abcX"));
+ BOOST_CHECK(!StringTools::startsWith("abc", "abc123"));
}
BOOST_AUTO_TEST_CASE(endsWith) {
- BOOST_CHECK(StringTools::endsWith("abc123", "123"));
- BOOST_CHECK(!StringTools::endsWith("abc123", "113"));
- BOOST_CHECK(!StringTools::endsWith("abc123", "X123"));
- BOOST_CHECK(!StringTools::endsWith("abc123", "123X"));
- BOOST_CHECK(!StringTools::endsWith("123", "abc123"));
+ BOOST_CHECK(StringTools::endsWith("abc123", "123"));
+ BOOST_CHECK(!StringTools::endsWith("abc123", "113"));
+ BOOST_CHECK(!StringTools::endsWith("abc123", "X123"));
+ BOOST_CHECK(!StringTools::endsWith("abc123", "123X"));
+ BOOST_CHECK(!StringTools::endsWith("123", "abc123"));
}
BOOST_AUTO_TEST_CASE(split) {
- BOOST_CHECK(StringTools::split("123 456 789", ' ') == vector<string>({"123", "456", "789"}));
- BOOST_CHECK(StringTools::split("aaa", ' ') == vector<string>({"aaa"}));
+ BOOST_CHECK(StringTools::split("123 456 789", ' ') == vector<string>({"123", "456", "789"}));
+ BOOST_CHECK(StringTools::split("aaa", ' ') == vector<string>({"aaa"}));
}
BOOST_AUTO_TEST_CASE(urlEncode) {
- string t = StringTools::urlEncode("`1234567890-qwertyuiop[]\\asdfghjkl;'zxcvbnm,./~!@#$%^&*()_+QWERTYUIOP{}|ASDFGHJKL:ZXCVBNM<>? ");
- string e = "%601234567890-qwertyuiop%5B%5D%5Casdfghjkl%3B%27zxcvbnm%2C.%2F~%21%40%23%24%25%5E%26%2A%28%29_%2BQWERTYUIOP%7B%7D%7CASDFGHJKL:ZXCVBNM%3C%3E%3F%20";
- BOOST_CHECK_MESSAGE(t == e, diffS(t, e));
+ string t = StringTools::urlEncode("`1234567890-qwertyuiop[]\\asdfghjkl;'zxcvbnm,./~!@#$%^&*()_+QWERTYUIOP{}|ASDFGHJKL:ZXCVBNM<>? ");
+ string e = "%601234567890-qwertyuiop%5B%5D%5Casdfghjkl%3B%27zxcvbnm%2C.%2F~%21%40%23%24%25%5E%26%2A%28%29_%2BQWERTYUIOP%7B%7D%7CASDFGHJKL:ZXCVBNM%3C%3E%3F%20";
+ BOOST_CHECK_MESSAGE(t == e, diffS(t, e));
}
BOOST_AUTO_TEST_CASE(urlDecode) {
- string t = StringTools::urlDecode("%601234567890-qwertyuiop%5b%5d%5casdfghjkl%3b%27zxcvbnm%2c.%2f~%21%40%23%24%25%5e%26%2a%28%29_%2bQWERTYUIOP%7b%7d%7cASDFGHJKL%3aZXCVBNM%3c%3e%3f%20");
- string e = "`1234567890-qwertyuiop[]\\asdfghjkl;'zxcvbnm,./~!@#$%^&*()_+QWERTYUIOP{}|ASDFGHJKL:ZXCVBNM<>? ";
- BOOST_CHECK_MESSAGE(t == e, diffS(t, e));
+ string t = StringTools::urlDecode("%601234567890-qwertyuiop%5b%5d%5casdfghjkl%3b%27zxcvbnm%2c.%2f~%21%40%23%24%25%5e%26%2a%28%29_%2bQWERTYUIOP%7b%7d%7cASDFGHJKL%3aZXCVBNM%3c%3e%3f%20");
+ string e = "`1234567890-qwertyuiop[]\\asdfghjkl;'zxcvbnm,./~!@#$%^&*()_+QWERTYUIOP{}|ASDFGHJKL:ZXCVBNM<>? ";
+ BOOST_CHECK_MESSAGE(t == e, diffS(t, e));
}
BOOST_AUTO_TEST_SUITE_END()