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

Unified Diff: net/reporting/reporting_test_util.h

Issue 2751103002: Reporting: Wrap existing classes in context. (Closed)
Patch Set: rebase Created 3 years, 8 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 | « net/reporting/reporting_policy.cc ('k') | net/reporting/reporting_test_util.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: net/reporting/reporting_test_util.h
diff --git a/net/reporting/reporting_test_util.h b/net/reporting/reporting_test_util.h
index bb279ebc0505fac6db94987223c961b2a978cdae..9aeaa2e28b29b354e7a71ce450155eba15fa90f8 100644
--- a/net/reporting/reporting_test_util.h
+++ b/net/reporting/reporting_test_util.h
@@ -5,8 +5,24 @@
#ifndef NET_REPORTING_REPORTING_TEST_UTIL_H_
#define NET_REPORTING_REPORTING_TEST_UTIL_H_
+#include <memory>
+#include <string>
+#include <vector>
+
+#include "base/macros.h"
+#include "net/reporting/reporting_context.h"
+#include "net/reporting/reporting_delegate.h"
+#include "net/reporting/reporting_uploader.h"
+#include "testing/gtest/include/gtest/gtest.h"
+
class GURL;
+namespace base {
+class SimpleTestClock;
+class SimpleTestTickClock;
+class Value;
+} // namespace base
+
namespace url {
class Origin;
} // namespace url
@@ -22,6 +38,122 @@ const ReportingClient* FindClientInCache(const ReportingCache* cache,
const url::Origin& origin,
const GURL& endpoint);
+// A simple implementation of ReportingDelegate that only persists data in RAM.
+class TestReportingDelegate : public ReportingDelegate {
+ public:
+ TestReportingDelegate();
+
+ ~TestReportingDelegate() override;
+
+ // ReportingDelegate implementation:
+ std::unique_ptr<const base::Value> GetPersistedData() override;
+
+ void PersistData(std::unique_ptr<const base::Value> persisted_data) override;
+
+ private:
+ std::unique_ptr<const base::Value> persisted_data_;
+
+ DISALLOW_COPY_AND_ASSIGN(TestReportingDelegate);
+};
+
+// A test implementation of ReportingUploader that holds uploads for tests to
+// examine and complete with a specified outcome.
+class TestReportingUploader : public ReportingUploader {
+ public:
+ class PendingUpload {
+ public:
+ virtual ~PendingUpload();
+
+ virtual const GURL& url() const = 0;
+ virtual const std::string& json() const = 0;
+ virtual std::unique_ptr<base::Value> GetValue() const = 0;
+
+ virtual void Complete(Outcome outcome) = 0;
+
+ protected:
+ PendingUpload();
+ };
+
+ TestReportingUploader();
+ ~TestReportingUploader() override;
+
+ const std::vector<std::unique_ptr<PendingUpload>>& pending_uploads() const {
+ return pending_uploads_;
+ }
+
+ // ReportingUploader implementation:
+ void StartUpload(const GURL& url,
+ const std::string& json,
+ const Callback& callback) override;
+
+ private:
+ std::vector<std::unique_ptr<PendingUpload>> pending_uploads_;
+
+ DISALLOW_COPY_AND_ASSIGN(TestReportingUploader);
+};
+
+// A test implementation of ReportingContext that uses test versions of
+// ReportingDelegate, Clock, TickClock, and ReportingUploader.
+class TestReportingContext : public ReportingContext {
+ public:
+ TestReportingContext(const ReportingPolicy& policy);
+ ~TestReportingContext();
+
+ TestReportingDelegate* test_delegate() {
+ return reinterpret_cast<TestReportingDelegate*>(delegate());
+ }
+ base::SimpleTestClock* test_clock() {
+ return reinterpret_cast<base::SimpleTestClock*>(clock());
+ }
+ base::SimpleTestTickClock* test_tick_clock() {
+ return reinterpret_cast<base::SimpleTestTickClock*>(tick_clock());
+ }
+ TestReportingUploader* test_uploader() {
+ return reinterpret_cast<TestReportingUploader*>(uploader());
+ }
+
+ private:
+ DISALLOW_COPY_AND_ASSIGN(TestReportingContext);
+};
+
+// A unit test base class that provides a TestReportingContext and shorthand
+// getters.
+class ReportingTestBase : public ::testing::Test {
+ protected:
+ ReportingTestBase();
+ ~ReportingTestBase() override;
+
+ void UsePolicy(const ReportingPolicy& policy);
+
+ TestReportingContext* context() { return context_.get(); }
+
+ const ReportingPolicy& policy() { return context_->policy(); }
+
+ TestReportingDelegate* delegate() { return context_->test_delegate(); }
+ base::SimpleTestClock* clock() { return context_->test_clock(); }
+ base::SimpleTestTickClock* tick_clock() {
+ return context_->test_tick_clock();
+ }
+ TestReportingUploader* uploader() { return context_->test_uploader(); }
+
+ ReportingCache* cache() { return context_->cache(); }
+ ReportingEndpointManager* endpoint_manager() {
+ return context_->endpoint_manager();
+ }
+ ReportingDeliveryAgent* delivery_agent() {
+ return context_->delivery_agent();
+ }
+
+ base::TimeTicks yesterday();
+
+ base::TimeTicks tomorrow();
+
+ private:
+ std::unique_ptr<TestReportingContext> context_;
+
+ DISALLOW_COPY_AND_ASSIGN(ReportingTestBase);
+};
+
} // namespace net
#endif // NET_REPORING_REPORTING_TEST_UTIL_H_
« no previous file with comments | « net/reporting/reporting_policy.cc ('k') | net/reporting/reporting_test_util.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698