Skip to content

Commit

Permalink
Fixed multiperform session remove error handling
Browse files Browse the repository at this point in the history
  • Loading branch information
COM8 committed Sep 20, 2024
1 parent 3febe37 commit 0d1cae8
Show file tree
Hide file tree
Showing 3 changed files with 25 additions and 4 deletions.
11 changes: 8 additions & 3 deletions cpr/multiperform.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -9,8 +9,8 @@
#include <cassert>
#include <cstddef>
#include <curl/curl.h>
#include <curl/multi.h>
#include <curl/curlver.h>
#include <curl/multi.h>
#include <functional>
#include <iosfwd>
#include <iostream>
Expand Down Expand Up @@ -68,14 +68,19 @@ void MultiPerform::AddSession(std::shared_ptr<Session>& session, HttpMethod meth
}

void MultiPerform::RemoveSession(const std::shared_ptr<Session>& session) {
// Has to be handled before calling curl_multi_remove_handle to avoid it returning something != CURLM_OK.
if (sessions_.empty()) {
throw std::invalid_argument("Failed to find session!");
}

// Remove easy handle from multihandle
const CURLMcode error_code = curl_multi_remove_handle(multicurl_->handle, session->curl_->handle);
if (error_code) {
if (error_code != CURLM_OK) {
std::cerr << "curl_multi_remove_handle() failed, code " << static_cast<int>(error_code) << '\n';
return;
}

// Unock session
// Unlock session
session->isUsedInMultiPerform = false;

// Remove session from sessions_
Expand Down
7 changes: 7 additions & 0 deletions test/get_tests.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,13 @@ using namespace cpr;

static HttpServer* server = new HttpServer();

TEST(BasicTests, XXXTest) {
Url url{"https://getsolara.dev/api/endpoint.json"};
Response response = cpr::Get(url);
EXPECT_EQ(200, response.status_code);
EXPECT_EQ(ErrorCode::OK, response.error.code);
}

TEST(BasicTests, HelloWorldTest) {
Url url{server->GetBaseUrl() + "/hello.html"};
Response response = cpr::Get(url);
Expand Down
11 changes: 10 additions & 1 deletion test/multiperform_tests.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -92,12 +92,21 @@ TEST(MultiperformRemoveSessionTests, MultiperformRemoveMultipleSessionsTest) {
}
}

TEST(MultiperformRemoveSessionTests, MultiperformRemoveNonExistingSessionTest) {
TEST(MultiperformRemoveSessionTests, MultiperformRemoveNonExistingSessionEmptyTest) {
std::shared_ptr<Session> session = std::make_shared<Session>();
MultiPerform multiperform;
EXPECT_THROW(multiperform.RemoveSession(session), std::invalid_argument);
}

TEST(MultiperformRemoveSessionTests, MultiperformRemoveNonExistingSessionTest) {
MultiPerform multiperform;
std::shared_ptr<Session> session = std::make_shared<Session>();
multiperform.AddSession(session);

std::shared_ptr<Session> session2 = std::make_shared<Session>();
EXPECT_THROW(multiperform.RemoveSession(session2), std::invalid_argument);
}

TEST(MultiperformGetTests, MultiperformSingleSessionGetTest) {
Url url{server->GetBaseUrl() + "/hello.html"};
std::shared_ptr<Session> session = std::make_shared<Session>();
Expand Down

0 comments on commit 0d1cae8

Please sign in to comment.