Commit 91cbdf44 authored by Yann Dago's avatar Yann Dago Committed by Commit Bot

Create BrowsingDataRemoverBrowserTestBase to hold shared test code.

Bug: 1026442
Change-Id: I9b4ee82690ea45b85ac3094821b9a9ecc2ccb143
Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/2524504
Commit-Queue: Yann Dago <ydago@chromium.org>
Commit-Queue: Avi Drissman <avi@chromium.org>
Reviewed-by: default avatarChristian Dullweber <dullweber@chromium.org>
Reviewed-by: default avatarAvi Drissman <avi@chromium.org>
Auto-Submit: Yann Dago <ydago@chromium.org>
Cr-Commit-Position: refs/heads/master@{#825475}
parent d292cade
...@@ -23,6 +23,7 @@ ...@@ -23,6 +23,7 @@
#include "build/build_config.h" #include "build/build_config.h"
#include "chrome/browser/browser_process.h" #include "chrome/browser/browser_process.h"
#include "chrome/browser/browsing_data/browsing_data_file_system_util.h" #include "chrome/browser/browsing_data/browsing_data_file_system_util.h"
#include "chrome/browser/browsing_data/browsing_data_remover_browsertest_base.h"
#include "chrome/browser/browsing_data/chrome_browsing_data_remover_delegate.h" #include "chrome/browser/browsing_data/chrome_browsing_data_remover_delegate.h"
#include "chrome/browser/browsing_data/cookies_tree_model.h" #include "chrome/browser/browsing_data/cookies_tree_model.h"
#include "chrome/browser/browsing_data/counters/cache_counter.h" #include "chrome/browser/browsing_data/counters/cache_counter.h"
...@@ -297,7 +298,8 @@ bool SetGaiaCookieForProfile(Profile* profile) { ...@@ -297,7 +298,8 @@ bool SetGaiaCookieForProfile(Profile* profile) {
} // namespace } // namespace
class BrowsingDataRemoverBrowserTest : public InProcessBrowserTest { class BrowsingDataRemoverBrowserTest
: public BrowsingDataRemoverBrowserTestBase {
public: public:
BrowsingDataRemoverBrowserTest() { BrowsingDataRemoverBrowserTest() {
std::vector<base::Feature> enabled_features = { std::vector<base::Feature> enabled_features = {
...@@ -305,70 +307,13 @@ class BrowsingDataRemoverBrowserTest : public InProcessBrowserTest { ...@@ -305,70 +307,13 @@ class BrowsingDataRemoverBrowserTest : public InProcessBrowserTest {
#if BUILDFLAG(ENABLE_LIBRARY_CDMS) #if BUILDFLAG(ENABLE_LIBRARY_CDMS)
enabled_features.push_back(media::kExternalClearKeyForTesting); enabled_features.push_back(media::kExternalClearKeyForTesting);
#endif #endif
feature_list_.InitWithFeatures(enabled_features, {}); InitFeatureList(std::move(enabled_features));
}
// Call to use an Incognito browser rather than the default.
void UseIncognitoBrowser() {
ASSERT_EQ(nullptr, incognito_browser_);
incognito_browser_ = CreateIncognitoBrowser();
}
Browser* GetBrowser() const {
return incognito_browser_ ? incognito_browser_ : browser();
} }
void SetUpOnMainThread() override { void SetUpOnMainThread() override {
base::FilePath path; BrowsingDataRemoverBrowserTestBase::SetUpOnMainThread();
base::PathService::Get(content::DIR_TEST_DATA, &path);
host_resolver()->AddRule(kExampleHost, "127.0.0.1"); host_resolver()->AddRule(kExampleHost, "127.0.0.1");
embedded_test_server()->ServeFilesFromDirectory(path);
ASSERT_TRUE(embedded_test_server()->Start());
}
void RunScriptAndCheckResult(const std::string& script,
const std::string& result) {
std::string data;
ASSERT_TRUE(content::ExecuteScriptAndExtractString(
GetBrowser()->tab_strip_model()->GetActiveWebContents(), script,
&data));
ASSERT_EQ(data, result);
}
bool RunScriptAndGetBool(const std::string& script) {
bool data;
EXPECT_TRUE(content::ExecuteScriptAndExtractBool(
GetBrowser()->tab_strip_model()->GetActiveWebContents(), script,
&data));
return data;
}
void VerifyDownloadCount(size_t expected) {
content::DownloadManager* download_manager =
content::BrowserContext::GetDownloadManager(GetBrowser()->profile());
std::vector<download::DownloadItem*> downloads;
download_manager->GetAllDownloads(&downloads);
EXPECT_EQ(expected, downloads.size());
}
void DownloadAnItem() {
// Start a download.
content::DownloadManager* download_manager =
content::BrowserContext::GetDownloadManager(GetBrowser()->profile());
std::unique_ptr<content::DownloadTestObserver> observer(
new content::DownloadTestObserverTerminal(
download_manager, 1,
content::DownloadTestObserver::ON_DANGEROUS_DOWNLOAD_ACCEPT));
GURL download_url = ui_test_utils::GetTestUrl(
base::FilePath().AppendASCII("downloads"),
base::FilePath().AppendASCII("a_zip_file.zip"));
ui_test_utils::NavigateToURL(GetBrowser(), download_url);
observer->WaitForFinished();
VerifyDownloadCount(1u);
} }
void RemoveAndWait(uint64_t remove_mask) { void RemoveAndWait(uint64_t remove_mask) {
RemoveAndWait(remove_mask, base::Time(), base::Time::Max()); RemoveAndWait(remove_mask, base::Time(), base::Time::Max());
} }
...@@ -449,28 +394,6 @@ class BrowsingDataRemoverBrowserTest : public InProcessBrowserTest { ...@@ -449,28 +394,6 @@ class BrowsingDataRemoverBrowserTest : public InProcessBrowserTest {
ExpectCookieTreeModelCount(0); ExpectCookieTreeModelCount(0);
} }
bool HasDataForType(const std::string& type) {
return RunScriptAndGetBool("has" + type + "()");
}
void SetDataForType(const std::string& type) {
ASSERT_TRUE(RunScriptAndGetBool("set" + type + "()"))
<< "Couldn't create data for: " << type;
}
int GetSiteDataCount() {
base::RunLoop run_loop;
int count = -1;
(new SiteDataCountingHelper(GetBrowser()->profile(), base::Time(),
base::Time::Max(),
base::BindLambdaForTesting([&](int c) {
count = c;
run_loop.Quit();
})))
->CountAndDestroySelfWhenFinished();
run_loop.Run();
return count;
}
#if BUILDFLAG(ENABLE_LIBRARY_CDMS) #if BUILDFLAG(ENABLE_LIBRARY_CDMS)
int GetMediaLicenseCount() { int GetMediaLicenseCount() {
...@@ -579,9 +502,6 @@ class BrowsingDataRemoverBrowserTest : public InProcessBrowserTest { ...@@ -579,9 +502,6 @@ class BrowsingDataRemoverBrowserTest : public InProcessBrowserTest {
RegisterClearKeyCdm(command_line); RegisterClearKeyCdm(command_line);
#endif #endif
} }
base::test::ScopedFeatureList feature_list_;
Browser* incognito_browser_ = nullptr;
}; };
#if BUILDFLAG(ENABLE_DICE_SUPPORT) #if BUILDFLAG(ENABLE_DICE_SUPPORT)
......
// Copyright (c) 2020 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/browsing_data/browsing_data_remover_browsertest_base.h"
#include <memory>
#include <utility>
#include <vector>
#include "base/callback.h"
#include "base/path_service.h"
#include "base/test/bind.h"
#include "chrome/browser/browsing_data/cookies_tree_model.h"
#include "chrome/browser/browsing_data/counters/site_data_counting_helper.h"
#include "chrome/browser/net/system_network_context_manager.h"
#include "chrome/browser/profiles/profile.h"
#include "chrome/browser/ui/browser.h"
#include "chrome/test/base/in_process_browser_test.h"
#include "chrome/test/base/ui_test_utils.h"
#include "content/public/browser/browser_context.h"
#include "content/public/browser/download_manager.h"
#include "content/public/browser/storage_partition.h"
#include "content/public/common/content_paths.h"
#include "content/public/test/browser_test_utils.h"
#include "content/public/test/download_test_observer.h"
#include "net/dns/mock_host_resolver.h"
#include "net/test/embedded_test_server/embedded_test_server.h"
#include "third_party/leveldatabase/leveldb_features.h"
#include "ui/base/models/tree_model.h"
namespace {
// Class for waiting for download manager to be initiailized.
class DownloadManagerWaiter : public content::DownloadManager::Observer {
public:
explicit DownloadManagerWaiter(content::DownloadManager* download_manager)
: initialized_(false), download_manager_(download_manager) {
download_manager_->AddObserver(this);
}
~DownloadManagerWaiter() override { download_manager_->RemoveObserver(this); }
void WaitForInitialized() {
initialized_ = download_manager_->IsManagerInitialized();
if (initialized_)
return;
base::RunLoop run_loop;
quit_closure_ = run_loop.QuitClosure();
run_loop.Run();
}
void OnManagerInitialized() override {
initialized_ = true;
if (quit_closure_)
std::move(quit_closure_).Run();
}
private:
base::OnceClosure quit_closure_;
bool initialized_;
content::DownloadManager* download_manager_;
};
} // namespace
BrowsingDataRemoverBrowserTestBase::BrowsingDataRemoverBrowserTestBase() =
default;
BrowsingDataRemoverBrowserTestBase::~BrowsingDataRemoverBrowserTestBase() =
default;
void BrowsingDataRemoverBrowserTestBase::InitFeatureList(
std::vector<base::Feature> enabled_features) {
feature_list_.InitWithFeatures(enabled_features, {});
}
// Call to use an Incognito browser rather than the default.
void BrowsingDataRemoverBrowserTestBase::UseIncognitoBrowser() {
ASSERT_EQ(nullptr, incognito_browser_);
incognito_browser_ = CreateIncognitoBrowser();
}
Browser* BrowsingDataRemoverBrowserTestBase::GetBrowser() const {
return incognito_browser_ ? incognito_browser_ : browser();
}
void BrowsingDataRemoverBrowserTestBase::SetUpOnMainThread() {
base::FilePath path;
base::PathService::Get(content::DIR_TEST_DATA, &path);
embedded_test_server()->ServeFilesFromDirectory(path);
ASSERT_TRUE(embedded_test_server()->Start());
}
void BrowsingDataRemoverBrowserTestBase::RunScriptAndCheckResult(
const std::string& script,
const std::string& result) {
std::string data;
ASSERT_TRUE(content::ExecuteScriptAndExtractString(
GetBrowser()->tab_strip_model()->GetActiveWebContents(), script, &data));
ASSERT_EQ(data, result);
}
bool BrowsingDataRemoverBrowserTestBase::RunScriptAndGetBool(
const std::string& script) {
bool data;
EXPECT_TRUE(content::ExecuteScriptAndExtractBool(
GetBrowser()->tab_strip_model()->GetActiveWebContents(), script, &data));
return data;
}
void BrowsingDataRemoverBrowserTestBase::VerifyDownloadCount(size_t expected) {
content::DownloadManager* download_manager =
content::BrowserContext::GetDownloadManager(GetBrowser()->profile());
DownloadManagerWaiter download_manager_waiter(download_manager);
download_manager_waiter.WaitForInitialized();
std::vector<download::DownloadItem*> downloads;
download_manager->GetAllDownloads(&downloads);
EXPECT_EQ(expected, downloads.size());
}
void BrowsingDataRemoverBrowserTestBase::DownloadAnItem() {
// Start a download.
content::DownloadManager* download_manager =
content::BrowserContext::GetDownloadManager(GetBrowser()->profile());
std::unique_ptr<content::DownloadTestObserver> observer(
new content::DownloadTestObserverTerminal(
download_manager, 1,
content::DownloadTestObserver::ON_DANGEROUS_DOWNLOAD_ACCEPT));
GURL download_url =
ui_test_utils::GetTestUrl(base::FilePath().AppendASCII("downloads"),
base::FilePath().AppendASCII("a_zip_file.zip"));
ui_test_utils::NavigateToURL(GetBrowser(), download_url);
observer->WaitForFinished();
VerifyDownloadCount(1u);
}
bool BrowsingDataRemoverBrowserTestBase::HasDataForType(
const std::string& type) {
return RunScriptAndGetBool("has" + type + "()");
}
void BrowsingDataRemoverBrowserTestBase::SetDataForType(
const std::string& type) {
ASSERT_TRUE(RunScriptAndGetBool("set" + type + "()"))
<< "Couldn't create data for: " << type;
}
int BrowsingDataRemoverBrowserTestBase::GetSiteDataCount() {
base::RunLoop run_loop;
int count = -1;
(new SiteDataCountingHelper(GetBrowser()->profile(), base::Time(),
base::Time::Max(),
base::BindLambdaForTesting([&](int c) {
count = c;
run_loop.Quit();
})))
->CountAndDestroySelfWhenFinished();
run_loop.Run();
return count;
}
network::mojom::NetworkContext*
BrowsingDataRemoverBrowserTestBase::network_context() const {
return content::BrowserContext::GetDefaultStoragePartition(
GetBrowser()->profile())
->GetNetworkContext();
}
// Copyright (c) 2020 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.
#ifndef CHROME_BROWSER_BROWSING_DATA_BROWSING_DATA_REMOVER_BROWSERTEST_BASE_H_
#define CHROME_BROWSER_BROWSING_DATA_BROWSING_DATA_REMOVER_BROWSERTEST_BASE_H_
#include <string>
#include "base/test/scoped_feature_list.h"
#include "chrome/test/base/in_process_browser_test.h"
class BrowsingDataRemoverBrowserTestBase : public InProcessBrowserTest {
public:
BrowsingDataRemoverBrowserTestBase();
~BrowsingDataRemoverBrowserTestBase() override;
void InitFeatureList(std::vector<base::Feature> enabled_features);
Browser* GetBrowser() const;
void SetUpOnMainThread() override;
void RunScriptAndCheckResult(const std::string& script,
const std::string& result);
bool RunScriptAndGetBool(const std::string& script);
void VerifyDownloadCount(size_t expected);
void DownloadAnItem();
bool HasDataForType(const std::string& type);
void SetDataForType(const std::string& type);
int GetSiteDataCount();
void UseIncognitoBrowser();
bool IsIncognito() { return incognito_browser_ != nullptr; }
network::mojom::NetworkContext* network_context() const;
private:
base::test::ScopedFeatureList feature_list_;
Browser* incognito_browser_ = nullptr;
};
#endif // CHROME_BROWSER_BROWSING_DATA_BROWSING_DATA_REMOVER_BROWSERTEST_BASE_H_
...@@ -18,6 +18,7 @@ ...@@ -18,6 +18,7 @@
#include "base/time/time.h" #include "base/time/time.h"
#include "chrome/browser/autofill/autofill_uitest_util.h" #include "chrome/browser/autofill/autofill_uitest_util.h"
#include "chrome/browser/autofill/personal_data_manager_factory.h" #include "chrome/browser/autofill/personal_data_manager_factory.h"
#include "chrome/browser/browsing_data/browsing_data_remover_browsertest_base.h"
#include "chrome/browser/browsing_data/chrome_browsing_data_lifetime_manager_factory.h" #include "chrome/browser/browsing_data/chrome_browsing_data_lifetime_manager_factory.h"
#include "chrome/browser/browsing_data/chrome_browsing_data_remover_delegate.h" #include "chrome/browser/browsing_data/chrome_browsing_data_remover_delegate.h"
#include "chrome/browser/browsing_data/counters/site_data_counting_helper.h" #include "chrome/browser/browsing_data/counters/site_data_counting_helper.h"
...@@ -50,94 +51,31 @@ ...@@ -50,94 +51,31 @@
#include "storage/browser/quota/special_storage_policy.h" #include "storage/browser/quota/special_storage_policy.h"
#include "testing/gmock/include/gmock/gmock.h" #include "testing/gmock/include/gmock/gmock.h"
#include "testing/gtest/include/gtest/gtest.h" #include "testing/gtest/include/gtest/gtest.h"
#include "url/gurl.h"
namespace { namespace {
static const char* kExampleHost = "example.com";
enum class BrowserType { Default, Incognito }; enum class BrowserType { Default, Incognito };
} // namespace } // namespace
// TODO(ydago) : Extract this into a base class shared with BrowsingDataRemover
// browser tests.
class ChromeBrowsingDataLifetimeManagerTest class ChromeBrowsingDataLifetimeManagerTest
: public InProcessBrowserTest, : public BrowsingDataRemoverBrowserTestBase,
public testing::WithParamInterface<BrowserType> { public testing::WithParamInterface<BrowserType> {
public: public:
ChromeBrowsingDataLifetimeManagerTest() { ChromeBrowsingDataLifetimeManagerTest() {
feature_list_.InitAndEnableFeature( InitFeatureList(
browsing_data::features::kEnableBrowsingDataLifetimeManager); {browsing_data::features::kEnableBrowsingDataLifetimeManager});
} }
~ChromeBrowsingDataLifetimeManagerTest() override = default; ~ChromeBrowsingDataLifetimeManagerTest() override = default;
void SetUpOnMainThread() override { void SetUpOnMainThread() override {
base::FilePath path; BrowsingDataRemoverBrowserTestBase::SetUpOnMainThread();
base::PathService::Get(content::DIR_TEST_DATA, &path);
host_resolver()->AddRule(kExampleHost, "127.0.0.1");
embedded_test_server()->ServeFilesFromDirectory(path);
ASSERT_TRUE(embedded_test_server()->Start());
if (GetParam() == BrowserType::Incognito) if (GetParam() == BrowserType::Incognito)
UseIncognitoBrowser(); UseIncognitoBrowser();
} }
bool RunScriptAndGetBool(const std::string& script) {
bool data;
EXPECT_TRUE(content::ExecuteScriptAndExtractBool(
GetBrowser()->tab_strip_model()->GetActiveWebContents(), script,
&data));
return data;
}
void SetDataForType(const std::string& type) {
ASSERT_TRUE(RunScriptAndGetBool("set" + type + "()"))
<< "Couldn't create data for: " << type;
}
bool HasDataForType(const std::string& type) {
return RunScriptAndGetBool("has" + type + "()");
}
void VerifyDownloadCount(size_t expected) {
content::DownloadManager* download_manager =
content::BrowserContext::GetDownloadManager(GetBrowser()->profile());
std::vector<download::DownloadItem*> downloads;
download_manager->GetAllDownloads(&downloads);
EXPECT_EQ(expected, downloads.size());
}
void DownloadAnItem() {
// Start a download.
content::DownloadManager* download_manager =
content::BrowserContext::GetDownloadManager(GetBrowser()->profile());
std::unique_ptr<content::DownloadTestObserver> observer(
new content::DownloadTestObserverTerminal(
download_manager, 1,
content::DownloadTestObserver::ON_DANGEROUS_DOWNLOAD_ACCEPT));
GURL download_url = ui_test_utils::GetTestUrl(
base::FilePath().AppendASCII("downloads"),
base::FilePath().AppendASCII("a_zip_file.zip"));
ui_test_utils::NavigateToURL(GetBrowser(), download_url);
observer->WaitForFinished();
}
network::mojom::NetworkContext* network_context() const {
return content::BrowserContext::GetDefaultStoragePartition(
GetBrowser()->profile())
->GetNetworkContext();
}
// Call to use an Incognito browser rather than the default.
void UseIncognitoBrowser() {
ASSERT_EQ(nullptr, incognito_browser_);
incognito_browser_ = CreateIncognitoBrowser();
}
bool IsIncognito() { return incognito_browser_ != nullptr; }
Browser* GetBrowser() const {
return incognito_browser_ ? incognito_browser_ : browser();
}
void ApplyBrowsingDataLifetimeDeletion(base::StringPiece pref) { void ApplyBrowsingDataLifetimeDeletion(base::StringPiece pref) {
auto* browsing_data_lifetime_manager = auto* browsing_data_lifetime_manager =
...@@ -156,10 +94,6 @@ class ChromeBrowsingDataLifetimeManagerTest ...@@ -156,10 +94,6 @@ class ChromeBrowsingDataLifetimeManagerTest
completion_observer.BlockUntilCompletion(); completion_observer.BlockUntilCompletion();
} }
private:
Browser* incognito_browser_ = nullptr;
base::test::ScopedFeatureList feature_list_;
}; };
IN_PROC_BROWSER_TEST_P(ChromeBrowsingDataLifetimeManagerTest, IN_PROC_BROWSER_TEST_P(ChromeBrowsingDataLifetimeManagerTest,
......
...@@ -972,6 +972,8 @@ if (!is_android) { ...@@ -972,6 +972,8 @@ if (!is_android) {
"../browser/browser_encoding_browsertest.cc", "../browser/browser_encoding_browsertest.cc",
"../browser/browsing_data/access_context_audit_browsertest.cc", "../browser/browsing_data/access_context_audit_browsertest.cc",
"../browser/browsing_data/browsing_data_remover_browsertest.cc", "../browser/browsing_data/browsing_data_remover_browsertest.cc",
"../browser/browsing_data/browsing_data_remover_browsertest_base.cc",
"../browser/browsing_data/browsing_data_remover_browsertest_base.h",
"../browser/browsing_data/chrome_browsing_data_lifetime_manager_browsertest.cc", "../browser/browsing_data/chrome_browsing_data_lifetime_manager_browsertest.cc",
"../browser/browsing_data/counters/autofill_counter_browsertest.cc", "../browser/browsing_data/counters/autofill_counter_browsertest.cc",
"../browser/browsing_data/counters/browsing_data_counter_utils_browsertest.cc", "../browser/browsing_data/counters/browsing_data_counter_utils_browsertest.cc",
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment