Chromium Code Reviews| 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..e246341369683fd9ba10341b6956c6c3c6afd53b |
| --- /dev/null |
| +++ b/chrome/browser/ui/ash/system_tray_tray_cast_browsertest_chromeos.cc |
| @@ -0,0 +1,178 @@ |
| +// 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 { |
| + |
|
achuithb
2015/07/08 22:04:55
remove newline
jdufault
2015/07/09 23:12:56
Done.
|
| +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) { |
| + LOG(ERROR) << "Expected profile"; |
| + return nullptr; |
| + } |
| + |
| + extensions::ProcessManager* pm = extensions::ProcessManager::Get(profile); |
|
achuithb
2015/07/08 22:04:55
You could use auto here
jdufault
2015/07/09 23:12:57
Done.
|
| + auto host = |
|
achuithb
2015/07/08 22:04:55
Don't think this is appropriate since the type is
jdufault
2015/07/09 23:12:58
Done.
|
| + 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, ""); |
| +} |
| + |
| +// Returns the cast tray. The tray initializer may have launched some |
| +// JavaScript callbacks which have not finished executing. |
| +ash::TrayCast* GetTrayCast() { |
| + ash::Shell::GetInstance()->GetPrimarySystemTray()->ShowDefaultView( |
|
achuithb
2015/07/08 22:04:55
I think it's worthwhile to create a temporary for
jdufault
2015/07/09 23:12:57
Done.
|
| + ash::BubbleCreationType::BUBBLE_CREATE_NEW); |
|
achuithb
2015/07/08 22:04:55
What's going on here?
jdufault
2015/07/09 23:12:57
I've added a comment.
|
| + return ash::Shell::GetInstance() |
| + ->GetPrimarySystemTray() |
| + ->GetTrayCastForTesting(); |
| +} |
| + |
| +} // namespace |
| + |
| +class SystemTrayTrayCastChromeOSTest : public ExtensionBrowserTest { |
| + protected: |
| + SystemTrayTrayCastChromeOSTest() : ExtensionBrowserTest() {} |
| + |
|
achuithb
2015/07/08 22:04:55
remove newline?
jdufault
2015/07/09 23:12:57
Done.
|
| + ~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 |
| +// recongnizes the cast extension. |
|
achuithb
2015/07/08 22:04:55
sp recognizes
jdufault
2015/07/09 23:12:57
Done.
|
| +IN_PROC_BROWSER_TEST_F(SystemTrayTrayCastChromeOSTest, |
| + CastTraySanityCheckTestExtensionGetsRecognized) { |
| + auto cast_config_delegate = ash::Shell::GetInstance() |
|
achuithb
2015/07/08 22:04:55
Type is not clear
jdufault
2015/07/09 23:12:57
Done.
|
| + ->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::TrayCast* tray = GetTrayCast(); |
| + 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) { |
| + auto extension = LoadCastTestExtension(); |
|
achuithb
2015/07/08 22:04:55
Type is not clear
jdufault
2015/07/09 23:12:57
Done.
|
| + |
| + ash::TrayCast* tray = GetTrayCast(); |
| + ExecutePendingJavaScript(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) { |
| + auto extension = LoadCastTestExtension(); |
|
achuithb
2015/07/08 22:04:55
Type is not clear.
jdufault
2015/07/09 23:12:57
Done.
|
| + ExecuteJavaScript(extension, "addReceiver('id', 'name', 'title', 1)"); |
|
achuithb
2015/07/08 22:04:55
test_id?
jdufault
2015/07/09 23:12:57
Done.
|
| + |
| + ash::TrayCast* tray = GetTrayCast(); |
| + ExecutePendingJavaScript(extension); |
|
achuithb
2015/07/08 22:04:55
I don't understand the rationale for this sequence
jdufault
2015/07/09 23:12:57
I've modified GetTrayCast so it takes an extension
achuithb
2015/07/10 21:32:06
Yup, I like that better
|
| + |
| + EXPECT_TRUE(tray->IsTrayInitializedForTest()); |
| + EXPECT_TRUE(tray->IsTrayVisibleForTest()); |
| +} |
| + |
| +// 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. |
| + auto extension = LoadCastTestExtension(); |
|
achuithb
2015/07/08 22:04:55
Type is not clear
jdufault
2015/07/09 23:12:56
Done.
|
| + ExecuteJavaScript(extension, "addReceiver('id', 'name', 'title', 1)"); |
| + |
| + // Stop the cast using the UI. |
| + ash::TrayCast* tray = GetTrayCast(); |
| + tray->StopCastForTest(); |
| + ExecutePendingJavaScript(extension); |
| + |
| + // Verify that stopMirroring was called. |
| + scoped_ptr<base::Value> wasStopMirroringCalled = |
| + ExecuteJavaScript(extension, "wasStopMirroringCalledWithUserStop()"); |
| + bool result; |
| + if (wasStopMirroringCalled->GetAsBoolean(&result) == false) { |
| + FAIL(); // Unknown return type for wasStopMirroringCalled(). |
|
achuithb
2015/07/08 22:04:55
Why not
EXPECT_TRUE(wasStopMirroringCalled->GetAsB
jdufault
2015/07/09 23:12:58
Done.
|
| + } |
| + EXPECT_TRUE(result); |
| +} |
| + |
| +// Verifies that the start cast button invokes "launchDesktopMirroring(...)". |
| +IN_PROC_BROWSER_TEST_F(SystemTrayTrayCastChromeOSTest, |
| + CastTrayStartButtonStartsCast) { |
| + // Add a receiver. |
| + auto extension = LoadCastTestExtension(); |
| + ExecuteJavaScript(extension, "addReceiver('id', 'name', 'title', 1)"); |
| + |
| + // Begin casting something with the id "id" |
| + ash::TrayCast* tray = GetTrayCast(); |
| + |
| + // Upcast because CreateDetailedView is not visible in TrayCast |
| + ((ash::SystemTrayItem*)tray) |
|
achuithb
2015/07/08 22:04:55
Please use static_cast here
jdufault
2015/07/09 23:12:57
Done.
|
| + ->CreateDetailedView(ash::user::LoginStatus::LOGGED_IN_USER); |
| + ExecutePendingJavaScript(extension); |
| + tray->StartCastForTest("id"); |
|
achuithb
2015/07/08 22:04:55
test_id
jdufault
2015/07/09 23:12:57
Done.
|
| + ExecutePendingJavaScript(extension); |
| + |
| + // Verify that launchDesktopMirroring was called with "id" |
| + scoped_ptr<base::Value> launchDesktopMirroringReceiverId = |
| + ExecuteJavaScript(extension, "getLaunchDesktopMirroringReceiverId()"); |
| + std::string result; |
| + if (launchDesktopMirroringReceiverId->GetAsString(&result) == false) { |
|
achuithb
2015/07/08 22:04:55
EXPECT_TRUE
jdufault
2015/07/09 23:12:57
Done.
|
| + FAIL(); // Unknown return type for launchDesktopMirroringReceiverId. |
| + } |
| + EXPECT_EQ("id", result); |
| +} |
| + |
| +IN_PROC_BROWSER_TEST_F(SystemTrayTrayCastChromeOSTest, CastTrayOpenOptions) { |
| + LoadCastTestExtension(); |
| + |
| + auto cast_config_delegate = ash::Shell::GetInstance() |
|
achuithb
2015/07/08 22:04:54
Type is not clear
jdufault
2015/07/09 23:12:57
Done.
|
| + ->system_tray_delegate() |
| + ->GetCastConfigDelegate(); |
| + cast_config_delegate->LaunchCastOptions(); |
| + |
| + auto url = browser()->tab_strip_model()->GetActiveWebContents()->GetURL(); |
|
achuithb
2015/07/08 22:04:55
GURL
jdufault
2015/07/09 23:12:57
Done.
|
| + EXPECT_TRUE(base::StringPiece(url.GetContent()).ends_with("options.html")); |
|
achuithb
2015/07/08 22:04:55
Hmm, this seems a bit fragile since the cast exten
jdufault
2015/07/09 23:12:57
I'm not sure it's even a good test, because the mo
achuithb
2015/07/10 21:32:06
So the mock extension is not launching the real op
jdufault
2015/07/13 21:19:57
It's not the extension which is launching the opti
|
| +} |
| + |
| +} // namespace chromeos |