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

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

Issue 2488273002: Revert of mojo VR interface simplified (Closed)
Patch Set: 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
« no previous file with comments | « device/vr/vr_service_impl.cc ('k') | third_party/WebKit/Source/modules/vr/VRController.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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"
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 // TODO(shaobo.yan@intel.com) : Update the whole unittest. 20 class MockVRServiceClient : public VRServiceClient {
21 class MockVRServiceClient : public mojom::VRServiceClient {}; 21 public:
22 MOCK_METHOD1(OnDisplayChanged, void(const VRDisplay& display));
23 void OnDisplayChanged(VRDisplayPtr display) override {
24 OnDisplayChanged(*display);
25 last_display_ = std::move(display);
26 }
27
28 MOCK_METHOD1(OnExitPresent, void(uint32_t index));
29
30 MOCK_METHOD1(OnDisplayConnected, void(const VRDisplay& display));
31 void OnDisplayConnected(VRDisplayPtr display) override {
32 OnDisplayConnected(*display);
33 last_display_ = std::move(display);
34 }
35 void OnDisplayDisconnected(unsigned index) override {}
36
37 const VRDisplayPtr& LastDisplay() { return last_display_; }
38
39 private:
40 VRDisplayPtr last_display_;
41 };
22 42
23 class VRServiceTestBinding { 43 class VRServiceTestBinding {
24 public: 44 public:
25 VRServiceTestBinding() { 45 VRServiceTestBinding() {
26 auto request = mojo::GetProxy(&service_ptr_); 46 auto request = mojo::GetProxy(&service_ptr_);
27 service_impl_.reset(new VRServiceImpl()); 47 service_impl_.reset(new VRServiceImpl());
28 service_impl_->Bind(std::move(request)); 48 service_impl_->Bind(std::move(request));
29 49
30 client_binding_.reset(new mojo::Binding<mojom::VRServiceClient>( 50 VRServiceClientPtr client_ptr;
31 mock_client_, mojo::GetProxy(&client_ptr_))); 51 client_binding_.reset(new mojo::Binding<VRServiceClient>(
32 } 52 &mock_client_, mojo::GetProxy(&client_ptr)));
33 53 service_impl_->SetClient(std::move(client_ptr));
34 void SetClient() {
35 service_impl_->SetClient(
36 std::move(client_ptr_),
37 base::Bind(&device::VRServiceTestBinding::SetNumberOfDevices,
38 base::Unretained(this)));
39 }
40
41 void SetNumberOfDevices(unsigned int number_of_devices) {
42 number_of_devices_ = number_of_devices;
43 } 54 }
44 55
45 void Close() { 56 void Close() {
46 service_ptr_.reset(); 57 service_ptr_.reset();
47 service_impl_.reset(); 58 service_impl_.reset();
48 } 59 }
49 60
50 MockVRServiceClient* client() { return mock_client_; } 61 MockVRServiceClient& client() { return mock_client_; }
51 VRServiceImpl* service() { return service_impl_.get(); } 62 VRServiceImpl* service() { return service_impl_.get(); }
52 63
53 private: 64 private:
54 mojom::VRServiceClientPtr client_ptr_;
55 std::unique_ptr<VRServiceImpl> service_impl_; 65 std::unique_ptr<VRServiceImpl> service_impl_;
56 mojo::InterfacePtr<mojom::VRService> service_ptr_; 66 mojo::InterfacePtr<VRService> service_ptr_;
57 67
58 MockVRServiceClient* mock_client_; 68 MockVRServiceClient mock_client_;
59 std::unique_ptr<mojo::Binding<mojom::VRServiceClient>> client_binding_; 69 std::unique_ptr<mojo::Binding<VRServiceClient>> client_binding_;
60 unsigned int number_of_devices_;
61 70
62 DISALLOW_COPY_AND_ASSIGN(VRServiceTestBinding); 71 DISALLOW_COPY_AND_ASSIGN(VRServiceTestBinding);
63 }; 72 };
64 73
65 class VRServiceImplTest : public testing::Test { 74 class VRServiceImplTest : public testing::Test {
66 public: 75 public:
67 VRServiceImplTest() {} 76 VRServiceImplTest() {}
68 ~VRServiceImplTest() override {} 77 ~VRServiceImplTest() override {}
69 78
70 protected: 79 protected:
71 void SetUp() override { 80 void SetUp() override {
72 std::unique_ptr<FakeVRDeviceProvider> provider(new FakeVRDeviceProvider()); 81 std::unique_ptr<FakeVRDeviceProvider> provider(new FakeVRDeviceProvider());
73 provider_ = provider.get(); 82 provider_ = provider.get();
74 device_manager_.reset(new VRDeviceManager(std::move(provider))); 83 device_manager_.reset(new VRDeviceManager(std::move(provider)));
75 } 84 }
76 85
77 void TearDown() override { base::RunLoop().RunUntilIdle(); } 86 void TearDown() override { base::RunLoop().RunUntilIdle(); }
78 87
79 std::unique_ptr<VRServiceTestBinding> BindService() { 88 std::unique_ptr<VRServiceTestBinding> BindService() {
80 auto test_binding = base::WrapUnique(new VRServiceTestBinding()); 89 return std::unique_ptr<VRServiceTestBinding>(new VRServiceTestBinding());
81 test_binding->SetClient();
82 return test_binding;
83 } 90 }
84 91
85 size_t ServiceCount() { return device_manager_->services_.size(); } 92 size_t ServiceCount() { return device_manager_->services_.size(); }
86 93
94 bool presenting() { return !!device_manager_->presenting_service_; }
95
87 base::MessageLoop message_loop_; 96 base::MessageLoop message_loop_;
88 FakeVRDeviceProvider* provider_; 97 FakeVRDeviceProvider* provider_;
89 std::unique_ptr<VRDeviceManager> device_manager_; 98 std::unique_ptr<VRDeviceManager> device_manager_;
90 99
91 DISALLOW_COPY_AND_ASSIGN(VRServiceImplTest); 100 DISALLOW_COPY_AND_ASSIGN(VRServiceImplTest);
92 }; 101 };
93 102
94 // Ensure that services are registered with the device manager as they are 103 // Ensure that services are registered with the device manager as they are
95 // created and removed from the device manager as their connections are closed. 104 // created and removed from the device manager as their connections are closed.
96 TEST_F(VRServiceImplTest, DeviceManagerRegistration) { 105 TEST_F(VRServiceImplTest, DeviceManagerRegistration) {
97 EXPECT_EQ(0u, ServiceCount()); 106 EXPECT_EQ(0u, ServiceCount());
98 107
99 std::unique_ptr<VRServiceTestBinding> service_1 = BindService(); 108 std::unique_ptr<VRServiceTestBinding> service_1 = BindService();
100 109
101 EXPECT_EQ(1u, ServiceCount()); 110 EXPECT_EQ(1u, ServiceCount());
102 111
103 std::unique_ptr<VRServiceTestBinding> service_2 = BindService(); 112 std::unique_ptr<VRServiceTestBinding> service_2 = BindService();
104 113
105 EXPECT_EQ(2u, ServiceCount()); 114 EXPECT_EQ(2u, ServiceCount());
106 115
107 service_1->Close(); 116 service_1->Close();
108 117
109 EXPECT_EQ(1u, ServiceCount()); 118 EXPECT_EQ(1u, ServiceCount());
110 119
111 service_2->Close(); 120 service_2->Close();
112 121
113 EXPECT_EQ(0u, ServiceCount()); 122 EXPECT_EQ(0u, ServiceCount());
114 } 123 }
115 124
125 // Ensure that DeviceChanged calls are dispatched to all active services.
126 TEST_F(VRServiceImplTest, DeviceChangedDispatched) {
127 std::unique_ptr<VRServiceTestBinding> service_1 = BindService();
128 std::unique_ptr<VRServiceTestBinding> service_2 = BindService();
129
130 EXPECT_CALL(service_1->client(), OnDisplayChanged(_));
131 EXPECT_CALL(service_2->client(), OnDisplayChanged(_));
132
133 std::unique_ptr<FakeVRDevice> device(new FakeVRDevice(provider_));
134 device_manager_->OnDeviceChanged(device->GetVRDevice());
135
136 base::RunLoop().RunUntilIdle();
137
138 EXPECT_EQ(device->id(), service_1->client().LastDisplay()->index);
139 EXPECT_EQ(device->id(), service_2->client().LastDisplay()->index);
116 } 140 }
141
142 // Ensure that presenting devices cannot be accessed by other services
143 TEST_F(VRServiceImplTest, DevicePresentationIsolation) {
144 std::unique_ptr<VRServiceTestBinding> service_1 = BindService();
145 std::unique_ptr<VRServiceTestBinding> service_2 = BindService();
146
147 std::unique_ptr<FakeVRDevice> device(new FakeVRDevice(provider_));
148 provider_->AddDevice(device.get());
149
150 // Ensure the device manager has seen the fake device
151 device_manager_->GetVRDevices();
152
153 // When not presenting either service should be able to access the device
154 EXPECT_EQ(device.get(), VRDeviceManager::GetAllowedDevice(
155 service_1->service(), device->id()));
156 EXPECT_EQ(device.get(), VRDeviceManager::GetAllowedDevice(
157 service_2->service(), device->id()));
158
159 // Begin presenting to the fake device with service 1
160 EXPECT_TRUE(device_manager_->RequestPresent(service_1->service(),
161 device->id(), true));
162
163 EXPECT_TRUE(presenting());
164
165 // Service 2 should not be able to present to the device while service 1
166 // is still presenting.
167 EXPECT_FALSE(device_manager_->RequestPresent(service_2->service(),
168 device->id(), true));
169
170 // Only the presenting service should be able to access the device
171 EXPECT_EQ(device.get(), VRDeviceManager::GetAllowedDevice(
172 service_1->service(), device->id()));
173 EXPECT_EQ(nullptr, VRDeviceManager::GetAllowedDevice(service_2->service(),
174 device->id()));
175
176 // Service 2 should not be able to exit presentation to the device
177 device_manager_->ExitPresent(service_2->service(), device->id());
178 EXPECT_TRUE(presenting());
179
180 // Service 1 should be able to exit the presentation it initiated.
181 device_manager_->ExitPresent(service_1->service(), device->id());
182 EXPECT_FALSE(presenting());
183
184 // Once presention had ended both services should be able to access the device
185 EXPECT_EQ(device.get(), VRDeviceManager::GetAllowedDevice(
186 service_1->service(), device->id()));
187 EXPECT_EQ(device.get(), VRDeviceManager::GetAllowedDevice(
188 service_2->service(), device->id()));
189 }
190
191 // Ensure that DeviceChanged calls are dispatched to all active services.
192 TEST_F(VRServiceImplTest, DeviceConnectedDispatched) {
193 std::unique_ptr<VRServiceTestBinding> service_1 = BindService();
194 std::unique_ptr<VRServiceTestBinding> service_2 = BindService();
195
196 EXPECT_CALL(service_1->client(), OnDisplayConnected(_));
197 EXPECT_CALL(service_2->client(), OnDisplayConnected(_));
198
199 std::unique_ptr<FakeVRDevice> device(new FakeVRDevice(provider_));
200 device_manager_->OnDeviceConnectionStatusChanged(device.get(), true);
201
202 base::RunLoop().RunUntilIdle();
203
204 EXPECT_EQ(device->id(), service_1->client().LastDisplay()->index);
205 EXPECT_EQ(device->id(), service_2->client().LastDisplay()->index);
206 }
207 }
OLDNEW
« no previous file with comments | « device/vr/vr_service_impl.cc ('k') | third_party/WebKit/Source/modules/vr/VRController.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698