summaryrefslogtreecommitdiffstats
path: root/chrome/browser/profile.cc
diff options
context:
space:
mode:
authorbrettw@chromium.org <brettw@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-06-29 17:25:27 +0000
committerbrettw@chromium.org <brettw@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-06-29 17:25:27 +0000
commit03c47326b78cb675b084efa829f350e45d5272d9 (patch)
tree7c8d01e37a0b99d45b5186060b2d3b5c12ca8c89 /chrome/browser/profile.cc
parent0afcb5672d2ec6d7c1250c474b7665de713b1b6d (diff)
downloadchromium_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.cc4
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);
}
}