From 9af4aa18c208563e8578fb27b9ce7733c3eb5b2c Mon Sep 17 00:00:00 2001 From: owent Date: Wed, 6 Apr 2022 13:09:57 +0800 Subject: [PATCH] Fix data race which is reported by thread sanitizer Signed-off-by: owent --- .../ext/http/client/curl/http_client_curl.h | 8 ++++++-- ext/src/http/client/curl/http_client_curl.cc | 6 +++--- ext/src/http/client/curl/http_operation_curl.cc | 2 +- ext/test/http/curl_http_test.cc | 12 +++++++++--- 4 files changed, 19 insertions(+), 9 deletions(-) diff --git a/ext/include/opentelemetry/ext/http/client/curl/http_client_curl.h b/ext/include/opentelemetry/ext/http/client/curl/http_client_curl.h index c5883634ff..bfb2671984 100644 --- a/ext/include/opentelemetry/ext/http/client/curl/http_client_curl.h +++ b/ext/include/opentelemetry/ext/http/client/curl/http_client_curl.h @@ -9,6 +9,7 @@ #include "opentelemetry/nostd/shared_ptr.h" #include "opentelemetry/version.h" +#include #include #include #include @@ -171,7 +172,10 @@ class Session : public opentelemetry::ext::http::client::Session virtual bool FinishSession() noexcept override; - virtual bool IsSessionActive() noexcept override { return is_session_active_; } + virtual bool IsSessionActive() noexcept override + { + return is_session_active_.load(std::memory_order_acquire); + } void SetId(uint64_t session_id) { session_id_ = session_id; } @@ -207,7 +211,7 @@ class Session : public opentelemetry::ext::http::client::Session std::unique_ptr curl_operation_; uint64_t session_id_; HttpClient &http_client_; - bool is_session_active_; + std::atomic is_session_active_; }; class HttpClientSync : public opentelemetry::ext::http::client::HttpClientSync diff --git a/ext/src/http/client/curl/http_client_curl.cc b/ext/src/http/client/curl/http_client_curl.cc index 18b9fc2d9c..597ca867af 100644 --- a/ext/src/http/client/curl/http_client_curl.cc +++ b/ext/src/http/client/curl/http_client_curl.cc @@ -35,7 +35,7 @@ nostd::shared_ptr HttpCurlGlobalInitializer::GetInsta void Session::SendRequest( std::shared_ptr callback) noexcept { - is_session_active_ = true; + is_session_active_.store(true, std::memory_order_release); std::string url = host_ + std::string(http_request_->uri_); auto callback_ptr = callback.get(); bool reuse_connection = false; @@ -64,7 +64,7 @@ void Session::SendRequest( response->status_code_ = operation.GetResponseCode(); callback->OnResponse(*response); } - is_session_active_ = false; + is_session_active_.store(false, std::memory_order_release); }); if (success) @@ -74,7 +74,7 @@ void Session::SendRequest( else if (callback) { callback->OnEvent(opentelemetry::ext::http::client::SessionState::CreateFailed, ""); - is_session_active_ = false; + is_session_active_.store(false, std::memory_order_release); } } diff --git a/ext/src/http/client/curl/http_operation_curl.cc b/ext/src/http/client/curl/http_operation_curl.cc index c2eaec7355..d7fc6bb0fe 100644 --- a/ext/src/http/client/curl/http_operation_curl.cc +++ b/ext/src/http/client/curl/http_operation_curl.cc @@ -572,7 +572,7 @@ CURLcode HttpOperation::SendAsync(Session *session, std::functioncallback = std::move(callback); session->GetHttpClient().ScheduleAddSession(session->GetSessionId()); - return last_curl_result_; + return code; } Headers HttpOperation::GetResponseHeaders() diff --git a/ext/test/http/curl_http_test.cc b/ext/test/http/curl_http_test.cc index 73c5b30adc..b4e6effbe4 100644 --- a/ext/test/http/curl_http_test.cc +++ b/ext/test/http/curl_http_test.cc @@ -358,8 +358,10 @@ TEST_F(BasicCurlHttpTests, SendGetRequestAsync) request->SetUri("get/"); handlers[i] = std::make_shared(); - sessions[i]->SendRequest(handlers[i]); + // Lock mtx_requests to prevent response, we will check IsSessionActive() in the end + std::unique_lock lock_requests(mtx_requests); + sessions[i]->SendRequest(handlers[i]); ASSERT_TRUE(sessions[i]->IsSessionActive()); } @@ -395,8 +397,10 @@ TEST_F(BasicCurlHttpTests, SendGetRequestAsyncTimeout) request->SetTimeoutMs(std::chrono::milliseconds(256)); handlers[i] = std::make_shared(); - sessions[i]->SendRequest(handlers[i]); + // Lock mtx_requests to prevent response, we will check IsSessionActive() in the end + std::unique_lock lock_requests(mtx_requests); + sessions[i]->SendRequest(handlers[i]); ASSERT_TRUE(sessions[i]->IsSessionActive()); } @@ -427,8 +431,10 @@ TEST_F(BasicCurlHttpTests, SendPostRequestAsync) auto request = session->CreateRequest(); request->SetMethod(http_client::Method::Post); request->SetUri("post/"); - session->SendRequest(handler); + // Lock mtx_requests to prevent response, we will check IsSessionActive() in the end + std::unique_lock lock_requests(mtx_requests); + session->SendRequest(handler); ASSERT_TRUE(session->IsSessionActive()); }