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

Side by Side Diff: device/vr/vr_device_client_impl_unittest.cc

Issue 2420743003: mojo VR interface simplified (Closed)
Patch Set: address leon@ comments about name Created 4 years, 1 month 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 2016 The Chromium Authors. All rights reserved. 1 // Copyright 2016 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 "device/vr/vr_service_impl.h" 5 /*#include "device/vr/vr_service_impl.h"
bajones 2016/10/25 22:21:38 Let's not check this in commented out.
6 6
7 #include "base/message_loop/message_loop.h" 7 #include "base/message_loop/message_loop.h"
8 #include "base/run_loop.h" 8 #include "base/run_loop.h"
9 #include "device/vr/test/fake_vr_device.h" 9 #include "device/vr/test/fake_vr_device.h"
10 #include "device/vr/test/fake_vr_device_provider.h" 10 #include "device/vr/test/fake_vr_device_provider.h"
11 #include "device/vr/vr_device_manager.h" 11 #include "device/vr/vr_device_manager.h"
12 #include "device/vr/vr_service.mojom.h" 12 #include "device/vr/vr_service.mojom.h"
13 #include "testing/gmock/include/gmock/gmock.h" 13 #include "testing/gmock/include/gmock/gmock.h"
14 14
15 using ::testing::_; 15 using ::testing::_;
16 using ::testing::Mock; 16 using ::testing::Mock;
17 17
18 namespace device { 18 namespace device {
19 19
20 class MockVRServiceClient : public VRServiceClient { 20 class MockVRDisplayClient : public VRDisplayClient {
21 public: 21 public:
22 MOCK_METHOD1(OnDisplayChanged, void(const VRDisplay& display)); 22 MOCK_METHOD1(RegisterDeviceClient, void(VRDeviceClientPtr& device_client));
23
24 MOCK_METHOD1(UpdateDisplayInfo, void(const VRDisplayPtr& display));
25
26 MOCK_METHOD1(OnDisplayChanged, void(const VRDisplayPtr& display));
23 void OnDisplayChanged(VRDisplayPtr display) override { 27 void OnDisplayChanged(VRDisplayPtr display) override {
24 OnDisplayChanged(*display); 28 OnDisplayChanged(*display);
25 last_display_ = std::move(display); 29 last_display_ = std::move(display);
26 } 30 }
27 31
28 MOCK_METHOD1(OnExitPresent, void(uint32_t index)); 32 MOCK_METHOD0(OnExitPresent, void());
29 33
30 MOCK_METHOD1(OnDisplayConnected, void(const VRDisplay& display)); 34 MOCK_METHOD1(OnDisplayConnected, void(const VRDisplayPtr& display));
31 void OnDisplayConnected(VRDisplayPtr display) override {
32 OnDisplayConnected(*display);
33 last_display_ = std::move(display);
34 }
35 void OnDisplayDisconnected(unsigned index) override {}
36 35
37 const VRDisplayPtr& LastDisplay() { return last_display_; } 36 MOCK_METHOD0(OnDisplayDisconnected, void());
38 37
39 private: 38 private:
40 VRDisplayPtr last_display_; 39 VRDisplayPtr last_display_;
41 }; 40 };
42 41
43 class VRServiceTestBinding { 42 class VRDeviceClientTestBinding {
44 public: 43 public:
45 VRServiceTestBinding() { 44 VRDeviceClientTestBinding(VRDevice* device, VRServiceImpl* service) {
46 auto request = mojo::GetProxy(&service_ptr_); 45 auto request = mojo::GetProxy(&device_client_ptr_);
47 service_impl_.reset(new VRServiceImpl()); 46 device_client_impl_.reset(new VRDeviceClientImpl(request, device, service));
48 service_impl_->Bind(std::move(request));
49 47
50 VRServiceClientPtr client_ptr; 48 VRServiceClientPtr client_ptr;
51 client_binding_.reset(new mojo::Binding<VRServiceClient>( 49 client_binding_.reset(new mojo::Binding<VRServiceClient>(
52 &mock_client_, mojo::GetProxy(&client_ptr))); 50 &mock_client_, mojo::GetProxy(&client_ptr)));
53 service_impl_->SetClient(std::move(client_ptr)); 51 service_impl_->SetClient(std::move(client_ptr));
54 } 52 }
55 53
56 void Close() { 54 void Close() {
57 service_ptr_.reset(); 55 device_client_ptr_.reset();
58 service_impl_.reset(); 56 device_client_impl_.reset();
59 } 57 }
60 58
61 MockVRServiceClient& client() { return mock_client_; } 59 MockVRServiceClient& client() { return mock_client_; }
62 VRServiceImpl* service() { return service_impl_.get(); } 60 VRServiceImpl* service() { return service_impl_.get(); }
63 61
64 private: 62 private:
65 std::unique_ptr<VRServiceImpl> service_impl_; 63 std::unique_ptr<VRDeviceClientImpl> device_client_impl_;
66 mojo::InterfacePtr<VRService> service_ptr_; 64 mojo::InterfacePtr<VRDeviceClient> device_client_ptr_;
67 65
68 MockVRServiceClient mock_client_; 66 MockVRDisplayClient mock_client_;
69 std::unique_ptr<mojo::Binding<VRServiceClient>> client_binding_; 67 std::unique_ptr<mojo::Binding<VRDisplayClient>> client_binding_;
70 68
71 DISALLOW_COPY_AND_ASSIGN(VRServiceTestBinding); 69 DISALLOW_COPY_AND_ASSIGN(VRServiceTestBinding);
72 }; 70 };
73 71
74 class VRServiceImplTest : public testing::Test { 72 class VRServiceImplTest : public testing::Test {
75 public: 73 public:
76 VRServiceImplTest() {} 74 VRServiceImplTest() {}
77 ~VRServiceImplTest() override {} 75 ~VRServiceImplTest() override {}
78 76
79 protected: 77 protected:
80 void SetUp() override { 78 void SetUp() override {
81 std::unique_ptr<FakeVRDeviceProvider> provider(new FakeVRDeviceProvider()); 79 std::unique_ptr<FakeVRDeviceProvider> provider(new FakeVRDeviceProvider());
82 provider_ = provider.get(); 80 provider_ = provider.get();
83 device_manager_.reset(new VRDeviceManager(std::move(provider))); 81 device_manager_.reset(new VRDeviceManager(std::move(provider)));
84 } 82 }
85 83
86 void TearDown() override { base::RunLoop().RunUntilIdle(); } 84 void TearDown() override { base::RunLoop().RunUntilIdle(); }
87 85
88 std::unique_ptr<VRServiceTestBinding> BindService() { 86 std::unique_ptr<VRServiceTestBinding> BindService() {
89 return std::unique_ptr<VRServiceTestBinding>(new VRServiceTestBinding()); 87 return std::unique_ptr<VRServiceTestBinding>(new VRServiceTestBinding());
90 } 88 }
91 89
92 size_t ServiceCount() { return device_manager_->services_.size(); } 90 size_t ServiceCount() { return device_manager_->services_.size(); }
93 91
94 bool presenting() { return !!device_manager_->presenting_service_; }
95
96 base::MessageLoop message_loop_; 92 base::MessageLoop message_loop_;
97 FakeVRDeviceProvider* provider_; 93 FakeVRDeviceProvider* provider_;
98 std::unique_ptr<VRDeviceManager> device_manager_; 94 std::unique_ptr<VRDeviceManager> device_manager_;
99 95
100 DISALLOW_COPY_AND_ASSIGN(VRServiceImplTest); 96 DISALLOW_COPY_AND_ASSIGN(VRServiceImplTest);
101 }; 97 };
102 98
103 // Ensure that services are registered with the device manager as they are
104 // created and removed from the device manager as their connections are closed.
105 TEST_F(VRServiceImplTest, DeviceManagerRegistration) {
106 EXPECT_EQ(0u, ServiceCount());
107
108 std::unique_ptr<VRServiceTestBinding> service_1 = BindService();
109
110 EXPECT_EQ(1u, ServiceCount());
111
112 std::unique_ptr<VRServiceTestBinding> service_2 = BindService();
113
114 EXPECT_EQ(2u, ServiceCount());
115
116 service_1->Close();
117
118 EXPECT_EQ(1u, ServiceCount());
119
120 service_2->Close();
121
122 EXPECT_EQ(0u, ServiceCount());
123 }
124
125 // Ensure that DeviceChanged calls are dispatched to all active services. 99 // Ensure that DeviceChanged calls are dispatched to all active services.
126 TEST_F(VRServiceImplTest, DeviceChangedDispatched) { 100 TEST_F(VRServiceImplTest, DeviceChangedDispatched) {
127 std::unique_ptr<VRServiceTestBinding> service_1 = BindService(); 101 std::unique_ptr<VRServiceTestBinding> service_1 = BindService();
128 std::unique_ptr<VRServiceTestBinding> service_2 = BindService(); 102 std::unique_ptr<VRServiceTestBinding> service_2 = BindService();
129 103
130 EXPECT_CALL(service_1->client(), OnDisplayChanged(_)); 104 EXPECT_CALL(service_1->client(), OnDisplayChanged(_));
131 EXPECT_CALL(service_2->client(), OnDisplayChanged(_)); 105 EXPECT_CALL(service_2->client(), OnDisplayChanged(_));
132 106
133 std::unique_ptr<FakeVRDevice> device(new FakeVRDevice(provider_)); 107 std::unique_ptr<FakeVRDevice> device(new FakeVRDevice(provider_));
134 device_manager_->OnDeviceChanged(device->GetVRDevice()); 108 device_manager_->OnDeviceChanged(device->GetVRDevice());
(...skipping 62 matching lines...) Expand 10 before | Expand all | Expand 10 after
197 EXPECT_CALL(service_2->client(), OnDisplayConnected(_)); 171 EXPECT_CALL(service_2->client(), OnDisplayConnected(_));
198 172
199 std::unique_ptr<FakeVRDevice> device(new FakeVRDevice(provider_)); 173 std::unique_ptr<FakeVRDevice> device(new FakeVRDevice(provider_));
200 device_manager_->OnDeviceConnectionStatusChanged(device.get(), true); 174 device_manager_->OnDeviceConnectionStatusChanged(device.get(), true);
201 175
202 base::RunLoop().RunUntilIdle(); 176 base::RunLoop().RunUntilIdle();
203 177
204 EXPECT_EQ(device->id(), service_1->client().LastDisplay()->index); 178 EXPECT_EQ(device->id(), service_1->client().LastDisplay()->index);
205 EXPECT_EQ(device->id(), service_2->client().LastDisplay()->index); 179 EXPECT_EQ(device->id(), service_2->client().LastDisplay()->index);
206 } 180 }
207 } 181
182 }*/
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698