diff options
author | David G. Quintas <dgq@google.com> | 2017-06-29 14:19:58 -0700 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-06-29 14:19:58 -0700 |
commit | b9223347bc297fd7c0684aba97d06b6a2dbab5b8 (patch) | |
tree | 6e42d8624ce38c8b96641f575b7dd399b9086e4a /test | |
parent | e81586bc5cce2dad15405a5afb73cd0f9df7c92f (diff) | |
parent | ab1ff6b0415a3582b7aee26e19e738928c75e0d3 (diff) |
Merge pull request #11539 from dgquintas/alarm_non_copyable
Make grpc::Alarm non-copyable
Diffstat (limited to 'test')
-rw-r--r-- | test/cpp/common/alarm_cpp_test.cc | 31 |
1 files changed, 31 insertions, 0 deletions
diff --git a/test/cpp/common/alarm_cpp_test.cc b/test/cpp/common/alarm_cpp_test.cc index 3e4999994a..ce4168843c 100644 --- a/test/cpp/common/alarm_cpp_test.cc +++ b/test/cpp/common/alarm_cpp_test.cc @@ -40,6 +40,37 @@ TEST(AlarmTest, RegularExpiry) { EXPECT_EQ(junk, output_tag); } +TEST(AlarmTest, MoveConstructor) { + CompletionQueue cq; + void* junk = reinterpret_cast<void*>(1618033); + Alarm first(&cq, grpc_timeout_seconds_to_deadline(1), junk); + Alarm second(std::move(first)); + void* output_tag; + bool ok; + const CompletionQueue::NextStatus status = cq.AsyncNext( + (void**)&output_tag, &ok, grpc_timeout_seconds_to_deadline(2)); + EXPECT_EQ(status, CompletionQueue::GOT_EVENT); + EXPECT_TRUE(ok); + EXPECT_EQ(junk, output_tag); +} + +TEST(AlarmTest, MoveAssignment) { + CompletionQueue cq; + void* junk = reinterpret_cast<void*>(1618033); + Alarm first(&cq, grpc_timeout_seconds_to_deadline(1), junk); + Alarm second(std::move(first)); + first = std::move(second); + + void* output_tag; + bool ok; + const CompletionQueue::NextStatus status = cq.AsyncNext( + (void**)&output_tag, &ok, grpc_timeout_seconds_to_deadline(2)); + + EXPECT_EQ(status, CompletionQueue::GOT_EVENT); + EXPECT_TRUE(ok); + EXPECT_EQ(junk, output_tag); +} + TEST(AlarmTest, RegularExpiryChrono) { CompletionQueue cq; void* junk = reinterpret_cast<void*>(1618033); |