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

Unified Diff: chrome/browser/subresource_filter/subresource_filter_browsertest.cc

Issue 2667303003: Disable subresource filtering on page reloads. (Closed)
Patch Set: move ui/base to public_deps Created 3 years, 10 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 | components/subresource_filter/content/browser/BUILD.gn » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/browser/subresource_filter/subresource_filter_browsertest.cc
diff --git a/chrome/browser/subresource_filter/subresource_filter_browsertest.cc b/chrome/browser/subresource_filter/subresource_filter_browsertest.cc
index 5eb1a175658b661ae67370d9589988d7012a6a2d..17e67c902cab8420b54732fe76b65371c99fd2ae 100644
--- a/chrome/browser/subresource_filter/subresource_filter_browsertest.cc
+++ b/chrome/browser/subresource_filter/subresource_filter_browsertest.cc
@@ -20,6 +20,7 @@
#include "chrome/browser/safe_browsing/test_safe_browsing_service.h"
#include "chrome/browser/subresource_filter/test_ruleset_publisher.h"
#include "chrome/browser/ui/browser.h"
+#include "chrome/browser/ui/browser_commands.h"
#include "chrome/browser/ui/tabs/tab_strip_model.h"
#include "chrome/common/chrome_paths.h"
#include "chrome/test/base/in_process_browser_test.h"
@@ -39,6 +40,7 @@
#include "content/public/browser/web_contents.h"
#include "content/public/common/content_switches.h"
#include "content/public/test/browser_test_utils.h"
+#include "content/public/test/test_navigation_observer.h"
#include "content/public/test/test_utils.h"
#include "net/dns/mock_host_resolver.h"
#include "net/test/embedded_test_server/embedded_test_server.h"
@@ -200,8 +202,10 @@ IN_PROC_BROWSER_TEST_F(SubresourceFilterDisabledBrowserTest,
class SubresourceFilterBrowserTestImpl : public InProcessBrowserTest {
public:
- explicit SubresourceFilterBrowserTestImpl(bool measure_performance)
- : measure_performance_(measure_performance) {}
+ explicit SubresourceFilterBrowserTestImpl(bool measure_performance,
+ bool whitelist_site_on_reload)
+ : measure_performance_(measure_performance),
+ whitelist_site_on_reload_(whitelist_site_on_reload) {}
~SubresourceFilterBrowserTestImpl() override {}
@@ -234,7 +238,8 @@ class SubresourceFilterBrowserTestImpl : public InProcessBrowserTest {
scoped_feature_toggle_.reset(new ScopedSubresourceFilterFeatureToggle(
base::FeatureList::OVERRIDE_ENABLE_FEATURE, kActivationLevelEnabled,
kActivationScopeActivationList, kActivationListPhishingInterstitial,
- measure_performance_ ? "1" : "0"));
+ measure_performance_ ? "1" : "0", "" /* suppress_notifications */,
+ whitelist_site_on_reload_ ? "true" : "false"));
base::FilePath test_data_dir;
PathService::Get(chrome::DIR_TEST_DATA, &test_data_dir);
@@ -331,7 +336,8 @@ class SubresourceFilterBrowserTestImpl : public InProcessBrowserTest {
std::unique_ptr<ScopedSubresourceFilterFeatureToggle> scoped_feature_toggle_;
TestRulesetPublisher test_ruleset_publisher_;
- bool measure_performance_;
+ const bool measure_performance_;
+ const bool whitelist_site_on_reload_;
TestRulesetCreator ruleset_creator_;
DISALLOW_COPY_AND_ASSIGN(SubresourceFilterBrowserTestImpl);
@@ -339,7 +345,8 @@ class SubresourceFilterBrowserTestImpl : public InProcessBrowserTest {
class SubresourceFilterBrowserTest : public SubresourceFilterBrowserTestImpl {
public:
- SubresourceFilterBrowserTest() : SubresourceFilterBrowserTestImpl(false) {}
+ SubresourceFilterBrowserTest()
+ : SubresourceFilterBrowserTestImpl(false, false) {}
};
// TODO(pkalinnikov): It should be possible to have only one fixture, i.e.,
@@ -351,7 +358,14 @@ class SubresourceFilterWithPerformanceMeasurementBrowserTest
: public SubresourceFilterBrowserTestImpl {
public:
SubresourceFilterWithPerformanceMeasurementBrowserTest()
- : SubresourceFilterBrowserTestImpl(true) {}
+ : SubresourceFilterBrowserTestImpl(true, false) {}
+};
+
+class SubresourceFilterWhitelistSiteOnReloadBrowserTest
+ : public SubresourceFilterBrowserTestImpl {
+ public:
+ SubresourceFilterWhitelistSiteOnReloadBrowserTest()
+ : SubresourceFilterBrowserTestImpl(false, true) {}
};
// Tests -----------------------------------------------------------------------
@@ -726,4 +740,76 @@ IN_PROC_BROWSER_TEST_F(SubresourceFilterBrowserTest,
static_cast<base::Histogram::Sample>(ActivationLevel::DISABLED), 6);
}
+IN_PROC_BROWSER_TEST_F(SubresourceFilterBrowserTest,
+ ActivationEnabledOnReloadByDefault) {
+ GURL url(GetTestUrl("subresource_filter/frame_with_included_script.html"));
+ ConfigureAsPhishingURL(url);
+ ASSERT_NO_FATAL_FAILURE(
+ SetRulesetToDisallowURLsWithPathSuffix("included_script.js"));
+ ui_test_utils::NavigateToURL(browser(), url);
+ EXPECT_FALSE(WasParsedScriptElementLoaded(web_contents()->GetMainFrame()));
+
+ content::TestNavigationObserver observer(
+ browser()->tab_strip_model()->GetActiveWebContents(),
+ content::MessageLoopRunner::QuitMode::DEFERRED);
+ chrome::Reload(browser(), WindowOpenDisposition::CURRENT_TAB);
+ observer.Wait();
+ EXPECT_FALSE(WasParsedScriptElementLoaded(web_contents()->GetMainFrame()));
+}
+
+IN_PROC_BROWSER_TEST_F(SubresourceFilterWhitelistSiteOnReloadBrowserTest,
+ ActivationDisabledOnReload) {
+ GURL url(GetTestUrl("subresource_filter/frame_with_included_script.html"));
+ ConfigureAsPhishingURL(url);
+ ASSERT_NO_FATAL_FAILURE(
+ SetRulesetToDisallowURLsWithPathSuffix("included_script.js"));
+ ui_test_utils::NavigateToURL(browser(), url);
+ EXPECT_FALSE(WasParsedScriptElementLoaded(web_contents()->GetMainFrame()));
+
+ content::TestNavigationObserver observer(
+ browser()->tab_strip_model()->GetActiveWebContents(),
+ content::MessageLoopRunner::QuitMode::DEFERRED);
+ chrome::Reload(browser(), WindowOpenDisposition::CURRENT_TAB);
+ observer.Wait();
+ EXPECT_TRUE(WasParsedScriptElementLoaded(web_contents()->GetMainFrame()));
+}
+
+IN_PROC_BROWSER_TEST_F(SubresourceFilterWhitelistSiteOnReloadBrowserTest,
+ ActivationDisabledOnReloadFromScript) {
+ GURL url(GetTestUrl("subresource_filter/frame_with_included_script.html"));
+ ConfigureAsPhishingURL(url);
+ ASSERT_NO_FATAL_FAILURE(
+ SetRulesetToDisallowURLsWithPathSuffix("included_script.js"));
+ ui_test_utils::NavigateToURL(browser(), url);
+ EXPECT_FALSE(WasParsedScriptElementLoaded(web_contents()->GetMainFrame()));
+
+ content::TestNavigationObserver observer(
+ browser()->tab_strip_model()->GetActiveWebContents(),
+ content::MessageLoopRunner::QuitMode::DEFERRED);
+ ASSERT_TRUE(content::ExecuteScript(
+ browser()->tab_strip_model()->GetActiveWebContents(),
+ "location.reload();"));
+ observer.Wait();
+ EXPECT_TRUE(WasParsedScriptElementLoaded(web_contents()->GetMainFrame()));
+}
+
+IN_PROC_BROWSER_TEST_F(SubresourceFilterWhitelistSiteOnReloadBrowserTest,
+ ActivationDisabledOnNavigationToSameURL) {
+ GURL url(GetTestUrl("subresource_filter/frame_with_included_script.html"));
+ ConfigureAsPhishingURL(url);
+ ASSERT_NO_FATAL_FAILURE(
+ SetRulesetToDisallowURLsWithPathSuffix("included_script.js"));
+ ui_test_utils::NavigateToURL(browser(), url);
+ EXPECT_FALSE(WasParsedScriptElementLoaded(web_contents()->GetMainFrame()));
+
+ content::TestNavigationObserver observer(
+ browser()->tab_strip_model()->GetActiveWebContents(),
+ content::MessageLoopRunner::QuitMode::DEFERRED);
+ std::string nav_frame_script = "location.href = '" + url.spec() + "';";
+ ASSERT_TRUE(content::ExecuteScript(
+ browser()->tab_strip_model()->GetActiveWebContents(), nav_frame_script));
+ observer.Wait();
+ EXPECT_TRUE(WasParsedScriptElementLoaded(web_contents()->GetMainFrame()));
+}
+
} // namespace subresource_filter
« no previous file with comments | « no previous file | components/subresource_filter/content/browser/BUILD.gn » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698