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

Side by Side Diff: chrome/browser/media/router/mojo/media_route_controller_unittest.cc

Issue 2728543009: [Media Router] Custom Controls 2 - add MediaRouter::GetRouteController() (Closed)
Patch Set: Address Derek's comments 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 unified diff | Download patch
OLDNEW
1 // Copyright 2017 The Chromium Authors. All rights reserved. 1 // Copyright 2017 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "chrome/browser/media/router/mojo/media_route_controller.h" 5 #include "chrome/browser/media/router/mojo/media_route_controller.h"
6 6
7 #include <string> 7 #include <string>
8 #include <utility> 8 #include <utility>
9 9
10 #include "base/run_loop.h" 10 #include "base/run_loop.h"
11 #include "chrome/browser/media/router/mock_media_router.h"
11 #include "chrome/browser/media/router/mojo/media_router_mojo_test.h" 12 #include "chrome/browser/media/router/mojo/media_router_mojo_test.h"
12 #include "testing/gmock/include/gmock/gmock.h" 13 #include "testing/gmock/include/gmock/gmock.h"
13 #include "testing/gtest/include/gtest/gtest.h" 14 #include "testing/gtest/include/gtest/gtest.h"
14 15
16 using ::testing::Mock;
15 using ::testing::StrictMock; 17 using ::testing::StrictMock;
16 18
17 namespace media_router { 19 namespace media_router {
18 20
19 class MockMediaController : public mojom::MediaController { 21 namespace {
20 public:
21 MOCK_METHOD0(Play, void());
22 MOCK_METHOD0(Pause, void());
23 MOCK_METHOD1(SetMute, void(bool mute));
24 MOCK_METHOD1(SetVolume, void(float volume));
25 MOCK_METHOD1(Seek, void(base::TimeDelta time));
26 };
27 22
28 class MockMediaRouteControllerObserver : public MediaRouteController::Observer { 23 const char kRouteId[] = "routeId";
mark a. foltz 2017/04/11 19:43:20 constexpr
takumif 2017/04/12 23:11:36 Done.
29 public:
30 MockMediaRouteControllerObserver(
31 scoped_refptr<MediaRouteController> controller)
32 : MediaRouteController::Observer(controller) {}
33 24
34 MOCK_METHOD1(OnMediaStatusUpdated, void(const MediaStatus& status)); 25 } // namespace
35 };
36 26
37 class MediaRouteControllerTest : public ::testing::Test { 27 class MediaRouteControllerTest : public ::testing::Test {
38 public: 28 public:
39 MediaRouteControllerTest() {} 29 MediaRouteControllerTest() {}
40 ~MediaRouteControllerTest() override {} 30 ~MediaRouteControllerTest() override {}
41 31
42 void SetUp() override { 32 void SetUp() override {
43 mojom::MediaControllerPtr media_controller_ptr; 33 mojom::MediaControllerPtr media_controller_ptr;
44 mojom::MediaControllerRequest media_controller_request = 34 mojom::MediaControllerRequest media_controller_request =
45 mojo::MakeRequest(&media_controller_ptr); 35 mojo::MakeRequest(&media_controller_ptr);
46 media_controller_binding_ = 36 mock_media_controller_.Bind(std::move(media_controller_request));
47 base::MakeUnique<mojo::Binding<mojom::MediaController>>(
48 &mock_media_controller_, std::move(media_controller_request));
49 37
50 observer_ = base::MakeUnique<MockMediaRouteControllerObserver>( 38 observer_ = base::MakeUnique<MockMediaRouteControllerObserver>(
51 new MediaRouteController("routeId", std::move(media_controller_ptr))); 39 new MediaRouteController(kRouteId, std::move(media_controller_ptr),
dcheng 2017/04/14 05:30:07 Nit: from a readability perspective, this is a lit
takumif 2017/04/14 18:42:58 Done.
40 &router_));
52 } 41 }
53 42
54 scoped_refptr<MediaRouteController> GetController() const { 43 scoped_refptr<MediaRouteController> GetController() const {
55 return observer_->controller(); 44 return observer_->controller();
56 } 45 }
57 46
58 protected: 47 protected:
59 // This must be called only after |observer_| is set. 48 // This must be called only after |observer_| is set.
60 std::unique_ptr<StrictMock<MockMediaRouteControllerObserver>> CreateObserver() 49 std::unique_ptr<StrictMock<MockMediaRouteControllerObserver>> CreateObserver()
61 const { 50 const {
62 return base::MakeUnique<StrictMock<MockMediaRouteControllerObserver>>( 51 return base::MakeUnique<StrictMock<MockMediaRouteControllerObserver>>(
63 GetController()); 52 GetController());
64 } 53 }
65 54
55 MockMediaRouter router_;
66 MockMediaController mock_media_controller_; 56 MockMediaController mock_media_controller_;
67 std::unique_ptr<mojo::Binding<mojom::MediaController>>
68 media_controller_binding_;
69 std::unique_ptr<MockMediaRouteControllerObserver> observer_; 57 std::unique_ptr<MockMediaRouteControllerObserver> observer_;
70 58
71 content::TestBrowserThreadBundle test_thread_bundle_; 59 content::TestBrowserThreadBundle test_thread_bundle_;
72 60
73 private: 61 private:
74 DISALLOW_COPY_AND_ASSIGN(MediaRouteControllerTest); 62 DISALLOW_COPY_AND_ASSIGN(MediaRouteControllerTest);
75 }; 63 };
76 64
77 TEST_F(MediaRouteControllerTest, ForwardControllerCommands) { 65 TEST_F(MediaRouteControllerTest, ForwardControllerCommands) {
78 const float volume = 0.5; 66 const float volume = 0.5;
(...skipping 11 matching lines...) Expand all
90 GetController()->Seek(time); 78 GetController()->Seek(time);
91 } 79 }
92 80
93 TEST_F(MediaRouteControllerTest, NotifyMediaRouteControllerObservers) { 81 TEST_F(MediaRouteControllerTest, NotifyMediaRouteControllerObservers) {
94 auto observer1 = CreateObserver(); 82 auto observer1 = CreateObserver();
95 auto observer2 = CreateObserver(); 83 auto observer2 = CreateObserver();
96 84
97 MediaStatus status; 85 MediaStatus status;
98 status.title = "test media status"; 86 status.title = "test media status";
99 87
88 // Get a mojo pointer for |controller_|, so that we can notify it of status
89 // updates via mojo.
90 mojom::MediaStatusObserverPtr mojo_observer =
mark a. foltz 2017/04/11 19:43:19 It might be a good idea to test the binding invali
takumif 2017/04/12 23:11:36 BindObserverPtr() should only be called once in th
91 GetController()->BindObserverPtr();
92
93 base::RunLoop run_loop1;
100 EXPECT_CALL(*observer1, OnMediaStatusUpdated(status)); 94 EXPECT_CALL(*observer1, OnMediaStatusUpdated(status));
101 EXPECT_CALL(*observer2, OnMediaStatusUpdated(status)); 95 EXPECT_CALL(*observer2, OnMediaStatusUpdated(status));
102 // TODO(takumif): Use a mojom::MediaStatusObserverPtr bound to the controller. 96 mojo_observer->OnMediaStatusUpdated(status);
103 GetController()->OnMediaStatusUpdated(status); 97 run_loop1.RunUntilIdle();
104 98
105 observer1.reset(); 99 observer1.reset();
106 auto observer3 = CreateObserver(); 100 auto observer3 = CreateObserver();
107 101
102 base::RunLoop run_loop2;
108 EXPECT_CALL(*observer2, OnMediaStatusUpdated(status)); 103 EXPECT_CALL(*observer2, OnMediaStatusUpdated(status));
109 EXPECT_CALL(*observer3, OnMediaStatusUpdated(status)); 104 EXPECT_CALL(*observer3, OnMediaStatusUpdated(status));
110 // TODO(takumif): Use a mojom::MediaStatusObserverPtr bound to the controller. 105 mojo_observer->OnMediaStatusUpdated(status);
111 GetController()->OnMediaStatusUpdated(status); 106 run_loop2.RunUntilIdle();
107 }
108
109 TEST_F(MediaRouteControllerTest, DestroyControllerOnDisconnect) {
110 base::RunLoop run_loop;
111
112 // DetachRouteController() should be called when the connection to
113 // |mock_media_controller_| is invalidated.
114 EXPECT_CALL(router_, DetachRouteController(kRouteId, GetController().get()))
115 .Times(1);
116 mock_media_controller_.CloseBinding();
117
118 run_loop.RunUntilIdle();
119 EXPECT_TRUE(Mock::VerifyAndClearExpectations(&router_));
120 }
121
122 TEST_F(MediaRouteControllerTest, DestroyControllerOnNoObservers) {
123 auto observer1 = CreateObserver();
124 auto observer2 = CreateObserver();
125 // Get a pointer to the controller to use in EXPECT_CALL().
126 MediaRouteController* controller = GetController().get();
127 // Get rid of |observer_| and its reference to the controller.
128 observer_.reset();
129
130 EXPECT_CALL(router_, DetachRouteController(kRouteId, controller)).Times(0);
131 observer1.reset();
132
133 // DetachRouteController() should be called when the controller no longer
134 // has any observers.
135 EXPECT_CALL(router_, DetachRouteController(kRouteId, controller)).Times(1);
136 observer2.reset();
137 EXPECT_TRUE(Mock::VerifyAndClearExpectations(&router_));
112 } 138 }
113 139
114 } // namespace media_router 140 } // namespace media_router
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698