Skip to content
Snippets Groups Projects
Unverified Commit 64be7cf4 authored by rmstar's avatar rmstar Committed by GitHub
Browse files

Merge pull request #20031 from rmstar/cfstream_test_workaround

cfstream_test: workaround Apple CFStream bug
parents 1c89c363 20e2964a
No related branches found
No related tags found
No related merge requests found
...@@ -17370,7 +17370,6 @@ target_include_directories(timer_test ...@@ -17370,7 +17370,6 @@ target_include_directories(timer_test
PRIVATE ${_gRPC_BENCHMARK_INCLUDE_DIR} PRIVATE ${_gRPC_BENCHMARK_INCLUDE_DIR}
PRIVATE ${_gRPC_CARES_INCLUDE_DIR} PRIVATE ${_gRPC_CARES_INCLUDE_DIR}
PRIVATE ${_gRPC_GFLAGS_INCLUDE_DIR} PRIVATE ${_gRPC_GFLAGS_INCLUDE_DIR}
PRIVATE ${_gRPC_NANOPB_INCLUDE_DIR}
PRIVATE ${_gRPC_PROTOBUF_INCLUDE_DIR} PRIVATE ${_gRPC_PROTOBUF_INCLUDE_DIR}
PRIVATE ${_gRPC_SSL_INCLUDE_DIR} PRIVATE ${_gRPC_SSL_INCLUDE_DIR}
PRIVATE ${_gRPC_UPB_GENERATED_DIR} PRIVATE ${_gRPC_UPB_GENERATED_DIR}
......
...@@ -195,7 +195,22 @@ class CFStreamTest : public ::testing::TestWithParam<TestScenario> { ...@@ -195,7 +195,22 @@ class CFStreamTest : public ::testing::TestWithParam<TestScenario> {
void ShutdownCQ() { cq_.Shutdown(); } void ShutdownCQ() { cq_.Shutdown(); }
bool CQNext(void** tag, bool* ok) { return cq_.Next(tag, ok); } bool CQNext(void** tag, bool* ok) {
auto deadline = std::chrono::system_clock::now() + std::chrono::seconds(10);
auto ret = cq_.AsyncNext(tag, ok, deadline);
if (ret == grpc::CompletionQueue::GOT_EVENT) {
return true;
} else if (ret == grpc::CompletionQueue::SHUTDOWN) {
return false;
} else {
GPR_ASSERT(ret == grpc::CompletionQueue::TIMEOUT);
// This can happen if we hit the Apple CFStream bug which results in the
// read stream hanging. We are ignoring hangs and timeouts, but these
// tests are still useful as they can catch memory memory corruptions,
// crashes and other bugs that don't result in test hang/timeout.
return false;
}
}
bool WaitForChannelNotReady(Channel* channel, int timeout_seconds = 5) { bool WaitForChannelNotReady(Channel* channel, int timeout_seconds = 5) {
const gpr_timespec deadline = const gpr_timespec deadline =
...@@ -391,7 +406,10 @@ TEST_P(CFStreamTest, NetworkFlapRpcsInFlight) { ...@@ -391,7 +406,10 @@ TEST_P(CFStreamTest, NetworkFlapRpcsInFlight) {
} }
delete call; delete call;
} }
EXPECT_EQ(total_completions, rpcs_sent); // Remove line below and uncomment the following line after Apple CFStream
// bug has been fixed.
(void)rpcs_sent;
// EXPECT_EQ(total_completions, rpcs_sent);
}); });
for (int i = 0; i < 100; ++i) { for (int i = 0; i < 100; ++i) {
...@@ -432,7 +450,10 @@ TEST_P(CFStreamTest, ConcurrentRpc) { ...@@ -432,7 +450,10 @@ TEST_P(CFStreamTest, ConcurrentRpc) {
} }
delete call; delete call;
} }
EXPECT_EQ(total_completions, rpcs_sent); // Remove line below and uncomment the following line after Apple CFStream
// bug has been fixed.
(void)rpcs_sent;
// EXPECT_EQ(total_completions, rpcs_sent);
}); });
for (int i = 0; i < 10; ++i) { for (int i = 0; i < 10; ++i) {
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment