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

Side by Side Diff: mojo/edk/system/channel_test_base.cc

Issue 1473413002: EDK: Add a TestIOThread::IsCurrentAndRunning(). (Closed) Base URL: https://github.com/domokit/mojo.git@master
Patch Set: Created 5 years 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 | mojo/edk/system/data_pipe_impl_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 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2015 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 "mojo/edk/system/channel_test_base.h" 5 #include "mojo/edk/system/channel_test_base.h"
6 6
7 #include <utility> 7 #include <utility>
8 8
9 #include "base/logging.h" 9 #include "base/logging.h"
10 #include "base/message_loop/message_loop.h"
11 #include "mojo/edk/embedder/platform_channel_pair.h" 10 #include "mojo/edk/embedder/platform_channel_pair.h"
12 #include "mojo/edk/system/raw_channel.h" 11 #include "mojo/edk/system/raw_channel.h"
13 12
14 using mojo::util::MakeRefCounted; 13 using mojo::util::MakeRefCounted;
15 14
16 namespace mojo { 15 namespace mojo {
17 namespace system { 16 namespace system {
18 namespace test { 17 namespace test {
19 18
20 ChannelTestBase::ChannelTestBase() 19 ChannelTestBase::ChannelTestBase()
21 : io_thread_(TestIOThread::StartMode::AUTO) {} 20 : io_thread_(TestIOThread::StartMode::AUTO) {}
22 21
23 ChannelTestBase::~ChannelTestBase() { 22 ChannelTestBase::~ChannelTestBase() {
24 } 23 }
25 24
26 void ChannelTestBase::SetUp() { 25 void ChannelTestBase::SetUp() {
27 PostMethodToIOThreadAndWait(&ChannelTestBase::SetUpOnIOThread); 26 PostMethodToIOThreadAndWait(&ChannelTestBase::SetUpOnIOThread);
28 } 27 }
29 28
30 void ChannelTestBase::CreateChannelOnIOThread(unsigned i) { 29 void ChannelTestBase::CreateChannelOnIOThread(unsigned i) {
31 CHECK_EQ(base::MessageLoop::current(), io_thread()->message_loop()); 30 CHECK(io_thread()->IsCurrentAndRunning());
32 31
33 CHECK(!channels_[i]); 32 CHECK(!channels_[i]);
34 channels_[i] = MakeRefCounted<Channel>(&platform_support_); 33 channels_[i] = MakeRefCounted<Channel>(&platform_support_);
35 } 34 }
36 35
37 void ChannelTestBase::InitChannelOnIOThread(unsigned i) { 36 void ChannelTestBase::InitChannelOnIOThread(unsigned i) {
38 CHECK_EQ(base::MessageLoop::current(), io_thread()->message_loop()); 37 CHECK(io_thread()->IsCurrentAndRunning());
39 38
40 CHECK(raw_channels_[i]); 39 CHECK(raw_channels_[i]);
41 CHECK(channels_[i]); 40 CHECK(channels_[i]);
42 channels_[i]->Init(std::move(raw_channels_[i])); 41 channels_[i]->Init(std::move(raw_channels_[i]));
43 } 42 }
44 43
45 void ChannelTestBase::CreateAndInitChannelOnIOThread(unsigned i) { 44 void ChannelTestBase::CreateAndInitChannelOnIOThread(unsigned i) {
46 CreateChannelOnIOThread(i); 45 CreateChannelOnIOThread(i);
47 InitChannelOnIOThread(i); 46 InitChannelOnIOThread(i);
48 } 47 }
49 48
50 void ChannelTestBase::ShutdownChannelOnIOThread(unsigned i) { 49 void ChannelTestBase::ShutdownChannelOnIOThread(unsigned i) {
51 CHECK_EQ(base::MessageLoop::current(), io_thread()->message_loop()); 50 CHECK(io_thread()->IsCurrentAndRunning());
52 51
53 CHECK(channels_[i]); 52 CHECK(channels_[i]);
54 channels_[i]->Shutdown(); 53 channels_[i]->Shutdown();
55 } 54 }
56 55
57 void ChannelTestBase::ShutdownAndReleaseChannelOnIOThread(unsigned i) { 56 void ChannelTestBase::ShutdownAndReleaseChannelOnIOThread(unsigned i) {
58 ShutdownChannelOnIOThread(i); 57 ShutdownChannelOnIOThread(i);
59 channels_[i] = nullptr; 58 channels_[i] = nullptr;
60 } 59 }
61 60
62 void ChannelTestBase::SetUpOnIOThread() { 61 void ChannelTestBase::SetUpOnIOThread() {
63 CHECK_EQ(base::MessageLoop::current(), io_thread()->message_loop()); 62 CHECK(io_thread()->IsCurrentAndRunning());
64 63
65 embedder::PlatformChannelPair channel_pair; 64 embedder::PlatformChannelPair channel_pair;
66 raw_channels_[0] = RawChannel::Create(channel_pair.PassServerHandle()); 65 raw_channels_[0] = RawChannel::Create(channel_pair.PassServerHandle());
67 raw_channels_[1] = RawChannel::Create(channel_pair.PassClientHandle()); 66 raw_channels_[1] = RawChannel::Create(channel_pair.PassClientHandle());
68 } 67 }
69 68
70 } // namespace test 69 } // namespace test
71 } // namespace system 70 } // namespace system
72 } // namespace mojo 71 } // namespace mojo
OLDNEW
« no previous file with comments | « no previous file | mojo/edk/system/data_pipe_impl_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698