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

Side by Side Diff: base/test/thread_test_helper.cc

Issue 2032603002: Migrate WaitableEvent to enum-based constructor in base/ (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@WEvent_enums
Patch Set: undo incorrect template change Created 4 years, 6 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 | « base/test/test_io_thread.cc ('k') | base/test/trace_event_analyzer_unittest.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "base/test/thread_test_helper.h" 5 #include "base/test/thread_test_helper.h"
6 6
7 #include <utility> 7 #include <utility>
8 8
9 #include "base/bind.h" 9 #include "base/bind.h"
10 #include "base/location.h" 10 #include "base/location.h"
11 #include "base/threading/thread_restrictions.h" 11 #include "base/threading/thread_restrictions.h"
12 12
13 namespace base { 13 namespace base {
14 14
15 ThreadTestHelper::ThreadTestHelper( 15 ThreadTestHelper::ThreadTestHelper(
16 scoped_refptr<SingleThreadTaskRunner> target_thread) 16 scoped_refptr<SingleThreadTaskRunner> target_thread)
17 : test_result_(false), 17 : test_result_(false),
18 target_thread_(std::move(target_thread)), 18 target_thread_(std::move(target_thread)),
19 done_event_(false, false) {} 19 done_event_(WaitableEvent::ResetPolicy::AUTOMATIC,
20 WaitableEvent::InitialState::NOT_SIGNALED) {}
20 21
21 bool ThreadTestHelper::Run() { 22 bool ThreadTestHelper::Run() {
22 if (!target_thread_->PostTask( 23 if (!target_thread_->PostTask(
23 FROM_HERE, base::Bind(&ThreadTestHelper::RunInThread, this))) { 24 FROM_HERE, base::Bind(&ThreadTestHelper::RunInThread, this))) {
24 return false; 25 return false;
25 } 26 }
26 base::ThreadRestrictions::ScopedAllowWait allow_wait; 27 base::ThreadRestrictions::ScopedAllowWait allow_wait;
27 done_event_.Wait(); 28 done_event_.Wait();
28 return test_result_; 29 return test_result_;
29 } 30 }
30 31
31 void ThreadTestHelper::RunTest() { set_test_result(true); } 32 void ThreadTestHelper::RunTest() { set_test_result(true); }
32 33
33 ThreadTestHelper::~ThreadTestHelper() {} 34 ThreadTestHelper::~ThreadTestHelper() {}
34 35
35 void ThreadTestHelper::RunInThread() { 36 void ThreadTestHelper::RunInThread() {
36 RunTest(); 37 RunTest();
37 done_event_.Signal(); 38 done_event_.Signal();
38 } 39 }
39 40
40 } // namespace base 41 } // namespace base
OLDNEW
« no previous file with comments | « base/test/test_io_thread.cc ('k') | base/test/trace_event_analyzer_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698