aboutsummaryrefslogtreecommitdiff
path: root/thirdparty/cpr/test/patch_tests.cpp
diff options
context:
space:
mode:
authorStefan Boberg <[email protected]>2025-10-24 19:32:01 +0200
committerGitHub Enterprise <[email protected]>2025-10-24 19:32:01 +0200
commit4cba4eb3f122c7a1a49b629b1c0656d7f817f001 (patch)
treee184821073167f6e81a75193efca91013d7b359b /thirdparty/cpr/test/patch_tests.cpp
parentfixed progress bar when scanning changed local files (#608) (diff)
downloadzen-4cba4eb3f122c7a1a49b629b1c0656d7f817f001.tar.xz
zen-4cba4eb3f122c7a1a49b629b1c0656d7f817f001.zip
move cpr in-tree (#605)
* added cpr 1.10.5 in-tree to allow updates to vcpkg without breaking the build * added asio 1.29.0 in-tree to remove one more vcpkg dependency * bumped vcpkg to 2024.06.15 to address failure to build due to use of deprecated binaries in vcpkg (404 error: `https://mirror.msys2.org/mingw/mingw64/mingw-w64-x86_64-pkgconf-1~2.1.0-1-any.pkg.tar.zst` during build)
Diffstat (limited to 'thirdparty/cpr/test/patch_tests.cpp')
-rw-r--r--thirdparty/cpr/test/patch_tests.cpp276
1 files changed, 276 insertions, 0 deletions
diff --git a/thirdparty/cpr/test/patch_tests.cpp b/thirdparty/cpr/test/patch_tests.cpp
new file mode 100644
index 000000000..22d0b4f41
--- /dev/null
+++ b/thirdparty/cpr/test/patch_tests.cpp
@@ -0,0 +1,276 @@
+#include <gtest/gtest.h>
+
+#include <string>
+
+#include <cpr/cpr.h>
+
+#include "httpServer.hpp"
+
+using namespace cpr;
+
+static HttpServer* server = new HttpServer();
+
+TEST(PatchTests, PatchTest) {
+ Url url{server->GetBaseUrl() + "/patch.html"};
+ Payload payload{{"x", "5"}};
+ Response response = cpr::Patch(url, payload);
+ std::string expected_text{
+ "{\n"
+ " \"x\": 5\n"
+ "}"};
+ EXPECT_EQ(expected_text, response.text);
+ EXPECT_EQ(url, response.url);
+ EXPECT_EQ(std::string{"application/json"}, response.header["content-type"]);
+ EXPECT_EQ(200, response.status_code);
+ EXPECT_EQ(ErrorCode::OK, response.error.code);
+}
+
+TEST(PatchTests, PatchUnallowedTest) {
+ Url url{server->GetBaseUrl() + "/patch_unallowed.html"};
+ Payload payload{{"x", "5"}};
+ Response response = cpr::Patch(url, payload);
+ std::string expected_text{"Method Not Allowed"};
+ EXPECT_EQ(expected_text, response.text);
+ EXPECT_EQ(url, response.url);
+ EXPECT_EQ(std::string{"text/plain"}, response.header["content-type"]);
+ EXPECT_EQ(405, response.status_code);
+ EXPECT_EQ(ErrorCode::OK, response.error.code);
+}
+
+TEST(PatchTests, SessionPatchTest) {
+ Url url{server->GetBaseUrl() + "/patch.html"};
+ Payload payload{{"x", "5"}};
+ Session session;
+ session.SetUrl(url);
+ session.SetPayload(payload);
+ Response response = session.Patch();
+ std::string expected_text{
+ "{\n"
+ " \"x\": 5\n"
+ "}"};
+ EXPECT_EQ(expected_text, response.text);
+ EXPECT_EQ(url, response.url);
+ EXPECT_EQ(std::string{"application/json"}, response.header["content-type"]);
+ EXPECT_EQ(200, response.status_code);
+ EXPECT_EQ(ErrorCode::OK, response.error.code);
+}
+
+TEST(PatchTests, SessionPatchUnallowedTest) {
+ Url url{server->GetBaseUrl() + "/patch_unallowed.html"};
+ Payload payload{{"x", "5"}};
+ Session session;
+ session.SetUrl(url);
+ session.SetPayload(payload);
+ Response response = session.Patch();
+ std::string expected_text{"Method Not Allowed"};
+ EXPECT_EQ(expected_text, response.text);
+ EXPECT_EQ(url, response.url);
+ EXPECT_EQ(std::string{"text/plain"}, response.header["content-type"]);
+ EXPECT_EQ(405, response.status_code);
+ EXPECT_EQ(ErrorCode::OK, response.error.code);
+}
+
+TEST(PatchTests, SessionPatchAfterGetTest) {
+ Session session;
+ {
+ Url url{server->GetBaseUrl() + "/get.html"};
+ session.SetUrl(url);
+ Response response = session.Get();
+ }
+ Url url{server->GetBaseUrl() + "/patch.html"};
+ Payload payload{{"x", "5"}};
+ session.SetUrl(url);
+ session.SetPayload(payload);
+ Response response = session.Patch();
+ std::string expected_text{
+ "{\n"
+ " \"x\": 5\n"
+ "}"};
+ EXPECT_EQ(expected_text, response.text);
+ EXPECT_EQ(url, response.url);
+ EXPECT_EQ(std::string{"application/json"}, response.header["content-type"]);
+ EXPECT_EQ(200, response.status_code);
+ EXPECT_EQ(ErrorCode::OK, response.error.code);
+}
+
+TEST(PatchTests, SessionPatchUnallowedAfterGetTest) {
+ Session session;
+ {
+ Url url{server->GetBaseUrl() + "/get.html"};
+ session.SetUrl(url);
+ Response response = session.Get();
+ }
+ Url url{server->GetBaseUrl() + "/patch_unallowed.html"};
+ Payload payload{{"x", "5"}};
+ session.SetUrl(url);
+ session.SetPayload(payload);
+ Response response = session.Patch();
+ std::string expected_text{"Method Not Allowed"};
+ EXPECT_EQ(expected_text, response.text);
+ EXPECT_EQ(url, response.url);
+ EXPECT_EQ(std::string{"text/plain"}, response.header["content-type"]);
+ EXPECT_EQ(405, response.status_code);
+ EXPECT_EQ(ErrorCode::OK, response.error.code);
+}
+
+TEST(PatchTests, SessionPatchAfterHeadTest) {
+ Session session;
+ {
+ Url url{server->GetBaseUrl() + "/get.html"};
+ session.SetUrl(url);
+ Response response = session.Head();
+ }
+ Url url{server->GetBaseUrl() + "/patch.html"};
+ Payload payload{{"x", "5"}};
+ session.SetUrl(url);
+ session.SetPayload(payload);
+ Response response = session.Patch();
+ std::string expected_text{
+ "{\n"
+ " \"x\": 5\n"
+ "}"};
+ EXPECT_EQ(expected_text, response.text);
+ EXPECT_EQ(url, response.url);
+ EXPECT_EQ(std::string{"application/json"}, response.header["content-type"]);
+ EXPECT_EQ(200, response.status_code);
+ EXPECT_EQ(ErrorCode::OK, response.error.code);
+}
+
+TEST(PatchTests, SessionPatchUnallowedAfterHeadTest) {
+ Session session;
+ {
+ Url url{server->GetBaseUrl() + "/get.html"};
+ session.SetUrl(url);
+ Response response = session.Head();
+ }
+ Url url{server->GetBaseUrl() + "/patch_unallowed.html"};
+ Payload payload{{"x", "5"}};
+ session.SetUrl(url);
+ session.SetPayload(payload);
+ Response response = session.Patch();
+ std::string expected_text{"Method Not Allowed"};
+ EXPECT_EQ(expected_text, response.text);
+ EXPECT_EQ(url, response.url);
+ EXPECT_EQ(std::string{"text/plain"}, response.header["content-type"]);
+ EXPECT_EQ(405, response.status_code);
+ EXPECT_EQ(ErrorCode::OK, response.error.code);
+}
+
+TEST(PatchTests, SessionPatchAfterPostTest) {
+ Session session;
+ {
+ Url url{server->GetBaseUrl() + "/url_post.html"};
+ Payload payload{{"x", "5"}};
+ session.SetUrl(url);
+ Response response = session.Post();
+ }
+ Url url{server->GetBaseUrl() + "/patch.html"};
+ Payload payload{{"x", "5"}};
+ session.SetUrl(url);
+ session.SetPayload(payload);
+ Response response = session.Patch();
+ std::string expected_text{
+ "{\n"
+ " \"x\": 5\n"
+ "}"};
+ EXPECT_EQ(expected_text, response.text);
+ EXPECT_EQ(url, response.url);
+ EXPECT_EQ(std::string{"application/json"}, response.header["content-type"]);
+ EXPECT_EQ(200, response.status_code);
+ EXPECT_EQ(ErrorCode::OK, response.error.code);
+}
+
+TEST(PatchTests, SessionPatchUnallowedAfterPostTest) {
+ Session session;
+ {
+ Url url{server->GetBaseUrl() + "/url_post.html"};
+ Payload payload{{"x", "5"}};
+ session.SetUrl(url);
+ Response response = session.Post();
+ }
+ Url url{server->GetBaseUrl() + "/patch_unallowed.html"};
+ Payload payload{{"x", "5"}};
+ session.SetUrl(url);
+ session.SetPayload(payload);
+ Response response = session.Patch();
+ std::string expected_text{"Method Not Allowed"};
+ EXPECT_EQ(expected_text, response.text);
+ EXPECT_EQ(url, response.url);
+ EXPECT_EQ(std::string{"text/plain"}, response.header["content-type"]);
+ EXPECT_EQ(405, response.status_code);
+ EXPECT_EQ(ErrorCode::OK, response.error.code);
+}
+
+TEST(PatchTests, AsyncPatchTest) {
+ Url url{server->GetBaseUrl() + "/patch.html"};
+ Payload payload{{"x", "5"}};
+ cpr::AsyncResponse future_response = cpr::PatchAsync(url, payload);
+ cpr::Response response = future_response.get();
+ std::string expected_text{
+ "{\n"
+ " \"x\": 5\n"
+ "}"};
+ EXPECT_EQ(expected_text, response.text);
+ EXPECT_EQ(url, response.url);
+ EXPECT_EQ(std::string{"application/json"}, response.header["content-type"]);
+ EXPECT_EQ(200, response.status_code);
+ EXPECT_EQ(ErrorCode::OK, response.error.code);
+}
+
+TEST(PatchTests, AsyncPatchUnallowedTest) {
+ Url url{server->GetBaseUrl() + "/patch_unallowed.html"};
+ Payload payload{{"x", "5"}};
+ cpr::AsyncResponse future_response = cpr::PatchAsync(url, payload);
+ cpr::Response response = future_response.get();
+ std::string expected_text{"Method Not Allowed"};
+ EXPECT_EQ(expected_text, response.text);
+ EXPECT_EQ(url, response.url);
+ EXPECT_EQ(std::string{"text/plain"}, response.header["content-type"]);
+ EXPECT_EQ(405, response.status_code);
+ EXPECT_EQ(ErrorCode::OK, response.error.code);
+}
+
+TEST(PatchTests, AsyncMultiplePatchTest) {
+ Url url{server->GetBaseUrl() + "/patch.html"};
+ Payload payload{{"x", "5"}};
+ std::vector<AsyncResponse> responses;
+ for (size_t i = 0; i < 10; ++i) {
+ responses.emplace_back(cpr::PatchAsync(url, payload));
+ }
+ for (cpr::AsyncResponse& future_response : responses) {
+ cpr::Response response = future_response.get();
+ std::string expected_text{
+ "{\n"
+ " \"x\": 5\n"
+ "}"};
+ EXPECT_EQ(expected_text, response.text);
+ EXPECT_EQ(url, response.url);
+ EXPECT_EQ(std::string{"application/json"}, response.header["content-type"]);
+ EXPECT_EQ(200, response.status_code);
+ EXPECT_EQ(ErrorCode::OK, response.error.code);
+ }
+}
+
+TEST(PatchTests, AsyncMultiplePatchUnallowedTest) {
+ Url url{server->GetBaseUrl() + "/patch_unallowed.html"};
+ Payload payload{{"x", "5"}};
+ std::vector<AsyncResponse> responses;
+ for (size_t i = 0; i < 10; ++i) {
+ responses.emplace_back(cpr::PatchAsync(url, payload));
+ }
+ for (cpr::AsyncResponse& future_response : responses) {
+ cpr::Response response = future_response.get();
+ std::string expected_text{"Method Not Allowed"};
+ EXPECT_EQ(expected_text, response.text);
+ EXPECT_EQ(url, response.url);
+ EXPECT_EQ(std::string{"text/plain"}, response.header["content-type"]);
+ EXPECT_EQ(405, response.status_code);
+ EXPECT_EQ(ErrorCode::OK, response.error.code);
+ }
+}
+
+int main(int argc, char** argv) {
+ ::testing::InitGoogleTest(&argc, argv);
+ ::testing::AddGlobalTestEnvironment(server);
+ return RUN_ALL_TESTS();
+}