diff options
author | brettw@chromium.org <brettw@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-01-17 05:41:48 +0000 |
---|---|---|
committer | brettw@chromium.org <brettw@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-01-17 05:41:48 +0000 |
commit | cde96e19f7142ab29d80d96ebf6719bbcd8f06fe (patch) | |
tree | 5ac81cc7a3a968f291338b5b46d6471665455ae2 /chrome/renderer/mock_render_thread.cc | |
parent | e900bb3e43ce97892cdeb0c79ce503befbdaf4c8 (diff) | |
download | chromium_src-cde96e19f7142ab29d80d96ebf6719bbcd8f06fe.zip chromium_src-cde96e19f7142ab29d80d96ebf6719bbcd8f06fe.tar.gz chromium_src-cde96e19f7142ab29d80d96ebf6719bbcd8f06fe.tar.bz2 |
Factor out the message sink from MockRenderThread to a separate class. I will be
using this in a RenderView test in the future.
Review URL: http://codereview.chromium.org/18326
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@8255 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/renderer/mock_render_thread.cc')
-rw-r--r-- | chrome/renderer/mock_render_thread.cc | 55 |
1 files changed, 2 insertions, 53 deletions
diff --git a/chrome/renderer/mock_render_thread.cc b/chrome/renderer/mock_render_thread.cc index a100a01..8bf07aa 100644 --- a/chrome/renderer/mock_render_thread.cc +++ b/chrome/renderer/mock_render_thread.cc @@ -17,8 +17,6 @@ MockRenderThread::MockRenderThread() } MockRenderThread::~MockRenderThread() { - // Don't leak the allocated message bodies. - ClearMessages(); } // Called by the Widget. The routing_id must match the routing id assigned @@ -60,62 +58,14 @@ bool MockRenderThread::Send(IPC::Message* msg) { return true; } -void MockRenderThread::ClearMessages() { - for (size_t i = 0; i < messages_.size(); i++) - delete[] messages_[i].second; - messages_.clear(); -} - -const IPC::Message* MockRenderThread::GetMessageAt(size_t index) const { - if (index >= messages_.size()) - return NULL; - return &messages_[index].first; -} - -const IPC::Message* MockRenderThread::GetFirstMessageMatching(uint16 id) const { - for (size_t i = 0; i < messages_.size(); i++) { - if (messages_[i].first.type() == id) - return &messages_[i].first; - } - return NULL; -} - -const IPC::Message* MockRenderThread::GetUniqueMessageMatching( - uint16 id) const { - size_t found_index = 0; - size_t found_count = 0; - for (size_t i = 0; i < messages_.size(); i++) { - if (messages_[i].first.type() == id) { - found_count++; - found_index = i; - } - } - if (found_count != 1) - return NULL; // Didn't find a unique one. - return &messages_[found_index].first; -} - void MockRenderThread::SendCloseMessage() { ViewMsg_Close msg(routing_id_); widget_->OnMessageReceived(msg); } void MockRenderThread::OnMessageReceived(const IPC::Message& msg) { - // Copy the message into a pair. This is tricky since the message doesn't - // manage its data itself. - char* data_copy; - if (msg.size()) { - data_copy = new char[msg.size()]; - memcpy(data_copy, msg.data(), msg.size()); - } else { - // Dummy data so we can treat everything the same. - data_copy = new char[1]; - data_copy[0] = 0; - } - - // Save the message. - messages_.push_back( - std::make_pair(IPC::Message(data_copy, msg.size()), data_copy)); + // Save the message in the sink. + sink_.OnMessageReceived(msg); // Some messages we do special handling. bool handled = true; @@ -133,4 +83,3 @@ void MockRenderThread::OnMsgCreateWidget(int opener_id, opener_id_ = opener_id; *route_id = routing_id_; } - |