Chromium Code Reviews| Index: content/browser/vr/vr_service_unittest.cc |
| diff --git a/content/browser/vr/vr_service_unittest.cc b/content/browser/vr/vr_service_unittest.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..59a5dcdd00df31355e3ed10ac50d9193cd672975 |
| --- /dev/null |
| +++ b/content/browser/vr/vr_service_unittest.cc |
| @@ -0,0 +1,153 @@ |
| +// Copyright 2015 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. |
| + |
| +#include "base/memory/scoped_ptr.h" |
| +#include "content/browser/vr/test/fake_vr_device.h" |
| +#include "content/browser/vr/test/fake_vr_device_provider.h" |
| +#include "content/browser/vr/vr_device_provider.h" |
| +#include "content/browser/vr/vr_service.h" |
| +#include "testing/gtest/include/gtest/gtest.h" |
| + |
| +namespace content { |
| + |
| +using blink::WebVRDevice; |
| + |
| +class VRServiceTest : public testing::Test { |
| + protected: |
| + VRServiceTest(); |
| + ~VRServiceTest() override; |
| + |
| + void SetUp() override; |
| + |
| + void InitializeProviders() { |
| + service_->InitializeProviders(); |
| + } |
| + |
| + void ReleaseProviderDevices() { |
| + service_->ReleaseProviderDevices(); |
| + } |
| + |
| + int ServiceConsumerCount() { |
| + return service_->consumers_.size(); |
| + } |
| + |
| + protected: |
| + FakeVRDeviceProvider* provider_; |
| + VRService* service_; |
| + |
| + DISALLOW_COPY_AND_ASSIGN(VRServiceTest); |
| +}; |
| + |
| +VRServiceTest::VRServiceTest() { |
| + |
| +} |
| + |
| +VRServiceTest::~VRServiceTest() { |
| + delete service_; |
|
no sievers
2015/03/26 19:55:15
Can you make |service_| scoped_ptr then?
|
| +} |
| + |
| +void VRServiceTest::SetUp() { |
| + provider_ = new FakeVRDeviceProvider(); |
|
no sievers
2015/03/26 19:55:15
Who deletes the provider?
|
| + service_ = new VRService(provider_); |
| +} |
| + |
| +TEST_F(VRServiceTest, InitializationTest) { |
| + EXPECT_FALSE(provider_->IsInitialized()); |
| + |
| + // The VRService should initialize each of it's providers upon initialization. |
| + InitializeProviders(); |
| + EXPECT_TRUE(provider_->IsInitialized()); |
| + |
| + // Similarly, upon ReleaseProviderDevices it should call ReleaseDevices on |
| + // each of it's providers. |
| + ReleaseProviderDevices(); |
| + EXPECT_FALSE(provider_->IsInitialized()); |
| + |
| + // Calling GetDevices should initialize the service if it hasn't been |
| + // initialized yet or the providesr have been released. |
| + std::vector<blink::WebVRDevice> webvr_devices; |
| + service_->GetVRDevices(&webvr_devices); |
| + EXPECT_TRUE(provider_->IsInitialized()); |
| +} |
| + |
| +TEST_F(VRServiceTest, ServiceConsumerTest) { |
| + |
| + { |
| + VRServiceConsumer consumer(service_); |
| + |
| + // Constructing a consumer should not cause the service to initialize it's |
| + // providers. |
| + EXPECT_FALSE(provider_->IsInitialized()); |
| + // Constructing a consumer does not automatically add it to the service. |
| + EXPECT_EQ(0, ServiceConsumerCount()); |
| + |
| + consumer.GetServiceInstance(); |
| + // Getting a service instance should not cause the service to initialize |
| + // it's providers. |
| + EXPECT_FALSE(provider_->IsInitialized()); |
| + // Getting a service instance should add the consumer to the service. |
| + EXPECT_EQ(1, ServiceConsumerCount()); |
| + |
| + InitializeProviders(); |
| + |
| + { |
| + VRServiceConsumer consumer2(service_); |
| + consumer2.GetServiceInstance(); |
| + EXPECT_EQ(2, ServiceConsumerCount()); |
| + } |
| + |
| + // Consumers should remove themselves from the service when destroyed. |
| + EXPECT_EQ(1, ServiceConsumerCount()); |
| + // Providers should not be released as long as there are one or more |
| + // consumers attached to the service. |
| + EXPECT_TRUE(provider_->IsInitialized()); |
| + } |
| + |
| + // When all consumers have been removed the providers should be released. |
| + EXPECT_EQ(0, ServiceConsumerCount()); |
| + EXPECT_FALSE(provider_->IsInitialized()); |
| +} |
| + |
| +TEST_F(VRServiceTest, GetDevicesBasicTest) { |
| + std::vector<blink::WebVRDevice> webvr_devices; |
| + service_->GetVRDevices(&webvr_devices); |
| + // Calling GetVRDevices should initialize the providers. |
| + EXPECT_TRUE(provider_->IsInitialized()); |
| + // Should successfully return zero devices when none are available. |
| + EXPECT_EQ((size_t)0, webvr_devices.size()); |
|
no sievers
2015/03/26 19:55:15
nit: 0u (or static_cast, style guide) here and bel
|
| + |
| + // GetDeviceByIndex should return NULL if an invalid index in queried. |
| + VRDevice* queried_device = service_->GetDevice(1); |
| + EXPECT_EQ(NULL, queried_device); |
| + |
| + scoped_ptr<FakeVRDevice> device1(new FakeVRDevice(provider_)); |
| + provider_->AddDevice(device1.get()); |
| + service_->GetVRDevices(&webvr_devices); |
| + // Should have successfully returned one device. |
| + EXPECT_EQ((size_t)1, webvr_devices.size()); |
| + // The WebVRDevice index should match the device id. |
| + EXPECT_EQ(webvr_devices[0].index, device1->id()); |
| + |
| + scoped_ptr<FakeVRDevice> device2(new FakeVRDevice(provider_)); |
| + provider_->AddDevice(device2.get()); |
| + service_->GetVRDevices(&webvr_devices); |
| + // Should have successfully returned two devices. |
| + EXPECT_EQ((size_t)2, webvr_devices.size()); |
| + // NOTE: Returned WebVRDevices are not required to be in any particular order. |
| + |
| + // Querying the WebVRDevice index should return the correct device. |
| + queried_device = service_->GetDevice(device1->id()); |
| + EXPECT_EQ(device1.get(), queried_device); |
| + queried_device = service_->GetDevice(device2->id()); |
| + EXPECT_EQ(device2.get(), queried_device); |
| + |
| + provider_->RemoveDevice(device1.get()); |
| + service_->GetVRDevices(&webvr_devices); |
| + // Should have successfully returned one device. |
| + EXPECT_EQ((size_t)1, webvr_devices.size()); |
| + // The WebVRDevice index should match the only remaining device id. |
| + EXPECT_EQ(webvr_devices[0].index, device2->id()); |
| +} |
| + |
| +} // namespace content |