Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | |
| 2 // Use of this source code is governed by a BSD-style license that can be | |
| 3 // found in the LICENSE file. | |
| 4 | |
| 5 #include "chrome/browser/system_monitor/image_capture_device_browser_mac.h" | |
| 6 | |
| 7 #import <ImageCaptureCore/ImageCaptureCore.h> | |
|
sail
2012/12/17 03:16:03
newline after system includes
Greg Billock
2012/12/17 23:20:41
Done.
| |
| 8 #include "base/file_path.h" | |
| 9 #include "base/mac/foundation_util.h" | |
| 10 #include "base/memory/weak_ptr.h" | |
| 11 #include "base/message_loop.h" | |
| 12 #include "base/system_monitor/system_monitor.h" | |
| 13 #include "chrome/browser/system_monitor/image_capture_camera.h" | |
| 14 #include "testing/gtest/include/gtest/gtest.h" | |
| 15 | |
| 16 @interface MockICCameraDevice : ICCameraDevice { | |
| 17 } | |
| 18 | |
| 19 @end | |
| 20 | |
| 21 @implementation MockICCameraDevice | |
| 22 | |
| 23 - (NSString*)mountPoint { | |
| 24 return @"mountPoint"; | |
| 25 } | |
| 26 | |
| 27 - (NSString*)name { | |
| 28 return @"name"; | |
| 29 } | |
| 30 | |
| 31 - (NSString*)UUIDString { | |
| 32 return @"id"; | |
|
sail
2012/12/17 03:16:03
make this a constant above in an anonymous namespa
Greg Billock
2012/12/17 23:20:41
Done.
| |
| 33 } | |
| 34 | |
| 35 - (ICDeviceType)type { | |
| 36 return ICDeviceTypeCamera; | |
| 37 } | |
| 38 | |
| 39 - (void)requestOpenSession { | |
| 40 } | |
| 41 | |
| 42 - (void)requestCloseSession { | |
| 43 } | |
| 44 | |
| 45 @end | |
| 46 | |
| 47 @interface MockICCameraFile : ICCameraFile { | |
| 48 @private | |
|
sail
2012/12/17 03:16:03
space
Greg Billock
2012/12/17 23:20:41
Done.
| |
| 49 scoped_nsobject<NSString> name_; | |
| 50 scoped_nsobject<NSDate> date_; | |
| 51 } | |
| 52 | |
| 53 - (id)init:(NSString*)name; | |
| 54 | |
| 55 @end | |
| 56 | |
| 57 @implementation MockICCameraFile | |
| 58 | |
| 59 - (id)init:(NSString*)name { | |
| 60 if ((self = [super init])) { | |
| 61 name_.reset(name); | |
| 62 date_.reset([[NSDate dateWithNaturalLanguageString:@"12/12/12"] retain]); | |
| 63 } | |
| 64 return self; | |
| 65 } | |
| 66 | |
| 67 - (NSString*)name { | |
| 68 return name_.get(); | |
| 69 } | |
| 70 | |
| 71 - (NSString*)UTI { | |
| 72 return base::mac::CFToNSCast(kUTTypeImage); | |
| 73 } | |
| 74 | |
| 75 - (NSDate*)modificationDate { | |
| 76 return date_.get(); | |
| 77 } | |
| 78 | |
| 79 - (NSDate*)creationDate { | |
| 80 return date_.get(); | |
| 81 } | |
| 82 | |
| 83 - (off_t)fileSize { | |
| 84 return 1000; | |
| 85 } | |
| 86 | |
| 87 @end | |
| 88 | |
| 89 class TestCameraListener | |
| 90 : public ImageCaptureDeviceListener, | |
| 91 public base::SupportsWeakPtr<TestCameraListener> { | |
| 92 public: | |
| 93 TestCameraListener() : completed_(false), removed_(false) {} | |
| 94 ~TestCameraListener() {} | |
|
sail
2012/12/17 03:16:03
virtual
Greg Billock
2012/12/17 23:20:41
Done.
| |
| 95 | |
| 96 virtual void ItemAdded(const std::string& name, | |
| 97 const base::PlatformFileInfo& info) OVERRIDE { | |
| 98 items_.push_back(name); | |
| 99 } | |
| 100 | |
| 101 virtual void NoMoreItems() OVERRIDE { | |
| 102 completed_ = true; | |
| 103 } | |
| 104 | |
| 105 virtual void DownloadedFile(const std::string& name, | |
| 106 base::PlatformFileError error) OVERRIDE { | |
| 107 downloads_.push_back(name); | |
| 108 } | |
| 109 | |
| 110 virtual void DeviceRemoved() OVERRIDE { | |
| 111 removed_ = true; | |
| 112 } | |
| 113 | |
| 114 std::vector<std::string> items_; | |
|
sail
2012/12/17 03:16:03
private and add accessors as needed
Greg Billock
2012/12/17 23:20:41
I think that just adds noise to test-only objects.
sail
2012/12/17 23:55:03
I've never seen a test do that. Only structs have
Greg Billock
2012/12/19 00:05:09
ok, sure.
On 2012/12/17 23:55:03, sail wrote:
| |
| 115 std::vector<std::string> downloads_; | |
| 116 bool completed_; | |
| 117 bool removed_; | |
| 118 }; | |
| 119 | |
| 120 class ImageCaptureDeviceBrowserTest : public testing::Test { | |
| 121 public: | |
| 122 virtual void SetUp() OVERRIDE { | |
| 123 base::SystemMonitor::AllocateSystemIOPorts(); | |
| 124 system_monitor_.reset(new base::SystemMonitor()); | |
| 125 } | |
| 126 | |
| 127 void AttachDevice(chrome::ImageCaptureDeviceBrowser* browser) { | |
| 128 ICCameraDevice* device = [MockICCameraDevice alloc]; | |
|
sail
2012/12/17 03:16:03
scoped_nsobject,
[[MockICCameraDevice alloc] init]
Greg Billock
2012/12/17 23:20:41
Yes. Saw this looking through the test as well.
O
| |
| 129 NSObject<ICDeviceBrowserDelegate>* delegate = | |
| 130 base::mac::ObjCCastStrict<NSObject<ICDeviceBrowserDelegate> >( | |
| 131 browser->device_browser_.get()); | |
|
sail
2012/12/17 03:16:03
change to use an accessor, same in DetachDevice
Greg Billock
2012/12/17 23:20:41
Done.
| |
| 132 [delegate deviceBrowser:nil didAddDevice:device moreComing:NO]; | |
| 133 } | |
| 134 | |
| 135 void DetachDevice(chrome::ImageCaptureDeviceBrowser* browser) { | |
| 136 ICCameraDevice* device = [MockICCameraDevice alloc]; | |
| 137 NSObject<ICDeviceBrowserDelegate>* delegate = | |
| 138 base::mac::ObjCCastStrict<NSObject<ICDeviceBrowserDelegate> >( | |
| 139 browser->device_browser_.get()); | |
| 140 [delegate deviceBrowser:nil didRemoveDevice:device moreGoing:NO]; | |
| 141 } | |
| 142 | |
| 143 MessageLoop message_loop_; | |
|
sail
2012/12/17 03:16:03
protected
Greg Billock
2012/12/17 23:20:41
Done.
| |
| 144 scoped_ptr<base::SystemMonitor> system_monitor_; | |
| 145 TestCameraListener listener_; | |
| 146 }; | |
| 147 | |
| 148 TEST_F(ImageCaptureDeviceBrowserTest, TestAttachDetach) { | |
| 149 chrome::ImageCaptureDeviceBrowser browser; | |
| 150 AttachDevice(&browser); | |
| 151 | |
| 152 std::vector<base::SystemMonitor::RemovableStorageInfo> devices = | |
| 153 system_monitor_->GetAttachedRemovableStorage(); | |
| 154 | |
| 155 ASSERT_EQ(1U, devices.size()); | |
| 156 EXPECT_EQ("ic:id", devices[0].device_id); | |
|
sail
2012/12/17 03:16:03
use a constant for "id"?
Greg Billock
2012/12/17 23:20:41
Done.
| |
| 157 | |
| 158 DetachDevice(&browser); | |
| 159 devices = system_monitor_->GetAttachedRemovableStorage(); | |
| 160 ASSERT_EQ(0U, devices.size()); | |
| 161 }; | |
| 162 | |
| 163 TEST_F(ImageCaptureDeviceBrowserTest, OpenCamera) { | |
| 164 chrome::ImageCaptureDeviceBrowser browser; | |
| 165 AttachDevice(&browser); | |
| 166 | |
| 167 EXPECT_FALSE(chrome::ImageCaptureDeviceBrowser::cameraInterfaceForUUID( | |
| 168 "nonexistent")); | |
| 169 | |
| 170 scoped_nsobject<ImageCaptureCameraInterface> camera( | |
| 171 [chrome::ImageCaptureDeviceBrowser::cameraInterfaceForUUID("id") retain]); | |
|
sail
2012/12/17 03:16:03
use a constant for "id"?
Greg Billock
2012/12/17 23:20:41
Done.
| |
| 172 | |
| 173 [camera open]; | |
| 174 [camera setListener:listener_.AsWeakPtr()]; | |
| 175 | |
| 176 scoped_nsobject<MockICCameraFile> picture1( | |
| 177 [[MockICCameraFile alloc] init:@"pic1"]); | |
| 178 [camera cameraDevice:nil didAddItem:picture1]; | |
| 179 scoped_nsobject<MockICCameraFile> picture2( | |
| 180 [[MockICCameraFile alloc] init:@"pic2"]); | |
| 181 [camera cameraDevice:nil didAddItem:picture2]; | |
| 182 ASSERT_EQ(2U, listener_.items_.size()); | |
| 183 EXPECT_EQ("pic1", listener_.items_[0]); | |
| 184 EXPECT_EQ("pic2", listener_.items_[1]); | |
| 185 EXPECT_FALSE(listener_.completed_); | |
| 186 | |
| 187 [camera deviceDidBecomeReadyWithCompleteContentCatalog:nil]; | |
| 188 ASSERT_EQ(2U, listener_.items_.size()); | |
| 189 EXPECT_TRUE(listener_.completed_); | |
| 190 | |
| 191 [camera close]; | |
|
sail
2012/12/17 03:16:03
add a test for DidRemoveDevice?
test that removing
Greg Billock
2012/12/17 23:20:41
Added. I still need a couple more tests for the ca
sail
2012/12/17 23:55:03
I think now would be better.
Greg Billock
2012/12/19 00:05:09
Added. This was pretty low impact. Getting the dow
| |
| 192 } | |
| OLD | NEW |