diff options
author | brettw@chromium.org <brettw@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-06-29 17:25:27 +0000 |
---|---|---|
committer | brettw@chromium.org <brettw@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-06-29 17:25:27 +0000 |
commit | 03c47326b78cb675b084efa829f350e45d5272d9 (patch) | |
tree | 7c8d01e37a0b99d45b5186060b2d3b5c12ca8c89 /chrome/browser/profile.cc | |
parent | 0afcb5672d2ec6d7c1250c474b7665de713b1b6d (diff) | |
download | chromium_src-03c47326b78cb675b084efa829f350e45d5272d9.zip chromium_src-03c47326b78cb675b084efa829f350e45d5272d9.tar.gz chromium_src-03c47326b78cb675b084efa829f350e45d5272d9.tar.bz2 |
Let RenderProcessHost provide a method HasConnection() instead of exposing
channel().
Motivation:
Currently, components that are using RenderProcessHost are checking its
liveness by null testing on channel(). I'd like to write unittests for those
components, but to mock out RenderProcessHost instances, I have to also
mock out the instance returned by RenderProcessHost::channel(), but there's
no interface class prepared. SyncChannel is directly used in RenderProcessHost.
Instead of dependency injection, I can let mock objects return invalid pointer
such as 0x1, but its bad test design. Rather than that, I'd like to introduce
HasConnection() method and override it to return true.
In fact, most of those components are not accessing channel()'s methods
directry. They're just checking channel() is null or not, and to issue IPCs,
they are calling Send method. So, it's OK to hide channel pointer from users, I
think.
Original review: http://codereview.chromium.org/147077
Patch by tyoshino@google.com
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@19493 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/browser/profile.cc')
-rw-r--r-- | chrome/browser/profile.cc | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/chrome/browser/profile.cc b/chrome/browser/profile.cc index 54ecdf2..f5182c0 100644 --- a/chrome/browser/profile.cc +++ b/chrome/browser/profile.cc @@ -667,7 +667,7 @@ static void BroadcastNewHistoryTable(base::SharedMemory* table_memory) { // send to all RenderProcessHosts for (RenderProcessHost::iterator i = RenderProcessHost::begin(); i != RenderProcessHost::end(); i++) { - if (!i->second->channel()) + if (!i->second->HasConnection()) continue; base::SharedMemoryHandle new_table; @@ -679,7 +679,7 @@ static void BroadcastNewHistoryTable(base::SharedMemory* table_memory) { table_memory->ShareToProcess(process, &new_table); IPC::Message* msg = new ViewMsg_VisitedLink_NewTable(new_table); - i->second->channel()->Send(msg); + i->second->Send(msg); } } |