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

Side by Side Diff: chrome/browser/system_monitor/removable_device_notifications_mac_unittest.mm

Issue 11573048: [Media Galleries] Move RemovableStorageInfo notifications to chrome namespace (part 2) (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Working on windows Created 7 years, 10 months 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 | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 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 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 "chrome/browser/system_monitor/removable_device_notifications_mac.h" 5 #include "chrome/browser/system_monitor/removable_device_notifications_mac.h"
6 6
7 #include "base/file_util.h" 7 #include "base/file_util.h"
8 #include "base/files/scoped_temp_dir.h" 8 #include "base/files/scoped_temp_dir.h"
9 #include "base/mac/foundation_util.h" 9 #include "base/mac/foundation_util.h"
10 #include "base/message_loop.h" 10 #include "base/message_loop.h"
11 #include "base/sys_string_conversions.h" 11 #include "base/sys_string_conversions.h"
12 #include "base/system_monitor/system_monitor.h"
13 #include "base/test/mock_devices_changed_observer.h"
14 #include "base/utf_string_conversions.h" 12 #include "base/utf_string_conversions.h"
15 #include "chrome/browser/system_monitor/media_storage_util.h" 13 #include "chrome/browser/system_monitor/media_storage_util.h"
14 #include "chrome/browser/system_monitor/mock_removable_storage_observer.h"
16 #include "chrome/browser/system_monitor/removable_device_constants.h" 15 #include "chrome/browser/system_monitor/removable_device_constants.h"
17 #include "content/public/test/test_browser_thread.h" 16 #include "content/public/test/test_browser_thread.h"
18 #include "testing/gtest/include/gtest/gtest.h" 17 #include "testing/gtest/include/gtest/gtest.h"
19 18
20 namespace chrome { 19 namespace chrome {
21 20
22 uint64 kTestSize = 1000000ULL; 21 uint64 kTestSize = 1000000ULL;
23 22
24 namespace { 23 namespace {
25 24
(...skipping 26 matching lines...) Expand all
52 } // namespace 51 } // namespace
53 52
54 class RemovableDeviceNotificationsMacTest : public testing::Test { 53 class RemovableDeviceNotificationsMacTest : public testing::Test {
55 public: 54 public:
56 RemovableDeviceNotificationsMacTest() 55 RemovableDeviceNotificationsMacTest()
57 : message_loop_(MessageLoop::TYPE_IO), 56 : message_loop_(MessageLoop::TYPE_IO),
58 file_thread_(content::BrowserThread::FILE, &message_loop_) { 57 file_thread_(content::BrowserThread::FILE, &message_loop_) {
59 } 58 }
60 59
61 virtual void SetUp() OVERRIDE { 60 virtual void SetUp() OVERRIDE {
62 base::SystemMonitor::AllocateSystemIOPorts(); 61 notifications_ = new RemovableDeviceNotificationsMac;
63 system_monitor_.reset(new base::SystemMonitor());
64 62
65 mock_devices_changed_observer_.reset(new base::MockDevicesChangedObserver); 63 mock_storage_observer_.reset(new MockRemovableStorageObserver);
66 system_monitor_->AddDevicesChangedObserver( 64 notifications_->AddObserver(mock_storage_observer_.get());
67 mock_devices_changed_observer_.get());
68 65
69 notifications_ = new RemovableDeviceNotificationsMac;
70 66
71 unique_id_ = "test_id"; 67 unique_id_ = "test_id";
72 display_name_ = ASCIIToUTF16("977 KB Test Display Name"); 68 display_name_ = ASCIIToUTF16("977 KB Test Display Name");
73 mount_point_ = FilePath("/unused_test_directory"); 69 mount_point_ = FilePath("/unused_test_directory");
74 device_id_ = MediaStorageUtil::MakeDeviceId( 70 device_id_ = MediaStorageUtil::MakeDeviceId(
75 MediaStorageUtil::REMOVABLE_MASS_STORAGE_NO_DCIM, unique_id_); 71 MediaStorageUtil::REMOVABLE_MASS_STORAGE_NO_DCIM, unique_id_);
76 disk_info_ = CreateDiskInfoMac(unique_id_, "", 72 disk_info_ = CreateDiskInfoMac(unique_id_, "",
77 ASCIIToUTF16("Test Display Name"), 73 ASCIIToUTF16("Test Display Name"),
78 mount_point_, kTestSize); 74 mount_point_, kTestSize);
79 } 75 }
80 76
81 protected: 77 protected:
82 // The message loop and file thread to run tests on. 78 // The message loop and file thread to run tests on.
83 MessageLoop message_loop_; 79 MessageLoop message_loop_;
84 content::TestBrowserThread file_thread_; 80 content::TestBrowserThread file_thread_;
85 81
86 // SystemMonitor and DevicesChangedObserver to hook together to test. 82 scoped_ptr<MockRemovableStorageObserver> mock_storage_observer_;
87 scoped_ptr<base::SystemMonitor> system_monitor_;
88 scoped_ptr<base::MockDevicesChangedObserver> mock_devices_changed_observer_;
89 83
90 // Information about the disk. 84 // Information about the disk.
91 std::string unique_id_; 85 std::string unique_id_;
92 string16 display_name_; 86 string16 display_name_;
93 FilePath mount_point_; 87 FilePath mount_point_;
94 std::string device_id_; 88 std::string device_id_;
95 DiskInfoMac disk_info_; 89 DiskInfoMac disk_info_;
96 90
97 scoped_refptr<RemovableDeviceNotificationsMac> notifications_; 91 scoped_refptr<RemovableDeviceNotificationsMac> notifications_;
98 }; 92 };
99 93
100 TEST_F(RemovableDeviceNotificationsMacTest, AddRemove) { 94 TEST_F(RemovableDeviceNotificationsMacTest, AddRemove) {
101 { 95 notifications_->UpdateDisk(
102 EXPECT_CALL(*mock_devices_changed_observer_, 96 disk_info_, RemovableDeviceNotificationsMac::UPDATE_DEVICE_ADDED);
103 OnRemovableStorageAttached(device_id_, 97 message_loop_.RunUntilIdle();
104 display_name_, 98 EXPECT_EQ(1, mock_storage_observer_->attach_calls());
105 mount_point_.value())); 99 EXPECT_EQ(0, mock_storage_observer_->detach_calls());
106 notifications_->UpdateDisk( 100 EXPECT_EQ(device_id_, mock_storage_observer_->last_attached().device_id);
107 disk_info_, RemovableDeviceNotificationsMac::UPDATE_DEVICE_ADDED); 101 EXPECT_EQ(display_name_, mock_storage_observer_->last_attached().name);
108 message_loop_.RunUntilIdle(); 102 EXPECT_EQ(mount_point_.value(),
109 } 103 mock_storage_observer_->last_attached().location);
110 104
111 { 105 notifications_->UpdateDisk(
112 EXPECT_CALL(*mock_devices_changed_observer_, 106 disk_info_, RemovableDeviceNotificationsMac::UPDATE_DEVICE_REMOVED);
113 OnRemovableStorageDetached(device_id_)); 107 message_loop_.RunUntilIdle();
114 notifications_->UpdateDisk( 108 EXPECT_EQ(1, mock_storage_observer_->attach_calls());
115 disk_info_, RemovableDeviceNotificationsMac::UPDATE_DEVICE_REMOVED); 109 EXPECT_EQ(1, mock_storage_observer_->detach_calls());
116 message_loop_.RunUntilIdle(); 110 EXPECT_EQ(device_id_, mock_storage_observer_->last_detached().device_id);
117 }
118 } 111 }
119 112
120 TEST_F(RemovableDeviceNotificationsMacTest, UpdateVolumeName) { 113 TEST_F(RemovableDeviceNotificationsMacTest, UpdateVolumeName) {
121 { 114 notifications_->UpdateDisk(
122 EXPECT_CALL(*mock_devices_changed_observer_, 115 disk_info_, RemovableDeviceNotificationsMac::UPDATE_DEVICE_ADDED);
123 OnRemovableStorageAttached(device_id_, 116 message_loop_.RunUntilIdle();
124 display_name_,
125 mount_point_.value()));
126 notifications_->UpdateDisk(
127 disk_info_, RemovableDeviceNotificationsMac::UPDATE_DEVICE_ADDED);
128 message_loop_.RunUntilIdle();
129 }
130 117
131 { 118 EXPECT_EQ(1, mock_storage_observer_->attach_calls());
132 string16 new_display_name(ASCIIToUTF16("977 KB Test Display Name")); 119 EXPECT_EQ(0, mock_storage_observer_->detach_calls());
133 DiskInfoMac info2 = CreateDiskInfoMac( 120 EXPECT_EQ(device_id_, mock_storage_observer_->last_attached().device_id);
134 unique_id_, "", ASCIIToUTF16("Test Display Name"), mount_point_, 121 EXPECT_EQ(display_name_, mock_storage_observer_->last_attached().name);
135 kTestSize); 122 EXPECT_EQ(mount_point_.value(),
136 EXPECT_CALL(*mock_devices_changed_observer_, 123 mock_storage_observer_->last_attached().location);
137 OnRemovableStorageDetached(device_id_)); 124
138 EXPECT_CALL(*mock_devices_changed_observer_, 125 string16 new_display_name(ASCIIToUTF16("977 KB Test Display Name"));
139 OnRemovableStorageAttached(device_id_, 126 DiskInfoMac info2 = CreateDiskInfoMac(
140 new_display_name, 127 unique_id_, "", ASCIIToUTF16("Test Display Name"), mount_point_,
141 mount_point_.value())); 128 kTestSize);
142 notifications_->UpdateDisk( 129 notifications_->UpdateDisk(
143 info2, RemovableDeviceNotificationsMac::UPDATE_DEVICE_CHANGED); 130 info2, RemovableDeviceNotificationsMac::UPDATE_DEVICE_CHANGED);
144 message_loop_.RunUntilIdle(); 131 message_loop_.RunUntilIdle();
145 } 132
133 EXPECT_EQ(1, mock_storage_observer_->detach_calls());
134 EXPECT_EQ(device_id_, mock_storage_observer_->last_detached().device_id);
135 EXPECT_EQ(2, mock_storage_observer_->attach_calls());
136 EXPECT_EQ(device_id_, mock_storage_observer_->last_attached().device_id);
137 EXPECT_EQ(new_display_name, mock_storage_observer_->last_attached().name);
138 EXPECT_EQ(mount_point_.value(),
139 mock_storage_observer_->last_attached().location);
146 } 140 }
147 141
148 TEST_F(RemovableDeviceNotificationsMacTest, DCIM) { 142 TEST_F(RemovableDeviceNotificationsMacTest, DCIM) {
149 base::ScopedTempDir temp_dir; 143 base::ScopedTempDir temp_dir;
150 ASSERT_TRUE(temp_dir.CreateUniqueTempDir()); 144 ASSERT_TRUE(temp_dir.CreateUniqueTempDir());
151 file_util::CreateDirectory(temp_dir.path().Append(kDCIMDirectoryName)); 145 ASSERT_TRUE(file_util::CreateDirectory(
146 temp_dir.path().Append(kDCIMDirectoryName)));
152 147
153 FilePath mount_point = temp_dir.path(); 148 FilePath mount_point = temp_dir.path();
154 DiskInfoMac info = CreateDiskInfoMac( 149 DiskInfoMac info = CreateDiskInfoMac(
155 unique_id_, "", ASCIIToUTF16("Test Display Name"), mount_point, 150 unique_id_, "", ASCIIToUTF16("Test Display Name"), mount_point,
156 kTestSize); 151 kTestSize);
157 std::string device_id = MediaStorageUtil::MakeDeviceId( 152 std::string device_id = MediaStorageUtil::MakeDeviceId(
158 MediaStorageUtil::REMOVABLE_MASS_STORAGE_WITH_DCIM, unique_id_); 153 MediaStorageUtil::REMOVABLE_MASS_STORAGE_WITH_DCIM, unique_id_);
159 154
160 { 155 notifications_->UpdateDisk(
161 EXPECT_CALL(*mock_devices_changed_observer_, 156 info, RemovableDeviceNotificationsMac::UPDATE_DEVICE_ADDED);
162 OnRemovableStorageAttached(device_id, 157 message_loop_.RunUntilIdle();
163 display_name_, 158
164 mount_point.value())); 159 EXPECT_EQ(1, mock_storage_observer_->attach_calls());
165 notifications_->UpdateDisk( 160 EXPECT_EQ(0, mock_storage_observer_->detach_calls());
166 info, RemovableDeviceNotificationsMac::UPDATE_DEVICE_ADDED); 161 EXPECT_EQ(device_id, mock_storage_observer_->last_attached().device_id);
167 message_loop_.RunUntilIdle(); 162 EXPECT_EQ(display_name_, mock_storage_observer_->last_attached().name);
168 } 163 EXPECT_EQ(mount_point.value(),
164 mock_storage_observer_->last_attached().location);
169 } 165 }
170 166
171 TEST_F(RemovableDeviceNotificationsMacTest, GetDeviceInfo) { 167 TEST_F(RemovableDeviceNotificationsMacTest, GetDeviceInfo) {
172 { 168 notifications_->UpdateDisk(
173 EXPECT_CALL(*mock_devices_changed_observer_, 169 disk_info_, RemovableDeviceNotificationsMac::UPDATE_DEVICE_ADDED);
174 OnRemovableStorageAttached(device_id_, 170 message_loop_.RunUntilIdle();
175 display_name_,
176 mount_point_.value()));
177 notifications_->UpdateDisk(
178 disk_info_, RemovableDeviceNotificationsMac::UPDATE_DEVICE_ADDED);
179 message_loop_.RunUntilIdle();
180 }
181 171
182 base::SystemMonitor::RemovableStorageInfo info; 172 EXPECT_EQ(1, mock_storage_observer_->attach_calls());
173 EXPECT_EQ(0, mock_storage_observer_->detach_calls());
174 EXPECT_EQ(device_id_, mock_storage_observer_->last_attached().device_id);
175 EXPECT_EQ(display_name_, mock_storage_observer_->last_attached().name);
176 EXPECT_EQ(mount_point_.value(),
177 mock_storage_observer_->last_attached().location);
178
179 RemovableStorageNotifications::StorageInfo info;
183 EXPECT_TRUE(notifications_->GetDeviceInfoForPath( 180 EXPECT_TRUE(notifications_->GetDeviceInfoForPath(
184 mount_point_.AppendASCII("foo"), &info)); 181 mount_point_.AppendASCII("foo"), &info));
185 EXPECT_EQ(info.device_id, device_id_); 182 EXPECT_EQ(info.device_id, device_id_);
186 EXPECT_EQ(info.name, ASCIIToUTF16("Test Display Name")); 183 EXPECT_EQ(info.name, ASCIIToUTF16("Test Display Name"));
187 EXPECT_EQ(info.location, mount_point_.value()); 184 EXPECT_EQ(info.location, mount_point_.value());
188 185
189 EXPECT_FALSE(notifications_->GetDeviceInfoForPath( 186 EXPECT_FALSE(notifications_->GetDeviceInfoForPath(
190 FilePath("/non/matching/path"), &info)); 187 FilePath("/non/matching/path"), &info));
191 } 188 }
192 189
193 TEST_F(RemovableDeviceNotificationsMacTest, GetStorageSize) { 190 TEST_F(RemovableDeviceNotificationsMacTest, GetStorageSize) {
194 EXPECT_CALL(*mock_devices_changed_observer_,
195 OnRemovableStorageAttached(testing::_,
196 testing::_,
197 testing::_));
198 notifications_->UpdateDisk( 191 notifications_->UpdateDisk(
199 disk_info_, RemovableDeviceNotificationsMac::UPDATE_DEVICE_ADDED); 192 disk_info_, RemovableDeviceNotificationsMac::UPDATE_DEVICE_ADDED);
200 message_loop_.RunUntilIdle(); 193 message_loop_.RunUntilIdle();
194 EXPECT_EQ(1, mock_storage_observer_->attach_calls());
201 195
202 EXPECT_EQ(kTestSize, 196 EXPECT_EQ(kTestSize,
203 notifications_->GetStorageSize("/unused_test_directory")); 197 notifications_->GetStorageSize("/unused_test_directory"));
204 } 198 }
205 199
206 // Test that mounting a DMG doesn't send a notification. 200 // Test that mounting a DMG doesn't send a notification.
207 TEST_F(RemovableDeviceNotificationsMacTest, DMG) { 201 TEST_F(RemovableDeviceNotificationsMacTest, DMG) {
208 EXPECT_CALL(*mock_devices_changed_observer_,
209 OnRemovableStorageAttached(testing::_,
210 testing::_,
211 testing::_)).Times(0);
212 DiskInfoMac info = CreateDiskInfoMac( 202 DiskInfoMac info = CreateDiskInfoMac(
213 unique_id_, "Disk Image", display_name_, mount_point_, kTestSize); 203 unique_id_, "Disk Image", display_name_, mount_point_, kTestSize);
214 notifications_->UpdateDisk( 204 notifications_->UpdateDisk(
215 info, RemovableDeviceNotificationsMac::UPDATE_DEVICE_ADDED); 205 info, RemovableDeviceNotificationsMac::UPDATE_DEVICE_ADDED);
216 message_loop_.RunUntilIdle(); 206 message_loop_.RunUntilIdle();
207 EXPECT_EQ(0, mock_storage_observer_->attach_calls());
217 } 208 }
218 209
219 } // namespace chrome 210 } // namespace chrome
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698