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

Unified Diff: components/doodle/doodle_fetcher.h

Issue 2707293002: [Doodle] Split DoodleFetcher into interface + Impl (Closed)
Patch Set: review 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 | « components/doodle/BUILD.gn ('k') | components/doodle/doodle_fetcher.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: components/doodle/doodle_fetcher.h
diff --git a/components/doodle/doodle_fetcher.h b/components/doodle/doodle_fetcher.h
index 951bbad3913a5605fa4208b1b0c6e86c8805bd5c..5745d6c2ae771e0f873f74ccbc0a161f46c82927 100644
--- a/components/doodle/doodle_fetcher.h
+++ b/components/doodle/doodle_fetcher.h
@@ -5,104 +5,32 @@
#ifndef COMPONENTS_DOODLE_DOODLE_FETCHER_H_
#define COMPONENTS_DOODLE_DOODLE_FETCHER_H_
-#include <memory>
-#include <string>
-#include <utility>
-#include <vector>
-
-#include "base/callback.h"
-#include "base/macros.h"
-#include "base/memory/ref_counted.h"
-#include "base/memory/weak_ptr.h"
+#include "base/callback_forward.h"
#include "base/optional.h"
#include "components/doodle/doodle_types.h"
-#include "net/url_request/url_fetcher_delegate.h"
-#include "net/url_request/url_request_context_getter.h"
-#include "url/gurl.h"
-
-class GoogleURLTracker;
-
-namespace base {
-class Clock;
-class DictionaryValue;
-class Value;
-}
namespace doodle {
-// This class provides information about any recent doodle.
-// It works asynchronously and calls a callback when finished fetching the
-// information from the remote enpoint.
-class DoodleFetcher : public net::URLFetcherDelegate {
+// Interface for fetching the current doodle from the network.
+// It asynchronously calls a callback when fetching the doodle information from
+// the remote enpoint finishes.
+// DoodleFetcherImpl is the default implementation; this interface exists to
+// make it easy to use fakes or mocks in tests.
+class DoodleFetcher {
public:
// Callback that is invoked when the fetching is done.
// |doodle_config| will only contain a value if |state| is AVAILABLE.
using FinishedCallback = base::OnceCallback<void(
DoodleState state,
const base::Optional<DoodleConfig>& doodle_config)>;
- // Callback for JSON parsing to allow injecting platform-dependent code.
- using ParseJSONCallback = base::Callback<void(
- const std::string& unsafe_json,
- const base::Callback<void(std::unique_ptr<base::Value> json)>& success,
- const base::Callback<void(const std::string&)>& error)>;
- DoodleFetcher(scoped_refptr<net::URLRequestContextGetter> download_context,
- GoogleURLTracker* google_url_tracker,
- const ParseJSONCallback& json_parsing_callback);
- ~DoodleFetcher() override;
+ virtual ~DoodleFetcher() = default;
// Fetches a doodle asynchronously. The |callback| is called with a
// DoodleState indicating whether the request succeded in fetching a doodle.
// If a fetch is already running, the callback will be queued and invoked with
// result from the next completed request.
- void FetchDoodle(FinishedCallback callback);
-
- // Overrides internal clock for testing purposes.
- void SetClockForTesting(std::unique_ptr<base::Clock> clock) {
- clock_ = std::move(clock);
- }
-
- private:
- // net::URLFetcherDelegate implementation.
- void OnURLFetchComplete(const net::URLFetcher* source) override;
-
- // ParseJSONCallback Success callback
- void OnJsonParsed(std::unique_ptr<base::Value> json);
- // ParseJSONCallback Failure callback
- void OnJsonParseFailed(const std::string& error_message);
-
- base::Optional<DoodleConfig> ParseDoodle(
- const base::DictionaryValue& ddljson) const;
- bool ParseImage(const base::DictionaryValue& image_dict,
- const std::string& image_name,
- DoodleImage* image) const;
- void ParseBaseInformation(const base::DictionaryValue& ddljson,
- DoodleConfig* config) const;
- GURL ParseRelativeUrl(const base::DictionaryValue& dict_value,
- const std::string& key) const;
-
- void RespondToAllCallbacks(DoodleState state,
- const base::Optional<DoodleConfig>& config);
- GURL GetGoogleBaseUrl() const;
-
- // Returns whether a fetch is still in progress. A fetch begins when a
- // callback is added and ends when the last callback was called.
- bool IsFetchInProgress() const { return !callbacks_.empty(); }
-
- // Parameters set from constructor.
- scoped_refptr<net::URLRequestContextGetter> const download_context_;
- ParseJSONCallback json_parsing_callback_;
- GoogleURLTracker* google_url_tracker_;
-
- // Allow for an injectable tick clock for testing.
- std::unique_ptr<base::Clock> clock_;
-
- std::vector<FinishedCallback> callbacks_;
- std::unique_ptr<net::URLFetcher> fetcher_;
-
- base::WeakPtrFactory<DoodleFetcher> weak_ptr_factory_;
-
- DISALLOW_COPY_AND_ASSIGN(DoodleFetcher);
+ virtual void FetchDoodle(FinishedCallback callback) = 0;
};
} // namespace doodle
« no previous file with comments | « components/doodle/BUILD.gn ('k') | components/doodle/doodle_fetcher.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698