blob: 8248e5086c973f00da2a8ab2b6b8e00db46da70e [file] [log] [blame]
// 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 "chrome/browser/content_settings/host_content_settings_map_factory.h"
#include "chrome/browser/ui/browser.h"
#include "chrome/browser/ui/browser_commands.h"
#include "chrome/browser/ui/browser_tabstrip.h"
#include "chrome/browser/ui/browser_window.h"
#include "chrome/browser/ui/exclusive_access/fullscreen_controller.h"
#include "chrome/browser/ui/exclusive_access/fullscreen_controller_test.h"
#include "chrome/browser/ui/tabs/tab_strip_model.h"
#include "chrome/test/base/ui_test_utils.h"
#include "components/content_settings/core/browser/host_content_settings_map.h"
#include "content/public/browser/web_contents.h"
#include "content/public/common/url_constants.h"
#include "net/test/embedded_test_server/embedded_test_server.h"
using content::WebContents;
using ui::PAGE_TRANSITION_TYPED;
IN_PROC_BROWSER_TEST_F(FullscreenControllerTest,
PendingMouseLockExitsOnTabSwitch) {
// This test doesn't make sense in simplified mode, since we never prompt for
// mouse lock.
if (ExclusiveAccessManager::IsSimplifiedFullscreenUIEnabled())
return;
AddTabAtIndex(0, GURL(url::kAboutBlankURL), PAGE_TRANSITION_TYPED);
AddTabAtIndex(0, GURL(url::kAboutBlankURL), PAGE_TRANSITION_TYPED);
WebContents* tab1 = browser()->tab_strip_model()->GetActiveWebContents();
// Request mouse lock. Bubble is displayed.
RequestToLockMouse(true, false);
ASSERT_TRUE(IsFullscreenBubbleDisplayed());
// Activate current tab. Mouse lock bubble remains.
browser()->tab_strip_model()->ActivateTabAt(0, true);
ASSERT_TRUE(IsFullscreenBubbleDisplayed());
// Activate second tab. Mouse lock bubble clears.
{
MouseLockNotificationObserver mouse_lock_observer;
browser()->tab_strip_model()->ActivateTabAt(1, true);
mouse_lock_observer.Wait();
}
ASSERT_FALSE(IsFullscreenBubbleDisplayed());
// Now, test that closing an unrelated tab does not disturb a request.
// Request mouse lock. Bubble is displayed.
RequestToLockMouse(true, false);
ASSERT_TRUE(IsFullscreenBubbleDisplayed());
// Close first tab while second active. Mouse lock bubble remains.
chrome::CloseWebContents(browser(), tab1, false);
ASSERT_TRUE(IsFullscreenBubbleDisplayed());
}
IN_PROC_BROWSER_TEST_F(FullscreenControllerTest,
PendingMouseLockExitsOnTabClose) {
// This test doesn't make sense in simplified mode, since we never prompt for
// mouse lock.
if (ExclusiveAccessManager::IsSimplifiedFullscreenUIEnabled())
return;
// Add more tabs.
AddTabAtIndex(0, GURL(url::kAboutBlankURL), PAGE_TRANSITION_TYPED);
AddTabAtIndex(0, GURL(url::kAboutBlankURL), PAGE_TRANSITION_TYPED);
// Request mouse lock. Bubble is displayed.
RequestToLockMouse(true, false);
ASSERT_TRUE(IsFullscreenBubbleDisplayed());
// Close tab. Bubble is cleared.
{
MouseLockNotificationObserver mouse_lock_observer;
chrome::CloseTab(browser());
mouse_lock_observer.Wait();
}
ASSERT_FALSE(IsFullscreenBubbleDisplayed());
}
IN_PROC_BROWSER_TEST_F(FullscreenControllerTest, MouseLockOnFileURL) {
static const base::FilePath::CharType* kEmptyFile =
FILE_PATH_LITERAL("empty.html");
GURL file_url(ui_test_utils::GetTestUrl(
base::FilePath(base::FilePath::kCurrentDirectory),
base::FilePath(kEmptyFile)));
AddTabAtIndex(0, file_url, PAGE_TRANSITION_TYPED);
RequestToLockMouse(true, false);
ASSERT_TRUE(IsFullscreenBubbleDisplayed());
if (ExclusiveAccessManager::IsSimplifiedFullscreenUIEnabled())
ASSERT_FALSE(IsFullscreenBubbleDisplayingButtons());
else
ASSERT_TRUE(IsFullscreenBubbleDisplayingButtons());
}
IN_PROC_BROWSER_TEST_F(FullscreenControllerTest, FullscreenOnFileURL) {
static const base::FilePath::CharType* kEmptyFile =
FILE_PATH_LITERAL("empty.html");
GURL file_url(ui_test_utils::GetTestUrl(
base::FilePath(base::FilePath::kCurrentDirectory),
base::FilePath(kEmptyFile)));
AddTabAtIndex(0, file_url, PAGE_TRANSITION_TYPED);
GetFullscreenController()->EnterFullscreenModeForTab(
browser()->tab_strip_model()->GetActiveWebContents(),
file_url.GetOrigin());
ASSERT_TRUE(IsFullscreenBubbleDisplayed());
if (ExclusiveAccessManager::IsSimplifiedFullscreenUIEnabled())
ASSERT_FALSE(IsFullscreenBubbleDisplayingButtons());
else
ASSERT_TRUE(IsFullscreenBubbleDisplayingButtons());
}
IN_PROC_BROWSER_TEST_F(FullscreenControllerTest, PermissionContentSettings) {
ASSERT_TRUE(embedded_test_server()->Start());
GURL url = embedded_test_server()->GetURL(kFullscreenMouseLockHTML);
ui_test_utils::NavigateToURL(browser(), url);
EXPECT_FALSE(browser()->window()->IsFullscreen());
// The content's origin is not allowed to go fullscreen.
EXPECT_EQ(
CONTENT_SETTING_ASK,
HostContentSettingsMapFactory::GetForProfile(browser()->profile())
->GetContentSetting(url.GetOrigin(),
url.GetOrigin(),
CONTENT_SETTINGS_TYPE_FULLSCREEN,
std::string()));
GetFullscreenController()->EnterFullscreenModeForTab(
browser()->tab_strip_model()->GetActiveWebContents(), url.GetOrigin());
EXPECT_TRUE(IsFullscreenBubbleDisplayed());
// The content's origin is still not allowed to go fullscreen.
EXPECT_EQ(
CONTENT_SETTING_ASK,
HostContentSettingsMapFactory::GetForProfile(browser()->profile())
->GetContentSetting(url.GetOrigin(),
url.GetOrigin(),
CONTENT_SETTINGS_TYPE_FULLSCREEN,
std::string()));
if (ExclusiveAccessManager::IsSimplifiedFullscreenUIEnabled()) {
ASSERT_FALSE(IsFullscreenBubbleDisplayingButtons());
} else {
ASSERT_TRUE(IsFullscreenBubbleDisplayingButtons());
// It only makes sense to test this on the non-simplified mode. In the
// simplified mode, you cannot accept the request (as it is auto-accepted)
// so you can't set ALLOW.
AcceptCurrentFullscreenOrMouseLockRequest();
// The content's origin is allowed to go fullscreen.
EXPECT_EQ(CONTENT_SETTING_ALLOW,
HostContentSettingsMapFactory::GetForProfile(browser()->profile())
->GetContentSetting(url.GetOrigin(), url.GetOrigin(),
CONTENT_SETTINGS_TYPE_FULLSCREEN,
std::string()));
}
// The primary and secondary patterns have been set when setting the
// permission, thus setting another secondary pattern shouldn't work.
EXPECT_EQ(
CONTENT_SETTING_ASK,
HostContentSettingsMapFactory::GetForProfile(browser()->profile())
->GetContentSetting(url.GetOrigin(),
GURL("https://test.com"),
CONTENT_SETTINGS_TYPE_FULLSCREEN,
std::string()));
HostContentSettingsMapFactory::GetForProfile(browser()->profile())
->ClearSettingsForOneType(CONTENT_SETTINGS_TYPE_FULLSCREEN);
}