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

Unified Diff: chrome/browser/safe_browsing/v4_test_utils.cc

Issue 2690413002: Refactor safe browsing service tests. (Closed)
Patch Set: addressed comments 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 | « chrome/browser/safe_browsing/v4_test_utils.h ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/browser/safe_browsing/v4_test_utils.cc
diff --git a/chrome/browser/safe_browsing/v4_test_utils.cc b/chrome/browser/safe_browsing/v4_test_utils.cc
new file mode 100644
index 0000000000000000000000000000000000000000..5de0a3eafddd9dbc787ff56126f5ba8e9e6b8d9a
--- /dev/null
+++ b/chrome/browser/safe_browsing/v4_test_utils.cc
@@ -0,0 +1,104 @@
+// Copyright 2017 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/safe_browsing/v4_test_utils.h"
+
+#include "base/memory/ptr_util.h"
+#include "chrome/browser/safe_browsing/test_safe_browsing_service.h"
+#include "crypto/sha2.h"
+
+namespace safe_browsing {
+
+TestV4Store::TestV4Store(
+ const scoped_refptr<base::SequencedTaskRunner>& task_runner,
+ const base::FilePath& store_path)
+ : V4Store(task_runner, store_path, 0) {}
+
+bool TestV4Store::HasValidData() const {
+ return true;
+}
+
+void TestV4Store::MarkPrefixAsBad(HashPrefix prefix) {
+ hash_prefix_map_[prefix.size()] = prefix;
+}
+
+TestV4Database::TestV4Database(
+ const scoped_refptr<base::SequencedTaskRunner>& db_task_runner,
+ std::unique_ptr<StoreMap> store_map)
+ : V4Database(db_task_runner, std::move(store_map)) {}
+
+void TestV4Database::MarkPrefixAsBad(ListIdentifier list_id,
+ HashPrefix prefix) {
+ V4Store* base_store = store_map_->at(list_id).get();
+ TestV4Store* test_store = static_cast<TestV4Store*>(base_store);
+ test_store->MarkPrefixAsBad(prefix);
+}
+
+V4Store* TestV4StoreFactory::CreateV4Store(
+ const scoped_refptr<base::SequencedTaskRunner>& task_runner,
+ const base::FilePath& store_path) {
+ V4Store* new_store = new TestV4Store(task_runner, store_path);
+ new_store->Initialize();
+ return new_store;
+}
+
+TestV4DatabaseFactory::TestV4DatabaseFactory() : v4_db_(nullptr) {}
+
+std::unique_ptr<V4Database> TestV4DatabaseFactory::Create(
+ const scoped_refptr<base::SequencedTaskRunner>& db_task_runner,
+ std::unique_ptr<StoreMap> store_map) {
+ v4_db_ = new TestV4Database(db_task_runner, std::move(store_map));
+ return base::WrapUnique(v4_db_);
+}
+
+void TestV4DatabaseFactory::MarkPrefixAsBad(ListIdentifier list_id,
+ HashPrefix prefix) {
+ v4_db_->MarkPrefixAsBad(list_id, prefix);
+}
+
+TestV4GetHashProtocolManager::TestV4GetHashProtocolManager(
+ net::URLRequestContextGetter* request_context_getter,
+ const StoresToCheck& stores_to_check,
+ const V4ProtocolConfig& config)
+ : V4GetHashProtocolManager(request_context_getter,
+ stores_to_check,
+ config) {}
+
+void TestV4GetHashProtocolManager::AddToFullHashCache(FullHashInfo fhi) {
+ full_hash_cache_[fhi.full_hash].full_hash_infos.push_back(fhi);
+}
+
+std::unique_ptr<V4GetHashProtocolManager>
+TestV4GetHashProtocolManagerFactory::CreateProtocolManager(
+ net::URLRequestContextGetter* request_context_getter,
+ const StoresToCheck& stores_to_check,
+ const V4ProtocolConfig& config) {
+ pm_ = new TestV4GetHashProtocolManager(request_context_getter,
+ stores_to_check, config);
+ return base::WrapUnique(pm_);
+}
+
+FullHash GetFullHash(const GURL& url) {
+ std::string host;
+ std::string path;
+ V4ProtocolManagerUtil::CanonicalizeUrl(url, &host, &path, nullptr);
+
+ return crypto::SHA256HashString(host + path);
+}
+
+FullHashInfo GetFullHashInfo(const GURL& url, const ListIdentifier& list_id) {
+ return FullHashInfo(GetFullHash(url), list_id,
+ base::Time::Now() + base::TimeDelta::FromMinutes(5));
+}
+
+FullHashInfo GetFullHashInfoWithMetadata(
+ const GURL& url,
+ const ListIdentifier& list_id,
+ ThreatPatternType threat_pattern_type) {
+ FullHashInfo fhi = GetFullHashInfo(url, list_id);
+ fhi.metadata.threat_pattern_type = threat_pattern_type;
+ return fhi;
+}
+
+} // namespace safe_browsing
« no previous file with comments | « chrome/browser/safe_browsing/v4_test_utils.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698