Skip to content

Commit

Permalink
Add browsertest for Flash
Browse files Browse the repository at this point in the history
  • Loading branch information
bbondy committed May 31, 2018
1 parent b5264cb commit b4f24df
Show file tree
Hide file tree
Showing 4 changed files with 227 additions and 1 deletion.
1 change: 0 additions & 1 deletion components/brave_shields/common/brave_shield_constants.h
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,6 @@ const char kFingerprinting[] = "fingerprinting";
const char kBraveShields[] = "braveShields";
const char kReferrers[] = "referrers";
const char kCookies[] = "cookies";
const char kFlash[] = "adobe-flash-player";

} // brave_shields

Expand Down
199 changes: 199 additions & 0 deletions renderer/brave_content_settings_observer_flash_browsertest.cc
Original file line number Diff line number Diff line change
@@ -0,0 +1,199 @@
/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this file,
* You can obtain one at http://mozilla.org/MPL/2.0/. */

#include "base/path_service.h"
#include "brave/browser/brave_content_browser_client.h"
#include "brave/common/brave_paths.h"
#include "brave/components/brave_shields/common/brave_shield_constants.h"
#include "chrome/browser/content_settings/host_content_settings_map_factory.h"
#include "chrome/browser/ui/browser.h"
#include "chrome/browser/ui/permission_bubble/mock_permission_prompt_factory.h"
#include "chrome/common/chrome_content_client.h"
#include "chrome/test/base/in_process_browser_test.h"
#include "chrome/test/base/ui_test_utils.h"
#include "content/public/browser/render_frame_host.h"
#include "content/public/common/content_switches.h"
#include "content/public/test/browser_test_utils.h"
#include "content/public/test/ppapi_test_utils.h"
#include "components/content_settings/core/browser/host_content_settings_map.h"
#include "components/content_settings/core/common/content_settings.h"
#include "components/content_settings/core/common/content_settings_types.h"
#include "net/dns/mock_host_resolver.h"

const char kFlashPluginExists[] =
"domAutomationController.send(Array.from(navigator.plugins).filter("
" x => Array.from(x).some("
" y => y.type === 'application/x-shockwave-flash')).length)";

namespace {

class PageReloadWaiter {
public:
explicit PageReloadWaiter(content::WebContents* web_contents)
: web_contents_(web_contents),
navigation_observer_(web_contents,
web_contents->GetLastCommittedURL()) {}

bool Wait() {
navigation_observer_.WaitForNavigationFinished();
return content::WaitForLoadStop(web_contents_);
}

private:
content::WebContents* web_contents_;
content::TestNavigationManager navigation_observer_;
};

} // namespace

class BraveContentSettingsObserverFlashBrowserTest : public InProcessBrowserTest {
public:
void SetUpOnMainThread() override {
InProcessBrowserTest::SetUpOnMainThread();

content_client_.reset(new ChromeContentClient);
content::SetContentClient(content_client_.get());
browser_content_client_.reset(new BraveContentBrowserClient());
content::SetBrowserClientForTesting(browser_content_client_.get());

host_resolver()->AddRule("*", "127.0.0.1");
content::SetupCrossSiteRedirector(embedded_test_server());

brave::RegisterPathProvider();
base::FilePath test_data_dir;
PathService::Get(brave::DIR_TEST_DATA, &test_data_dir);
embedded_test_server()->ServeFilesFromDirectory(test_data_dir);

ASSERT_TRUE(embedded_test_server()->Start());

url_ = embedded_test_server()->GetURL("a.com", "/flash.html");
top_level_page_pattern_ =
ContentSettingsPattern::FromString("http://a.com/*");
}

void SetUpCommandLine(base::CommandLine* command_line) override {
InProcessBrowserTest::SetUpCommandLine(command_line);
ASSERT_TRUE(ppapi::RegisterFlashTestPlugin(command_line));
// These tests are for the permission prompt to add and remove Flash from
// navigator.plugins. We disable Plugin Power Saver, because its plugin
// throttling make it harder to test if Flash was succcessfully enabled.
command_line->AppendSwitchASCII(
switches::kOverridePluginPowerSaverForTesting, "never");
}

void TearDown() override {
browser_content_client_.reset();
content_client_.reset();
}

const GURL& url() { return url_; }

const ContentSettingsPattern& top_level_page_pattern() {
return top_level_page_pattern_;
}

const ContentSettingsPattern& empty_pattern() {
return empty_pattern_;
}

HostContentSettingsMap * content_settings() {
return HostContentSettingsMapFactory::GetForProfile(browser()->profile());
}

void UnblockFlash() {
content_settings()->SetContentSettingCustomScope(
top_level_page_pattern_,
ContentSettingsPattern::Wildcard(),
CONTENT_SETTINGS_TYPE_PLUGINS,
std::string(),
CONTENT_SETTING_DETECT_IMPORTANT_CONTENT);
}

void AllowFlash() {
content_settings()->SetContentSettingCustomScope(
top_level_page_pattern_,
ContentSettingsPattern::Wildcard(),
CONTENT_SETTINGS_TYPE_PLUGINS,
std::string(),
CONTENT_SETTING_ALLOW);
}

content::WebContents* contents() {
return browser()->tab_strip_model()->GetActiveWebContents();
}

bool NavigateToURLUntilLoadStop(const GURL& url) {
ui_test_utils::NavigateToURL(browser(), url);
return WaitForLoadStop(contents());
}

private:
GURL url_;
ContentSettingsPattern top_level_page_pattern_;
ContentSettingsPattern empty_pattern_;
std::unique_ptr<ChromeContentClient> content_client_;
std::unique_ptr<BraveContentBrowserClient> browser_content_client_;

base::ScopedTempDir temp_user_data_dir_;
};

