Chromium Code Reviews| Index: chrome/browser/usb/usb_chooser_permission_context_unittest.cc |
| diff --git a/chrome/browser/usb/usb_chooser_permission_context_unittest.cc b/chrome/browser/usb/usb_chooser_permission_context_unittest.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..723bb02a0107c1a26c977411137a3b10bd5fada2 |
| --- /dev/null |
| +++ b/chrome/browser/usb/usb_chooser_permission_context_unittest.cc |
| @@ -0,0 +1,122 @@ |
| +// 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 "chrome/browser/usb/usb_chooser_permission_context.h" |
| +#include "chrome/browser/usb/usb_chooser_permission_context_factory.h" |
| +#include "chrome/test/base/testing_profile.h" |
| +#include "content/public/test/test_browser_thread_bundle.h" |
| +#include "device/core/device_client.h" |
| +#include "device/usb/mock_usb_device.h" |
| +#include "device/usb/mock_usb_service.h" |
| + |
| +using device::MockUsbDevice; |
| +using device::UsbDevice; |
| + |
| +namespace { |
| + |
| +class TestDeviceClient : public device::DeviceClient { |
| + public: |
| + TestDeviceClient() {} |
| + ~TestDeviceClient() override {} |
| + |
| + device::MockUsbService& usb_service() { return usb_service_; } |
| + |
| + private: |
| + device::UsbService* GetUsbService() override { return &usb_service_; } |
| + |
| + device::MockUsbService usb_service_; |
| +}; |
| + |
| +} // namespace |
| + |
| +class UsbChooserPermissionContextTest : public testing::Test { |
| + public: |
| + UsbChooserPermissionContextTest() {} |
| + ~UsbChooserPermissionContextTest() override {} |
| + |
| + protected: |
| + Profile* profile() { return &profile_; } |
| + device::MockUsbService& usb_service() { return device_client_.usb_service(); } |
| + |
| + private: |
| + content::TestBrowserThreadBundle thread_bundle_; |
| + TestDeviceClient device_client_; |
| + TestingProfile profile_; |
| +}; |
| + |
| +TEST_F(UsbChooserPermissionContextTest, CheckGrantAndRevokePermission) { |
| + GURL origin("https://www.google.com"); |
| + scoped_refptr<UsbDevice> device = |
| + new MockUsbDevice(0, 0, "Google", "Gizmo", "123ABC"); |
| + usb_service().AddDevice(device); |
| + UsbChooserPermissionContext* store = |
| + UsbChooserPermissionContextFactory::GetForProfile(profile()); |
| + |
| + EXPECT_FALSE(store->HasDevicePermission(origin, origin, device->guid())); |
| + store->GrantDevicePermission(origin, origin, device->guid()); |
| + EXPECT_TRUE(store->HasDevicePermission(origin, origin, device->guid())); |
| + store->RevokeDevicePermission(origin, origin, device->guid()); |
| + EXPECT_FALSE(store->HasDevicePermission(origin, origin, device->guid())); |
| +} |
| + |
| +TEST_F(UsbChooserPermissionContextTest, |
| + CheckGrantAndRevokeEphemeralPermission) { |
| + GURL origin("https://www.google.com"); |
| + scoped_refptr<UsbDevice> device = |
| + new MockUsbDevice(0, 0, "Google", "Gizmo", ""); |
| + scoped_refptr<UsbDevice> other_device = |
|
raymes
2015/10/14 02:07:04
nit: this is unused
Though possible add a case whe
Reilly Grant (use Gerrit)
2015/10/22 00:57:03
Fixed.
|
| + new MockUsbDevice(0, 0, "Google", "Gizmo", ""); |
| + usb_service().AddDevice(device); |
| + UsbChooserPermissionContext* store = |
| + UsbChooserPermissionContextFactory::GetForProfile(profile()); |
| + |
| + EXPECT_FALSE(store->HasDevicePermission(origin, origin, device->guid())); |
| + store->GrantDevicePermission(origin, origin, device->guid()); |
| + EXPECT_TRUE(store->HasDevicePermission(origin, origin, device->guid())); |
| + store->RevokeDevicePermission(origin, origin, device->guid()); |
| + EXPECT_FALSE(store->HasDevicePermission(origin, origin, device->guid())); |
| +} |
| + |
| +TEST_F(UsbChooserPermissionContextTest, DisconnectDeviceWithPermission) { |
| + GURL origin("https://www.google.com"); |
| + scoped_refptr<UsbDevice> device = |
| + new MockUsbDevice(0, 0, "Google", "Gizmo", "123ABC"); |
| + usb_service().AddDevice(device); |
| + UsbChooserPermissionContext* store = |
| + UsbChooserPermissionContextFactory::GetForProfile(profile()); |
| + |
| + EXPECT_FALSE(store->HasDevicePermission(origin, origin, device->guid())); |
| + store->GrantDevicePermission(origin, origin, device->guid()); |
| + EXPECT_TRUE(store->HasDevicePermission(origin, origin, device->guid())); |
| + usb_service().RemoveDevice(device); |
| + EXPECT_FALSE(store->HasDevicePermission(origin, origin, device->guid())); |
| + |
| + scoped_refptr<UsbDevice> reconnected_device = |
| + new MockUsbDevice(0, 0, "Google", "Gizmo", "123ABC"); |
| + usb_service().AddDevice(reconnected_device); |
| + EXPECT_TRUE( |
| + store->HasDevicePermission(origin, origin, reconnected_device->guid())); |
| +} |
| + |
| +TEST_F(UsbChooserPermissionContextTest, |
| + DisconnectDeviceWithEphemeralPermission) { |
| + GURL origin("https://www.google.com"); |
| + scoped_refptr<UsbDevice> device = |
| + new MockUsbDevice(0, 0, "Google", "Gizmo", ""); |
| + usb_service().AddDevice(device); |
| + UsbChooserPermissionContext* store = |
| + UsbChooserPermissionContextFactory::GetForProfile(profile()); |
| + |
| + EXPECT_FALSE(store->HasDevicePermission(origin, origin, device->guid())); |
| + store->GrantDevicePermission(origin, origin, device->guid()); |
| + EXPECT_TRUE(store->HasDevicePermission(origin, origin, device->guid())); |
| + usb_service().RemoveDevice(device); |
| + EXPECT_FALSE(store->HasDevicePermission(origin, origin, device->guid())); |
| + |
| + scoped_refptr<UsbDevice> reconnected_device = |
| + new MockUsbDevice(0, 0, "Google", "Gizmo", ""); |
| + usb_service().AddDevice(reconnected_device); |
| + EXPECT_FALSE( |
| + store->HasDevicePermission(origin, origin, reconnected_device->guid())); |
| +} |