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

Unified Diff: chrome/browser/extensions/extension_messages_browsertest.cc

Issue 10024055: Remove unneeded extension_messages_browsertest.cc + cleanup. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: windoooowze Created 8 years, 8 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « no previous file | chrome/chrome_tests.gypi » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/browser/extensions/extension_messages_browsertest.cc
diff --git a/chrome/browser/extensions/extension_messages_browsertest.cc b/chrome/browser/extensions/extension_messages_browsertest.cc
deleted file mode 100644
index 784ffb7eaae72bd0c8affb612da41a66abd87a28..0000000000000000000000000000000000000000
--- a/chrome/browser/extensions/extension_messages_browsertest.cc
+++ /dev/null
@@ -1,145 +0,0 @@
-// Copyright (c) 2012 The Chromium Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style license that can be
-// found in the LICENSE file.
-
-#include "base/utf_string_conversions.h"
-#include "base/values.h"
-#include "chrome/browser/extensions/extension_message_service.h"
-#include "chrome/common/extensions/extension_messages.h"
-#include "chrome/common/render_messages.h"
-#include "chrome/renderer/extensions/chrome_v8_context.h"
-#include "chrome/renderer/extensions/extension_dispatcher.h"
-#include "chrome/renderer/extensions/miscellaneous_bindings.h"
-#include "chrome/test/base/chrome_render_view_test.h"
-#include "testing/gtest/include/gtest/gtest.h"
-
-using extensions::MiscellaneousBindings;
-
-namespace {
-
-static const char kTestingExtensionId[] = "oooooooooooooooooooooooooooooooo";
-
-void DispatchOnConnect(const ChromeV8ContextSet& v8_context_set,
- int source_port_id, const std::string& name,
- const std::string& tab_json) {
- MiscellaneousBindings::DispatchOnConnect(
- v8_context_set.GetAll(),
- source_port_id, name, tab_json,
- kTestingExtensionId, kTestingExtensionId,
- NULL);
-}
-
-void DispatchOnDisconnect(const ChromeV8ContextSet& v8_context_set,
- int source_port_id) {
- MiscellaneousBindings::DispatchOnDisconnect(
- v8_context_set.GetAll(),
- source_port_id, false,
- NULL);
-}
-
-}
-
-// Tests that the bindings for opening a channel to an extension and sending
-// and receiving messages through that channel all works.
-//
-// TODO(aa): Refactor MiscellaneousBindings to have fewer dependencies and
-// make this into a unit test. That will allow us to get rid of cruft like
-// SetTestExtensionId().
-TEST_F(ChromeRenderViewTest, ExtensionMessagesOpenChannel) {
- extension_dispatcher_->SetTestExtensionId(kTestingExtensionId);
- render_thread_->sink().ClearMessages();
- LoadHTML("<body></body>");
- ExecuteJavaScript(
- "var port = chrome.extension.connect({name:'testName'});"
- "port.onMessage.addListener(doOnMessage);"
- "port.postMessage({message: 'content ready'});"
- "function doOnMessage(msg, port) {"
- " alert('content got: ' + msg.val);"
- "}");
-
- // Verify that we opened a channel and sent a message through it.
- const IPC::Message* open_channel_msg =
- render_thread_->sink().GetUniqueMessageMatching(
- ExtensionHostMsg_OpenChannelToExtension::ID);
- ASSERT_TRUE(open_channel_msg);
- PickleIterator iter = IPC::SyncMessage::GetDataIterator(open_channel_msg);
- ExtensionHostMsg_OpenChannelToExtension::SendParam open_params;
- ASSERT_TRUE(IPC::ReadParam(open_channel_msg, &iter, &open_params));
- EXPECT_EQ("testName", open_params.d);
-
- const IPC::Message* post_msg =
- render_thread_->sink().GetUniqueMessageMatching(
- ExtensionHostMsg_PostMessage::ID);
- ASSERT_TRUE(post_msg);
- ExtensionHostMsg_PostMessage::Param post_params;
- ExtensionHostMsg_PostMessage::Read(post_msg, &post_params);
- EXPECT_EQ("{\"message\":\"content ready\"}", post_params.b);
-
- // Now simulate getting a message back from the other side.
- render_thread_->sink().ClearMessages();
- const int kPortId = 0;
- MiscellaneousBindings::DeliverMessage(
- extension_dispatcher_->v8_context_set().GetAll(),
- kPortId, "{\"val\": 42}", NULL);
-
- // Verify that we got it.
- render_thread_->VerifyRunJavaScriptMessageSend(
- ASCIIToUTF16("content got: 42"));
-}
-
-// Tests that the bindings for handling a new channel connection and channel
-// closing all works.
-TEST_F(ChromeRenderViewTest, ExtensionMessagesOnConnect) {
- extension_dispatcher_->SetTestExtensionId(kTestingExtensionId);
- LoadHTML("<body></body>");
- ExecuteJavaScript(
- "chrome.extension.onConnect.addListener(function (port) {"
- " port.test = 24;"
- " port.onMessage.addListener(doOnMessage);"
- " port.onDisconnect.addListener(doOnDisconnect);"
- " port.postMessage({message: 'onconnect from ' + port.tab.url + "
- " ' name ' + port.name});"
- "});"
- "function doOnMessage(msg, port) {"
- " alert('got: ' + msg.val);"
- "}"
- "function doOnDisconnect(port) {"
- " alert('disconnected: ' + port.test);"
- "}");
-
- render_thread_->sink().ClearMessages();
-
- // Simulate a new connection being opened.
- const int kPortId = 0;
- const std::string kPortName = "testName";
- DispatchOnConnect(extension_dispatcher_->v8_context_set(),
- kPortId, kPortName, "{\"url\":\"foo://bar\"}");
-
- // Verify that we handled the new connection by posting a message.
- const IPC::Message* post_msg =
- render_thread_->sink().GetUniqueMessageMatching(
- ExtensionHostMsg_PostMessage::ID);
- ASSERT_TRUE(post_msg);
- ExtensionHostMsg_PostMessage::Param post_params;
- ExtensionHostMsg_PostMessage::Read(post_msg, &post_params);
- std::string expected_msg =
- "{\"message\":\"onconnect from foo://bar name " + kPortName + "\"}";
- EXPECT_EQ(expected_msg, post_params.b);
-
- // Now simulate getting a message back from the channel opener.
- render_thread_->sink().ClearMessages();
- MiscellaneousBindings::DeliverMessage(
- extension_dispatcher_->v8_context_set().GetAll(),
- kPortId, "{\"val\": 42}", NULL);
-
- // Verify that we got it.
- render_thread_->VerifyRunJavaScriptMessageSend(ASCIIToUTF16("got: 42"));
-
- // Now simulate the channel closing.
- render_thread_->sink().ClearMessages();
- DispatchOnDisconnect(extension_dispatcher_->v8_context_set(), kPortId);
-
- // Verify that we got it.
- render_thread_->VerifyRunJavaScriptMessageSend(
- ASCIIToUTF16("disconnected: 24"));
-}
« no previous file with comments | « no previous file | chrome/chrome_tests.gypi » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698