// Flash is blocked by default
IN_PROC_BROWSER_TEST_F(BraveContentSettingsObserverFlashBrowserTest,
BlockFlashByDefault) {
NavigateToURLUntilLoadStop(url());
int len;
ASSERT_TRUE(ExecuteScriptAndExtractInt(contents(),
kFlashPluginExists, &len));
ASSERT_EQ(len, 0);
}

// Flash is unblocked and click to play eventually allows
IN_PROC_BROWSER_TEST_F(BraveContentSettingsObserverFlashBrowserTest,
UnblockFlash) {
UnblockFlash();
NavigateToURLUntilLoadStop(url());
int len;
ASSERT_TRUE(ExecuteScriptAndExtractInt(contents(),
kFlashPluginExists, &len));
ASSERT_EQ(len, 0);

PermissionRequestManager* manager = PermissionRequestManager::FromWebContents(
contents());

auto popup_prompt_factory =
std::make_unique<MockPermissionPromptFactory>(manager);

EXPECT_EQ(0, popup_prompt_factory->TotalRequestCount());
popup_prompt_factory->set_response_type(PermissionRequestManager::ACCEPT_ALL);

PageReloadWaiter reload_waiter(contents());

bool value;
EXPECT_TRUE(ExecuteScriptAndExtractBool(contents(), "triggerPrompt();",
&value));
EXPECT_TRUE(value);
EXPECT_TRUE(reload_waiter.Wait());

EXPECT_EQ(1, popup_prompt_factory->TotalRequestCount());

// Shut down the popup window tab, as the normal test teardown assumes there
// is only one test tab.
popup_prompt_factory.reset();

ASSERT_TRUE(ExecuteScriptAndExtractInt(contents(),
kFlashPluginExists, &len));
ASSERT_GT(len, 0);
}

// Flash is explicitly allowed
IN_PROC_BROWSER_TEST_F(BraveContentSettingsObserverFlashBrowserTest,
AllowFlashExplicitAllows) {
AllowFlash();
NavigateToURLUntilLoadStop(url());
int len;
ASSERT_TRUE(ExecuteScriptAndExtractInt(contents(),
kFlashPluginExists, &len));
ASSERT_GT(len, 0);
}

6 changes: 6 additions & 0 deletions test/BUILD.gn
Original file line number Diff line number Diff line change
Expand Up @@ -77,6 +77,7 @@ test("brave_browser_tests") {
"//brave/components/brave_shields/browser/tracking_protection_service_browsertest.cc",
"//brave/extensions/browser/brave_extension_provider_browsertest.cc",
"//brave/renderer/brave_content_settings_observer_browsertest.cc",
"//brave/renderer/brave_content_settings_observer_flash_browsertest.cc",
"//chrome/browser/extensions/browsertest_util.cc",
"//chrome/browser/extensions/browsertest_util.h",
"//chrome/browser/extensions/extension_browsertest.cc",
Expand All @@ -90,6 +91,11 @@ test("brave_browser_tests") {
deps = [
"//chrome/browser/ui",
"//chrome/test:browser_tests_runner",
"//ppapi/features",
":brave_browser_tests_deps",
]
data_deps = [
"//ppapi:ppapi_tests",
"//ppapi:power_saver_test_plugin",
]
}
22 changes: 22 additions & 0 deletions test/data/flash.html
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
<!DOCTYPE html>
<html>
<head>
<script>
function triggerPrompt() {
document.getElementById('flash-link').click();
window.domAutomationController.send(true);
}
</script>
</head>
<body>
<object id="flash-object" data="test.swf"
type="application/x-shockwave-flash" width="400" height="100">
Flash not supported.
<br>
<a href="https://get.adobe.com/flashplayer/" id="flash-link">
Download Flash.
</a>
</object>
</body>
</html>

0 comments on commit b4f24df

Please sign in to comment.