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

Unified Diff: chrome/browser/ui/ash/system_tray_tray_cast_browsertest_chromeos.cc

Issue 1231593002: Add some browser tests for the cast system tray. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@c0-support-code
Patch Set: Created 5 years, 5 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/ui/ash/system_tray_tray_cast_browsertest_chromeos.cc
diff --git a/chrome/browser/ui/ash/system_tray_tray_cast_browsertest_chromeos.cc b/chrome/browser/ui/ash/system_tray_tray_cast_browsertest_chromeos.cc
new file mode 100644
index 0000000000000000000000000000000000000000..c47db341aee7f2e32ff283ee62cd21becf355375
--- /dev/null
+++ b/chrome/browser/ui/ash/system_tray_tray_cast_browsertest_chromeos.cc
@@ -0,0 +1,227 @@
+// Copyright 2015 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 "ash/shell.h"
+#include "ash/system/cast/tray_cast.h"
+#include "ash/system/tray/system_tray.h"
+#include "ash/system/tray/system_tray_delegate.h"
+#include "ash/system/tray/system_tray_item.h"
+#include "chrome/browser/extensions/extension_browsertest.h"
+#include "chrome/browser/profiles/profile_manager.h"
+#include "chrome/browser/ui/tabs/tab_strip_model.h"
+#include "content/public/browser/render_view_host.h"
+#include "content/public/test/test_utils.h"
+#include "extensions/browser/process_manager.h"
+
+namespace chromeos {
+namespace {
+
+// Execute JavaScript within the context of the extension. Returns the result
+// of the execution.
+scoped_ptr<base::Value> ExecuteJavaScript(
+ const extensions::Extension* extension,
+ const std::string& javascript) {
+ Profile* profile = ProfileManager::GetActiveUserProfile();
+ if (!profile) {
achuithb 2015/07/14 18:22:20 Can this actually happen? If not, drop the check
jdufault 2015/07/15 17:35:27 Done.
+ LOG(ERROR) << "Expected profile";
+ return nullptr;
+ }
+
+ auto pm = extensions::ProcessManager::Get(profile);
+ content::RenderViewHost* host =
+ pm->GetBackgroundHostForExtension(extension->id())->render_view_host();
+ return content::ExecuteScriptAndGetValue(host->GetMainFrame(), javascript);
+}
+
+// Ensures that all pending JavaScript execution callbacks are invoked.
+void ExecutePendingJavaScript(const extensions::Extension* extension) {
+ ExecuteJavaScript(extension, "");
+}
+
+// Invokes tray->StartCastForTest(id) and verifies that launchDesktopMirroring
+// was called with the same id. This automatically creates/destroys the detail
+// view and notifies the tray that Chrome has begun casting.
+void StartCastWithVerification(const extensions::Extension* extension,
+ ash::TrayCast* tray,
+ const std::string& id) {
achuithb 2015/07/14 18:22:19 receiver_id
jdufault 2015/07/15 17:35:28 Done.
+ ash::SystemTrayItem* system_tray_item = tray;
+ ash::TrayCastTestMethods* test_tray = tray;
achuithb 2015/07/14 18:22:20 Is this necessary for compilation?
jdufault 2015/07/15 17:35:28 Yes, since the methods are private w.r.t. ash::Tra
achuithb 2015/07/15 18:59:32 Acknowledged.
+
+ // StartCastForTest will simulate a button click in the detail view to begin
+ // the cast, so we need to make a detail view available.
+ system_tray_item->CreateDetailedView(ash::user::LoginStatus::LOGGED_IN_USER);
+
+ // Clear out any old state and execute any pending JS calls created from the
+ // CreateDetailedView call.
+ ExecuteJavaScript(extension, "launchDesktopMirroringReceiverId = ''");
+
+ test_tray->StartCastForTest(id);
+
+ scoped_ptr<base::Value> getLaunchDesktopMirroringId =
achuithb 2015/07/14 18:22:20 variable name should have underscores, not camel c
jdufault 2015/07/15 17:35:27 Done.
+ ExecuteJavaScript(extension, "getLaunchDesktopMirroringReceiverId()");
+ std::string result;
+ EXPECT_TRUE(getLaunchDesktopMirroringId->GetAsString(&result));
+ EXPECT_EQ(id, result);
+ system_tray_item->DestroyDetailedView();
+
+ // Tell the tray item that Chrome has started casting.
+ test_tray->OnCastingSessionStartedOrStopped(true);
+ ExecutePendingJavaScript(extension);
+}
+
+// Invokes tray->StopCastForTest() and verifies that stopMirroring('user-stop')
+// got called in the extension.
+void StopCastWithVerification(const extensions::Extension* extension,
+ ash::TrayCastTestMethods* tray) {
+ ExecuteJavaScript(extension, "stopMirroringCalled = false");
+ tray->StopCastForTest();
+ scoped_ptr<base::Value> wasStopMirroringCalled =
+ ExecuteJavaScript(extension, "wasStopMirroringCalledWithUserStop()");
+ bool result;
+ EXPECT_TRUE(wasStopMirroringCalled->GetAsBoolean(&result));
+ EXPECT_TRUE(result);
+
+ // Tell the tray item that Chrome has stopped casting.
+ tray->OnCastingSessionStartedOrStopped(false);
+ ExecutePendingJavaScript(extension);
+}
+
+// Returns the cast tray. The tray initializer may have launched some
+// JavaScript callbacks which have not finished executing.
+ash::TrayCast* GetTrayCast(const extensions::Extension* extension) {
+ ash::SystemTray* tray = ash::Shell::GetInstance()->GetPrimarySystemTray();
+ // Make sure we actually popup the tray, otherwise the TrayCast instance will
+ // not be created.
+ tray->ShowDefaultView(ash::BubbleCreationType::BUBBLE_CREATE_NEW);
+
+ // Creating the tray causes some JavaScript to be executed. Let's try to make
+ // sure it is completed.
+ if (extension)
+ ExecutePendingJavaScript(extension);
+
+ return tray->GetTrayCastForTesting();
+}
+
+} // namespace
+
+class SystemTrayTrayCastChromeOSTest : public ExtensionBrowserTest {
achuithb 2015/07/14 18:22:19 This cannot be in the anonymous namespace, is that
jdufault 2015/07/15 17:35:28 Oh, I just was following the pattern of another br
achuithb 2015/07/15 18:59:32 I think you want the IN_PROC_BROWSER_TEST_F to be
jdufault 2015/07/15 19:46:37 I've been testing with --gtest_filter=SystemTrayT
+ protected:
+ SystemTrayTrayCastChromeOSTest() : ExtensionBrowserTest() {}
+ ~SystemTrayTrayCastChromeOSTest() override {}
+
+ const extensions::Extension* LoadCastTestExtension() {
+ return LoadExtension(test_data_dir_.AppendASCII("tray_cast"));
+ }
+
+ private:
+ DISALLOW_COPY_AND_ASSIGN(SystemTrayTrayCastChromeOSTest);
+};
+
+// A simple sanity check to make sure that the cast config delegate actually
+// recognizes the cast extension.
+IN_PROC_BROWSER_TEST_F(SystemTrayTrayCastChromeOSTest,
+ CastTraySanityCheckTestExtensionGetsRecognized) {
+ ash::CastConfigDelegate* cast_config_delegate =
+ ash::Shell::GetInstance()->system_tray_delegate()->GetCastConfigDelegate();
+
+ EXPECT_FALSE(cast_config_delegate->HasCastExtension());
+ LoadCastTestExtension();
+ EXPECT_TRUE(cast_config_delegate->HasCastExtension());
+}
+
+// Verifies that the cast tray is hidden when there is no extension installed.
+IN_PROC_BROWSER_TEST_F(SystemTrayTrayCastChromeOSTest,
+ CastTrayIsHiddenWhenThereIsNoExtension) {
+ ash::TrayCastTestMethods* tray = GetTrayCast(nullptr);
+ EXPECT_TRUE(tray->IsTrayInitializedForTest());
+ EXPECT_FALSE(tray->IsTrayVisibleForTest());
+}
+
+// Verifies that the cast tray is hidden if there are no available receivers,
+// even if there is an extension installed.
+IN_PROC_BROWSER_TEST_F(SystemTrayTrayCastChromeOSTest,
+ CastTrayIsHiddenWhenThereIsAnExtensionButNoReceivers) {
+ const extensions::Extension* extension = LoadCastTestExtension();
+
+ ash::TrayCastTestMethods* tray = GetTrayCast(extension);
+ EXPECT_TRUE(tray->IsTrayInitializedForTest());
+ EXPECT_FALSE(tray->IsTrayVisibleForTest());
+}
+
+// Verifies that the cast tray is displayed when there are receivers available.
+IN_PROC_BROWSER_TEST_F(SystemTrayTrayCastChromeOSTest,
+ CastTrayIsDisplayedWhenThereIsAnExtensionWithReceivers) {
+ const extensions::Extension* extension = LoadCastTestExtension();
+ ExecuteJavaScript(extension, "addReceiver('test_id', 'name')");
+
+ ash::TrayCastTestMethods* tray = GetTrayCast(extension);
+
+ EXPECT_TRUE(tray->IsTrayInitializedForTest());
+ EXPECT_TRUE(tray->IsTrayVisibleForTest());
+}
+
+// Verifies that we can cast to a specific receiver, stop casting, and then cast
+// to another receiver when there is more than one receiver
+IN_PROC_BROWSER_TEST_F(SystemTrayTrayCastChromeOSTest,
+ CastTrayMultipleReceivers) {
+ const extensions::Extension* extension = LoadCastTestExtension();
+ ExecuteJavaScript(extension, "addReceiver('test_id_1', 'name')");
achuithb 2015/07/14 18:22:20 Use different names for variety
jdufault 2015/07/15 17:35:27 I want to verify that the having the same name doe
achuithb 2015/07/15 18:59:32 Acknowledged.
+ ExecuteJavaScript(extension, "addReceiver('not_used_0', 'name')");
+ ExecuteJavaScript(extension, "addReceiver('test_id_0', 'name')");
+ ExecuteJavaScript(extension, "addReceiver('not_used_1', 'name')");
+
+ ash::TrayCast* tray = GetTrayCast(extension);
+ ash::TrayCastTestMethods* test_tray = tray;
+ StartCastWithVerification(extension, tray, "test_id_0");
+
+ EXPECT_TRUE(test_tray->IsTrayCastViewVisibleForTest());
+ StopCastWithVerification(extension, GetTrayCast(extension));
+ EXPECT_TRUE(test_tray->IsTraySelectViewVisibleForTest());
+
+ StartCastWithVerification(extension, GetTrayCast(extension), "test_id_1");
+ EXPECT_TRUE(test_tray->IsTrayCastViewVisibleForTest());
+ StopCastWithVerification(extension, GetTrayCast(extension));
+ EXPECT_TRUE(test_tray->IsTraySelectViewVisibleForTest());
+}
+
+// Verifies the stop cast button invokes the JavaScript function
+// "stopMirroring('user-stop')".
+IN_PROC_BROWSER_TEST_F(SystemTrayTrayCastChromeOSTest,
+ CastTrayStopButtonStopsCast) {
+ // Add a receiver that is casting.
+ const extensions::Extension* extension = LoadCastTestExtension();
+ ExecuteJavaScript(extension, "addReceiver('test_id', 'name', 'title', 1)");
+
+ ash::TrayCastTestMethods* test_tray = GetTrayCast(extension);
+ test_tray->OnCastingSessionStartedOrStopped(true);
+ ExecutePendingJavaScript(extension);
+ EXPECT_TRUE(test_tray->IsTrayCastViewVisibleForTest());
+
+ // Stop the cast using the UI.
+ StopCastWithVerification(extension, test_tray);
+ EXPECT_TRUE(test_tray->IsTraySelectViewVisibleForTest());
+}
+
+// Verifies that the start cast button invokes "launchDesktopMirroring(...)".
+IN_PROC_BROWSER_TEST_F(SystemTrayTrayCastChromeOSTest,
+ CastTrayStartButtonStartsCast) {
+ const extensions::Extension* extension = LoadCastTestExtension();
+ ExecuteJavaScript(extension, "addReceiver('test_id', 'name')");
+ ash::TrayCast* tray = GetTrayCast(extension);
+ StartCastWithVerification(extension, tray, "test_id");
+}
+
+// Verifies that the CastConfigDelegate opens up a tab called "options.html".
+IN_PROC_BROWSER_TEST_F(SystemTrayTrayCastChromeOSTest, CastTrayOpenOptions) {
+ LoadCastTestExtension();
+
+ ash::CastConfigDelegate* cast_config_delegate =
+ ash::Shell::GetInstance()->system_tray_delegate()->GetCastConfigDelegate();
+ cast_config_delegate->LaunchCastOptions();
+
+ GURL url = browser()->tab_strip_model()->GetActiveWebContents()->GetURL();
achuithb 2015/07/14 18:22:20 const
jdufault 2015/07/15 17:35:28 Done.
+ EXPECT_TRUE(base::StringPiece(url.GetContent()).ends_with("options.html"));
+}
+
+} // namespace chromeos
« 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