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

Unified Diff: chrome/browser/media/router/discovery/media_sink_service_base.h

Issue 2878103004: [Media Router] Create MediaSinkServiceBase and make DialMediaSinkService inherit from it (Closed)
Patch Set: rebase with master Created 3 years, 7 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
Index: chrome/browser/media/router/discovery/media_sink_service_base.h
diff --git a/chrome/browser/media/router/discovery/media_sink_service_base.h b/chrome/browser/media/router/discovery/media_sink_service_base.h
new file mode 100644
index 0000000000000000000000000000000000000000..1c761e4e5f99f85a7dfd466364d202005bb6e7ba
--- /dev/null
+++ b/chrome/browser/media/router/discovery/media_sink_service_base.h
@@ -0,0 +1,52 @@
+// 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.
+
+#ifndef CHROME_BROWSER_MEDIA_ROUTER_DISCOVERY_MEDIA_SINK_SERVICE_BASE_H_
+#define CHROME_BROWSER_MEDIA_ROUTER_DISCOVERY_MEDIA_SINK_SERVICE_BASE_H_
+
+#include <memory>
+#include <set>
+
+#include "base/gtest_prod_util.h"
+#include "base/timer/timer.h"
+#include "chrome/common/media_router/discovery/media_sink_internal.h"
+#include "chrome/common/media_router/discovery/media_sink_service.h"
+
+namespace media_router {
+
+class MediaSinkServiceBase : public MediaSinkService {
+ public:
+ explicit MediaSinkServiceBase(const OnSinksDiscoveredCallback& callback);
+ ~MediaSinkServiceBase() override;
+
+ protected:
+ void SetTimerForTest(std::unique_ptr<base::Timer> timer);
+
+ // Called when |finish_timer_| expires.
+ void OnFetchCompleted();
+
+ // Helper function to start |finish_timer_|.
+ void StartTimer();
+
+ // Timer for finishing fetching.
+ std::unique_ptr<base::Timer> finish_timer_;
+
+ // Time out value for |finish_timer_|
+ int fetch_complete_timeout_secs_;
+
+ // Sorted sinks from current round of discovery.
+ std::set<MediaSinkInternal> current_sinks_;
+
+ // Sorted sinks sent to Media Router Provider in last FetchCompleted().
+ std::set<MediaSinkInternal> mrp_sinks_;
+
+ private:
+ friend class MediaSinkServiceBaseTest;
+ FRIEND_TEST_ALL_PREFIXES(MediaSinkServiceBaseTest,
+ TestFetchCompleted_SameSink);
+};
+
+} // namespace media_router
+
+#endif // CHROME_BROWSER_MEDIA_ROUTER_DISCOVERY_MEDIA_SINK_SERVICE_BASE_H_

Powered by Google App Engine
This is Rietveld 408576698