Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(470)

Side by Side Diff: webrtc/system_wrappers/source/condition_variable_unittest.cc

Issue 1416873002: Testing that waiting for a condition variable waits. (Closed) Base URL: https://chromium.googlesource.com/external/webrtc.git@master
Patch Set: Created 5 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « no previous file | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 /* 1 /*
2 * Copyright (c) 2012 The WebRTC project authors. All Rights Reserved. 2 * Copyright (c) 2012 The WebRTC project authors. All Rights Reserved.
3 * 3 *
4 * Use of this source code is governed by a BSD-style license 4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source 5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found 6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may 7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree. 8 * be found in the AUTHORS file in the root of the source tree.
9 */ 9 */
10 10
11 #include "webrtc/system_wrappers/interface/condition_variable_wrapper.h" 11 #include "webrtc/system_wrappers/interface/condition_variable_wrapper.h"
12 12
13 #include "testing/gtest/include/gtest/gtest.h" 13 #include "testing/gtest/include/gtest/gtest.h"
14 #include "webrtc/base/scoped_ptr.h"
14 #include "webrtc/system_wrappers/interface/critical_section_wrapper.h" 15 #include "webrtc/system_wrappers/interface/critical_section_wrapper.h"
15 #include "webrtc/system_wrappers/interface/thread_wrapper.h" 16 #include "webrtc/system_wrappers/interface/thread_wrapper.h"
17 #include "webrtc/system_wrappers/interface/tick_util.h"
16 #include "webrtc/system_wrappers/interface/trace.h" 18 #include "webrtc/system_wrappers/interface/trace.h"
17 19
18 namespace webrtc { 20 namespace webrtc {
19 21
20 namespace { 22 namespace {
21 23
22 const int kLongWaitMs = 100 * 1000; // A long time in testing terms 24 const int kLongWaitMs = 100 * 1000; // A long time in testing terms
23 const int kShortWaitMs = 2 * 1000; // Long enough for process switches to happen 25 const int kShortWaitMs = 2 * 1000; // Long enough for process switches to happen
26 const int kVeryShortWaitMs = 20; // Used when we want a timeout
24 27
25 // A Baton is one possible control structure one can build using 28 // A Baton is one possible control structure one can build using
26 // conditional variables. 29 // conditional variables.
27 // A Baton is always held by one and only one active thread - unlike 30 // A Baton is always held by one and only one active thread - unlike
28 // a lock, it can never be free. 31 // a lock, it can never be free.
29 // One can pass it or grab it - both calls have timeouts. 32 // One can pass it or grab it - both calls have timeouts.
30 // Note - a production tool would guard against passing it without 33 // Note - a production tool would guard against passing it without
31 // grabbing it first. This one is for testing, so it doesn't. 34 // grabbing it first. This one is for testing, so it doesn't.
32 class Baton { 35 class Baton {
33 public: 36 public:
(...skipping 143 matching lines...) Expand 10 before | Expand all | Expand 10 after
177 // This test verifies that one can use the baton multiple times. 180 // This test verifies that one can use the baton multiple times.
178 TEST_F(CondVarTest, DISABLED_PassBatonMultipleTimes) { 181 TEST_F(CondVarTest, DISABLED_PassBatonMultipleTimes) {
179 const int kNumberOfRounds = 2; 182 const int kNumberOfRounds = 2;
180 for (int i = 0; i < kNumberOfRounds; ++i) { 183 for (int i = 0; i < kNumberOfRounds; ++i) {
181 ASSERT_TRUE(baton_.Pass(kShortWaitMs)); 184 ASSERT_TRUE(baton_.Pass(kShortWaitMs));
182 ASSERT_TRUE(baton_.Grab(kShortWaitMs)); 185 ASSERT_TRUE(baton_.Grab(kShortWaitMs));
183 } 186 }
184 EXPECT_EQ(2 * kNumberOfRounds, baton_.PassCount()); 187 EXPECT_EQ(2 * kNumberOfRounds, baton_.PassCount());
185 } 188 }
186 189
190 TEST(CondVarWaitTest, WaitingWaits) {
191 rtc::scoped_ptr<CriticalSectionWrapper> crit_sect(
192 CriticalSectionWrapper::CreateCriticalSection());
193 rtc::scoped_ptr<ConditionVariableWrapper> cond_var(
194 ConditionVariableWrapper::CreateConditionVariable());
195 CriticalSectionScoped cs(crit_sect.get());
196 int64_t start_ms = TickTime::MillisecondTimestamp();
197 EXPECT_FALSE(cond_var->SleepCS(*(crit_sect), kVeryShortWaitMs));
198 int64_t end_ms = TickTime::MillisecondTimestamp();
199 EXPECT_LE(start_ms + kVeryShortWaitMs, end_ms)
200 << "actual elapsed:" << end_ms - start_ms;
201 }
202
187 } // anonymous namespace 203 } // anonymous namespace
188 204
189 } // namespace webrtc 205 } // namespace webrtc
OLDNEW
« no previous file with comments | « no previous file | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698