Chromium Code Reviews| OLD | NEW |
|---|---|
| 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 // RemovableDeviceNotificationsLinux unit tests. | 5 // RemovableDeviceNotificationsLinux unit tests. |
| 6 | 6 |
| 7 #include "chrome/browser/system_monitor/removable_device_notifications_linux.h" | 7 #include "chrome/browser/system_monitor/removable_device_notifications_linux.h" |
| 8 | 8 |
| 9 #include <mntent.h> | 9 #include <mntent.h> |
| 10 #include <stdio.h> | 10 #include <stdio.h> |
| 11 | 11 |
| 12 #include <string> | 12 #include <string> |
| 13 | 13 |
| 14 #include "base/file_util.h" | 14 #include "base/file_util.h" |
| 15 #include "base/files/scoped_temp_dir.h" | 15 #include "base/files/scoped_temp_dir.h" |
| 16 #include "base/logging.h" | 16 #include "base/logging.h" |
| 17 #include "base/memory/scoped_ptr.h" | 17 #include "base/memory/scoped_ptr.h" |
| 18 #include "base/message_loop.h" | 18 #include "base/message_loop.h" |
| 19 #include "base/system_monitor/system_monitor.h" | |
| 20 #include "base/test/mock_devices_changed_observer.h" | |
| 21 #include "base/utf_string_conversions.h" | 19 #include "base/utf_string_conversions.h" |
| 22 #include "chrome/browser/system_monitor/media_device_notifications_utils.h" | 20 #include "chrome/browser/system_monitor/media_device_notifications_utils.h" |
| 23 #include "chrome/browser/system_monitor/media_storage_util.h" | 21 #include "chrome/browser/system_monitor/media_storage_util.h" |
| 22 #include "chrome/browser/system_monitor/mock_removable_storage_observer.h" | |
| 24 #include "chrome/browser/system_monitor/removable_device_constants.h" | 23 #include "chrome/browser/system_monitor/removable_device_constants.h" |
| 24 #include "chrome/browser/system_monitor/removable_storage_notifications.h" | |
| 25 #include "content/public/test/test_browser_thread.h" | 25 #include "content/public/test/test_browser_thread.h" |
| 26 #include "testing/gtest/include/gtest/gtest.h" | 26 #include "testing/gtest/include/gtest/gtest.h" |
| 27 | 27 |
| 28 namespace chrome { | 28 namespace chrome { |
| 29 | 29 |
| 30 namespace { | 30 namespace { |
| 31 | 31 |
| 32 using testing::_; | |
| 33 | |
| 34 const char kValidFS[] = "vfat"; | 32 const char kValidFS[] = "vfat"; |
| 35 const char kInvalidFS[] = "invalidfs"; | 33 const char kInvalidFS[] = "invalidfs"; |
| 36 | 34 |
| 37 const char kInvalidPath[] = "invalid path does not exist"; | 35 const char kInvalidPath[] = "invalid path does not exist"; |
| 38 | 36 |
| 39 const char kDeviceDCIM1[] = "d1"; | 37 const char kDeviceDCIM1[] = "d1"; |
| 40 const char kDeviceDCIM2[] = "d2"; | 38 const char kDeviceDCIM2[] = "d2"; |
| 41 const char kDeviceDCIM3[] = "d3"; | 39 const char kDeviceDCIM3[] = "d3"; |
| 42 const char kDeviceNoDCIM[] = "d4"; | 40 const char kDeviceNoDCIM[] = "d4"; |
| 43 const char kDeviceFixed[] = "d5"; | 41 const char kDeviceFixed[] = "d5"; |
| (...skipping 134 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 178 }; | 176 }; |
| 179 | 177 |
| 180 RemovableDeviceNotificationLinuxTest() | 178 RemovableDeviceNotificationLinuxTest() |
| 181 : message_loop_(MessageLoop::TYPE_IO), | 179 : message_loop_(MessageLoop::TYPE_IO), |
| 182 file_thread_(content::BrowserThread::FILE, &message_loop_) { | 180 file_thread_(content::BrowserThread::FILE, &message_loop_) { |
| 183 } | 181 } |
| 184 virtual ~RemovableDeviceNotificationLinuxTest() {} | 182 virtual ~RemovableDeviceNotificationLinuxTest() {} |
| 185 | 183 |
| 186 protected: | 184 protected: |
| 187 virtual void SetUp() OVERRIDE { | 185 virtual void SetUp() OVERRIDE { |
| 188 mock_devices_changed_observer_.reset(new base::MockDevicesChangedObserver); | |
| 189 system_monitor_.AddDevicesChangedObserver( | |
| 190 mock_devices_changed_observer_.get()); | |
| 191 | |
| 192 // Create and set up a temp dir with files for the test. | 186 // Create and set up a temp dir with files for the test. |
| 193 ASSERT_TRUE(scoped_temp_dir_.CreateUniqueTempDir()); | 187 ASSERT_TRUE(scoped_temp_dir_.CreateUniqueTempDir()); |
| 194 FilePath test_dir = scoped_temp_dir_.path().AppendASCII("test_etc"); | 188 FilePath test_dir = scoped_temp_dir_.path().AppendASCII("test_etc"); |
| 195 ASSERT_TRUE(file_util::CreateDirectory(test_dir)); | 189 ASSERT_TRUE(file_util::CreateDirectory(test_dir)); |
| 196 mtab_file_ = test_dir.AppendASCII("test_mtab"); | 190 mtab_file_ = test_dir.AppendASCII("test_mtab"); |
| 197 MtabTestData initial_test_data[] = { | 191 MtabTestData initial_test_data[] = { |
| 198 MtabTestData("dummydevice", "dummydir", kInvalidFS), | 192 MtabTestData("dummydevice", "dummydir", kInvalidFS), |
| 199 }; | 193 }; |
| 200 WriteToMtab(initial_test_data, | 194 WriteToMtab(initial_test_data, |
| 201 arraysize(initial_test_data), | 195 arraysize(initial_test_data), |
| 202 true /* overwrite */); | 196 true /* overwrite */); |
| 203 | 197 |
| 204 // Initialize the test subject. | 198 // Initialize the test subject. |
| 205 notifications_ = new RemovableDeviceNotificationsLinuxTestWrapper( | 199 notifications_ = new RemovableDeviceNotificationsLinuxTestWrapper( |
| 206 mtab_file_, &message_loop_); | 200 mtab_file_, &message_loop_); |
| 207 notifications_->Init(); | 201 notifications_->Init(); |
| 208 message_loop_.RunUntilIdle(); | 202 message_loop_.RunUntilIdle(); |
| 203 | |
| 204 mock_storage_observer_.reset(new MockRemovableStorageObserver); | |
|
vandebo (ex-Chrome)
2013/01/24 19:19:10
move the observer to line 201 so it will get notif
Greg Billock
2013/01/24 20:46:03
Those vary by test, so I think adding if after mak
vandebo (ex-Chrome)
2013/01/24 23:39:01
Previously it was set before and the tests worked
Greg Billock
2013/01/25 20:01:21
Done. I was thinking I'd have to change a lot of t
| |
| 205 notifications_->AddObserver(mock_storage_observer_.get()); | |
| 209 } | 206 } |
| 210 | 207 |
| 211 virtual void TearDown() OVERRIDE { | 208 virtual void TearDown() OVERRIDE { |
| 212 message_loop_.RunUntilIdle(); | 209 message_loop_.RunUntilIdle(); |
| 210 notifications_->RemoveObserver(mock_storage_observer_.get()); | |
| 213 notifications_ = NULL; | 211 notifications_ = NULL; |
| 214 system_monitor_.RemoveDevicesChangedObserver( | |
| 215 mock_devices_changed_observer_.get()); | |
| 216 } | 212 } |
| 217 | 213 |
| 218 // Append mtab entries from the |data| array of size |data_size| to the mtab | 214 // Append mtab entries from the |data| array of size |data_size| to the mtab |
| 219 // file, and run the message loop. | 215 // file, and run the message loop. |
| 220 void AppendToMtabAndRunLoop(const MtabTestData* data, size_t data_size) { | 216 void AppendToMtabAndRunLoop(const MtabTestData* data, size_t data_size) { |
| 221 WriteToMtab(data, data_size, false /* do not overwrite */); | 217 WriteToMtab(data, data_size, false /* do not overwrite */); |
| 222 message_loop_.Run(); | 218 message_loop_.Run(); |
| 223 } | 219 } |
| 224 | 220 |
| 225 // Overwrite the mtab file with mtab entries from the |data| array of size | 221 // Overwrite the mtab file with mtab entries from the |data| array of size |
| (...skipping 23 matching lines...) Expand all Loading... | |
| 249 FilePath CreateMountPointWithoutDCIMDir(const std::string& dir) { | 245 FilePath CreateMountPointWithoutDCIMDir(const std::string& dir) { |
| 250 return CreateMountPoint(dir, false /* do not create DCIM dir */); | 246 return CreateMountPoint(dir, false /* do not create DCIM dir */); |
| 251 } | 247 } |
| 252 | 248 |
| 253 void RemoveDCIMDirFromMountPoint(const std::string& dir) { | 249 void RemoveDCIMDirFromMountPoint(const std::string& dir) { |
| 254 FilePath dcim = | 250 FilePath dcim = |
| 255 scoped_temp_dir_.path().AppendASCII(dir).Append(kDCIMDirectoryName); | 251 scoped_temp_dir_.path().AppendASCII(dir).Append(kDCIMDirectoryName); |
| 256 file_util::Delete(dcim, false); | 252 file_util::Delete(dcim, false); |
| 257 } | 253 } |
| 258 | 254 |
| 259 base::MockDevicesChangedObserver& observer() { | 255 MockRemovableStorageObserver& observer() { |
| 260 return *mock_devices_changed_observer_; | 256 return *mock_storage_observer_; |
| 261 } | 257 } |
| 262 | 258 |
| 263 RemovableDeviceNotificationsLinux* notifier() { | 259 RemovableDeviceNotificationsLinux* notifier() { |
| 264 return notifications_.get(); | 260 return notifications_.get(); |
| 265 } | 261 } |
| 266 | 262 |
| 267 private: | 263 private: |
| 268 // Create a directory named |dir| relative to the test directory. | 264 // Create a directory named |dir| relative to the test directory. |
| 269 // Set |with_dcim_dir| to true if the created directory will have a "DCIM" | 265 // Set |with_dcim_dir| to true if the created directory will have a "DCIM" |
| 270 // subdirectory. | 266 // subdirectory. |
| (...skipping 40 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 311 entry.mnt_type = const_cast<char*>(data[i].mount_type.c_str()); | 307 entry.mnt_type = const_cast<char*>(data[i].mount_type.c_str()); |
| 312 ASSERT_EQ(0, addmntent(file, &entry)); | 308 ASSERT_EQ(0, addmntent(file, &entry)); |
| 313 } | 309 } |
| 314 ASSERT_EQ(1, endmntent(file)); | 310 ASSERT_EQ(1, endmntent(file)); |
| 315 } | 311 } |
| 316 | 312 |
| 317 // The message loop and file thread to run tests on. | 313 // The message loop and file thread to run tests on. |
| 318 MessageLoop message_loop_; | 314 MessageLoop message_loop_; |
| 319 content::TestBrowserThread file_thread_; | 315 content::TestBrowserThread file_thread_; |
| 320 | 316 |
| 321 // SystemMonitor and DevicesChangedObserver to hook together to test. | 317 scoped_ptr<MockRemovableStorageObserver> mock_storage_observer_; |
| 322 base::SystemMonitor system_monitor_; | |
| 323 scoped_ptr<base::MockDevicesChangedObserver> mock_devices_changed_observer_; | |
| 324 | 318 |
| 325 // Temporary directory for created test data. | 319 // Temporary directory for created test data. |
| 326 base::ScopedTempDir scoped_temp_dir_; | 320 base::ScopedTempDir scoped_temp_dir_; |
| 327 // Path to the test mtab file. | 321 // Path to the test mtab file. |
| 328 FilePath mtab_file_; | 322 FilePath mtab_file_; |
| 329 | 323 |
| 330 scoped_refptr<RemovableDeviceNotificationsLinuxTestWrapper> notifications_; | 324 scoped_refptr<RemovableDeviceNotificationsLinuxTestWrapper> notifications_; |
| 331 | 325 |
| 332 DISALLOW_COPY_AND_ASSIGN(RemovableDeviceNotificationLinuxTest); | 326 DISALLOW_COPY_AND_ASSIGN(RemovableDeviceNotificationLinuxTest); |
| 333 }; | 327 }; |
| 334 | 328 |
| 335 // Simple test case where we attach and detach a media device. | 329 // Simple test case where we attach and detach a media device. |
| 336 TEST_F(RemovableDeviceNotificationLinuxTest, BasicAttachDetach) { | 330 TEST_F(RemovableDeviceNotificationLinuxTest, BasicAttachDetach) { |
| 337 testing::Sequence mock_sequence; | |
| 338 FilePath test_path = CreateMountPointWithDCIMDir(kMountPointA); | 331 FilePath test_path = CreateMountPointWithDCIMDir(kMountPointA); |
| 339 ASSERT_FALSE(test_path.empty()); | 332 ASSERT_FALSE(test_path.empty()); |
| 340 MtabTestData test_data[] = { | 333 MtabTestData test_data[] = { |
| 341 MtabTestData(kDeviceDCIM2, test_path.value(), kValidFS), | 334 MtabTestData(kDeviceDCIM2, test_path.value(), kValidFS), |
| 342 MtabTestData(kDeviceFixed, kInvalidPath, kValidFS), | 335 MtabTestData(kDeviceFixed, kInvalidPath, kValidFS), |
| 343 }; | 336 }; |
| 344 // Only |kDeviceDCIM2| should be attached, since |kDeviceFixed| has a bad | 337 // Only |kDeviceDCIM2| should be attached, since |kDeviceFixed| has a bad |
| 345 // path. | 338 // path. |
| 346 EXPECT_CALL(observer(), | |
| 347 OnRemovableStorageAttached( | |
| 348 GetDeviceId(kDeviceDCIM2), | |
| 349 GetDeviceNameWithSizeDetails(kDeviceDCIM2), | |
| 350 test_path.value())) | |
| 351 .InSequence(mock_sequence); | |
| 352 AppendToMtabAndRunLoop(test_data, arraysize(test_data)); | 339 AppendToMtabAndRunLoop(test_data, arraysize(test_data)); |
| 353 | 340 |
| 341 EXPECT_EQ(1, observer().attach_calls()); | |
|
vandebo (ex-Chrome)
2013/01/24 19:19:10
nit: detach count
Greg Billock
2013/01/24 20:46:03
Done.
| |
| 342 EXPECT_EQ(GetDeviceId(kDeviceDCIM2), observer().last_attached().device_id); | |
| 343 EXPECT_EQ(GetDeviceNameWithSizeDetails(kDeviceDCIM2), | |
| 344 observer().last_attached().name); | |
| 345 EXPECT_EQ(test_path.value(), | |
| 346 observer().last_attached().location); | |
| 347 | |
| 354 // |kDeviceDCIM2| should be detached here. | 348 // |kDeviceDCIM2| should be detached here. |
| 355 EXPECT_CALL(observer(), OnRemovableStorageDetached(GetDeviceId(kDeviceDCIM2))) | |
| 356 .InSequence(mock_sequence); | |
| 357 WriteEmptyMtabAndRunLoop(); | 349 WriteEmptyMtabAndRunLoop(); |
| 350 EXPECT_EQ(1, observer().detach_calls()); | |
|
vandebo (ex-Chrome)
2013/01/24 19:19:10
nit: attach count
Greg Billock
2013/01/24 20:46:03
Done.
| |
| 351 EXPECT_EQ(GetDeviceId(kDeviceDCIM2), observer().last_detached().device_id); | |
| 358 } | 352 } |
| 359 | 353 |
| 360 // Only removable devices are recognized. | 354 // Only removable devices are recognized. |
| 361 TEST_F(RemovableDeviceNotificationLinuxTest, Removable) { | 355 TEST_F(RemovableDeviceNotificationLinuxTest, Removable) { |
| 362 testing::Sequence mock_sequence; | |
| 363 FilePath test_path_a = CreateMountPointWithDCIMDir(kMountPointA); | 356 FilePath test_path_a = CreateMountPointWithDCIMDir(kMountPointA); |
| 364 ASSERT_FALSE(test_path_a.empty()); | 357 ASSERT_FALSE(test_path_a.empty()); |
| 365 MtabTestData test_data1[] = { | 358 MtabTestData test_data1[] = { |
| 366 MtabTestData(kDeviceDCIM1, test_path_a.value(), kValidFS), | 359 MtabTestData(kDeviceDCIM1, test_path_a.value(), kValidFS), |
| 367 }; | 360 }; |
| 368 // |kDeviceDCIM1| should be attached as expected. | 361 // |kDeviceDCIM1| should be attached as expected. |
| 369 EXPECT_CALL(observer(), | |
| 370 OnRemovableStorageAttached( | |
| 371 GetDeviceId(kDeviceDCIM1), | |
| 372 GetDeviceNameWithSizeDetails(kDeviceDCIM1), | |
| 373 test_path_a.value())) | |
| 374 .InSequence(mock_sequence); | |
| 375 AppendToMtabAndRunLoop(test_data1, arraysize(test_data1)); | 362 AppendToMtabAndRunLoop(test_data1, arraysize(test_data1)); |
| 376 | 363 |
| 364 EXPECT_EQ(1, observer().attach_calls()); | |
| 365 EXPECT_EQ(GetDeviceId(kDeviceDCIM1), observer().last_attached().device_id); | |
| 366 EXPECT_EQ(GetDeviceNameWithSizeDetails(kDeviceDCIM1), | |
| 367 observer().last_attached().name); | |
| 368 EXPECT_EQ(test_path_a.value(), | |
| 369 observer().last_attached().location); | |
| 370 | |
| 377 // This should do nothing, since |kDeviceFixed| is not removable. | 371 // This should do nothing, since |kDeviceFixed| is not removable. |
| 378 FilePath test_path_b = CreateMountPointWithoutDCIMDir(kMountPointB); | 372 FilePath test_path_b = CreateMountPointWithoutDCIMDir(kMountPointB); |
| 379 ASSERT_FALSE(test_path_b.empty()); | 373 ASSERT_FALSE(test_path_b.empty()); |
| 380 MtabTestData test_data2[] = { | 374 MtabTestData test_data2[] = { |
| 381 MtabTestData(kDeviceFixed, test_path_b.value(), kValidFS), | 375 MtabTestData(kDeviceFixed, test_path_b.value(), kValidFS), |
| 382 }; | 376 }; |
| 383 AppendToMtabAndRunLoop(test_data2, arraysize(test_data2)); | 377 AppendToMtabAndRunLoop(test_data2, arraysize(test_data2)); |
| 378 EXPECT_EQ(1, observer().attach_calls()); | |
|
vandebo (ex-Chrome)
2013/01/24 19:19:10
nit: detach count
Greg Billock
2013/01/24 20:46:03
Done.
| |
| 384 | 379 |
| 385 // |kDeviceDCIM1| should be detached as expected. | 380 // |kDeviceDCIM1| should be detached as expected. |
| 386 EXPECT_CALL(observer(), OnRemovableStorageDetached(GetDeviceId(kDeviceDCIM1))) | |
| 387 .InSequence(mock_sequence); | |
| 388 WriteEmptyMtabAndRunLoop(); | 381 WriteEmptyMtabAndRunLoop(); |
| 382 EXPECT_EQ(1, observer().detach_calls()); | |
|
vandebo (ex-Chrome)
2013/01/24 19:19:10
nit: attach count
Greg Billock
2013/01/24 20:46:03
Done.
| |
| 383 EXPECT_EQ(GetDeviceId(kDeviceDCIM1), observer().last_detached().device_id); | |
| 389 | 384 |
| 390 // |kDeviceNoDCIM| should be attached as expected. | 385 // |kDeviceNoDCIM| should be attached as expected. |
| 391 EXPECT_CALL(observer(), | |
| 392 OnRemovableStorageAttached( | |
| 393 GetDeviceId(kDeviceNoDCIM), | |
| 394 GetDeviceNameWithSizeDetails(kDeviceNoDCIM), | |
| 395 test_path_b.value())) | |
| 396 .InSequence(mock_sequence); | |
| 397 MtabTestData test_data3[] = { | 386 MtabTestData test_data3[] = { |
| 398 MtabTestData(kDeviceNoDCIM, test_path_b.value(), kValidFS), | 387 MtabTestData(kDeviceNoDCIM, test_path_b.value(), kValidFS), |
| 399 }; | 388 }; |
| 400 AppendToMtabAndRunLoop(test_data3, arraysize(test_data3)); | 389 AppendToMtabAndRunLoop(test_data3, arraysize(test_data3)); |
| 390 EXPECT_EQ(2, observer().attach_calls()); | |
|
vandebo (ex-Chrome)
2013/01/24 19:19:10
nit: detach count
Greg Billock
2013/01/24 20:46:03
Done.
| |
| 391 EXPECT_EQ(GetDeviceId(kDeviceNoDCIM), observer().last_attached().device_id); | |
| 392 EXPECT_EQ(GetDeviceNameWithSizeDetails(kDeviceNoDCIM), | |
| 393 observer().last_attached().name); | |
| 394 EXPECT_EQ(test_path_b.value(), | |
| 395 observer().last_attached().location); | |
| 401 | 396 |
| 402 // |kDeviceNoDCIM| should be detached as expected. | 397 // |kDeviceNoDCIM| should be detached as expected. |
| 403 EXPECT_CALL(observer(), | |
| 404 OnRemovableStorageDetached(GetDeviceId(kDeviceNoDCIM))) | |
| 405 .InSequence(mock_sequence); | |
| 406 WriteEmptyMtabAndRunLoop(); | 398 WriteEmptyMtabAndRunLoop(); |
| 399 EXPECT_EQ(2, observer().detach_calls()); | |
|
vandebo (ex-Chrome)
2013/01/24 19:19:10
nit: attach count
Greg Billock
2013/01/24 20:46:03
Done.
| |
| 400 EXPECT_EQ(GetDeviceId(kDeviceNoDCIM), observer().last_detached().device_id); | |
| 407 } | 401 } |
| 408 | 402 |
| 409 // More complicated test case with multiple devices on multiple mount points. | 403 // More complicated test case with multiple devices on multiple mount points. |
| 410 TEST_F(RemovableDeviceNotificationLinuxTest, SwapMountPoints) { | 404 TEST_F(RemovableDeviceNotificationLinuxTest, SwapMountPoints) { |
| 411 FilePath test_path_a = CreateMountPointWithDCIMDir(kMountPointA); | 405 FilePath test_path_a = CreateMountPointWithDCIMDir(kMountPointA); |
| 412 FilePath test_path_b = CreateMountPointWithDCIMDir(kMountPointB); | 406 FilePath test_path_b = CreateMountPointWithDCIMDir(kMountPointB); |
| 413 ASSERT_FALSE(test_path_a.empty()); | 407 ASSERT_FALSE(test_path_a.empty()); |
| 414 ASSERT_FALSE(test_path_b.empty()); | 408 ASSERT_FALSE(test_path_b.empty()); |
| 415 | 409 |
| 416 // Attach two devices. (*'d mounts are those SystemMonitor knows about.) | 410 // Attach two devices. |
| 411 // (*'d mounts are those RemovableStorageNotifications knows about.) | |
| 417 // kDeviceDCIM1 -> kMountPointA * | 412 // kDeviceDCIM1 -> kMountPointA * |
| 418 // kDeviceDCIM2 -> kMountPointB * | 413 // kDeviceDCIM2 -> kMountPointB * |
| 419 MtabTestData test_data1[] = { | 414 MtabTestData test_data1[] = { |
| 420 MtabTestData(kDeviceDCIM1, test_path_a.value(), kValidFS), | 415 MtabTestData(kDeviceDCIM1, test_path_a.value(), kValidFS), |
| 421 MtabTestData(kDeviceDCIM2, test_path_b.value(), kValidFS), | 416 MtabTestData(kDeviceDCIM2, test_path_b.value(), kValidFS), |
| 422 }; | 417 }; |
| 423 EXPECT_CALL(observer(), OnRemovableStorageAttached(_, _, _)).Times(2); | |
| 424 EXPECT_CALL(observer(), OnRemovableStorageDetached(_)).Times(0); | |
| 425 AppendToMtabAndRunLoop(test_data1, arraysize(test_data1)); | 418 AppendToMtabAndRunLoop(test_data1, arraysize(test_data1)); |
| 419 EXPECT_EQ(2, observer().attach_calls()); | |
| 420 EXPECT_EQ(0, observer().detach_calls()); | |
| 426 | 421 |
| 427 // Detach two devices from old mount points and attach the devices at new | 422 // Detach two devices from old mount points and attach the devices at new |
| 428 // mount points. | 423 // mount points. |
| 429 // kDeviceDCIM1 -> kMountPointB * | 424 // kDeviceDCIM1 -> kMountPointB * |
| 430 // kDeviceDCIM2 -> kMountPointA * | 425 // kDeviceDCIM2 -> kMountPointA * |
| 431 MtabTestData test_data2[] = { | 426 MtabTestData test_data2[] = { |
| 432 MtabTestData(kDeviceDCIM1, test_path_b.value(), kValidFS), | 427 MtabTestData(kDeviceDCIM1, test_path_b.value(), kValidFS), |
| 433 MtabTestData(kDeviceDCIM2, test_path_a.value(), kValidFS), | 428 MtabTestData(kDeviceDCIM2, test_path_a.value(), kValidFS), |
| 434 }; | 429 }; |
| 435 EXPECT_CALL(observer(), OnRemovableStorageAttached(_, _, _)).Times(2); | |
| 436 EXPECT_CALL(observer(), OnRemovableStorageDetached(_)).Times(2); | |
| 437 OverwriteMtabAndRunLoop(test_data2, arraysize(test_data2)); | 430 OverwriteMtabAndRunLoop(test_data2, arraysize(test_data2)); |
| 431 EXPECT_EQ(4, observer().attach_calls()); | |
| 432 EXPECT_EQ(2, observer().detach_calls()); | |
| 438 | 433 |
| 439 // Detach all devices. | 434 // Detach all devices. |
| 440 EXPECT_CALL(observer(), OnRemovableStorageAttached(_, _, _)).Times(0); | |
| 441 EXPECT_CALL(observer(), OnRemovableStorageDetached(_)).Times(2); | |
| 442 WriteEmptyMtabAndRunLoop(); | 435 WriteEmptyMtabAndRunLoop(); |
| 436 EXPECT_EQ(4, observer().attach_calls()); | |
| 437 EXPECT_EQ(4, observer().detach_calls()); | |
| 443 } | 438 } |
| 444 | 439 |
| 445 // More complicated test case with multiple devices on multiple mount points. | 440 // More complicated test case with multiple devices on multiple mount points. |
| 446 TEST_F(RemovableDeviceNotificationLinuxTest, MultiDevicesMultiMountPoints) { | 441 TEST_F(RemovableDeviceNotificationLinuxTest, MultiDevicesMultiMountPoints) { |
| 447 FilePath test_path_a = CreateMountPointWithDCIMDir(kMountPointA); | 442 FilePath test_path_a = CreateMountPointWithDCIMDir(kMountPointA); |
| 448 FilePath test_path_b = CreateMountPointWithDCIMDir(kMountPointB); | 443 FilePath test_path_b = CreateMountPointWithDCIMDir(kMountPointB); |
| 449 ASSERT_FALSE(test_path_a.empty()); | 444 ASSERT_FALSE(test_path_a.empty()); |
| 450 ASSERT_FALSE(test_path_b.empty()); | 445 ASSERT_FALSE(test_path_b.empty()); |
| 451 | 446 |
| 452 // Attach two devices. (*'d mounts are those SystemMonitor knows about.) | 447 // Attach two devices. |
| 448 // (*'d mounts are those RemovableStorageNotifications knows about.) | |
| 453 // kDeviceDCIM1 -> kMountPointA * | 449 // kDeviceDCIM1 -> kMountPointA * |
| 454 // kDeviceDCIM2 -> kMountPointB * | 450 // kDeviceDCIM2 -> kMountPointB * |
| 455 MtabTestData test_data1[] = { | 451 MtabTestData test_data1[] = { |
| 456 MtabTestData(kDeviceDCIM1, test_path_a.value(), kValidFS), | 452 MtabTestData(kDeviceDCIM1, test_path_a.value(), kValidFS), |
| 457 MtabTestData(kDeviceDCIM2, test_path_b.value(), kValidFS), | 453 MtabTestData(kDeviceDCIM2, test_path_b.value(), kValidFS), |
| 458 }; | 454 }; |
| 459 EXPECT_CALL(observer(), OnRemovableStorageAttached(_, _, _)).Times(2); | |
| 460 EXPECT_CALL(observer(), OnRemovableStorageDetached(_)).Times(0); | |
| 461 AppendToMtabAndRunLoop(test_data1, arraysize(test_data1)); | 455 AppendToMtabAndRunLoop(test_data1, arraysize(test_data1)); |
| 456 EXPECT_EQ(2, observer().attach_calls()); | |
| 457 EXPECT_EQ(0, observer().detach_calls()); | |
| 462 | 458 |
| 463 // Attach |kDeviceDCIM1| to |kMountPointB|. | 459 // Attach |kDeviceDCIM1| to |kMountPointB|. |
| 464 // |kDeviceDCIM2| is inaccessible, so it is detached. |kDeviceDCIM1| has been | 460 // |kDeviceDCIM2| is inaccessible, so it is detached. |kDeviceDCIM1| has been |
| 465 // attached at |kMountPointB|, but is still accessible from |kMountPointA|. | 461 // attached at |kMountPointB|, but is still accessible from |kMountPointA|. |
| 466 // kDeviceDCIM1 -> kMountPointA * | 462 // kDeviceDCIM1 -> kMountPointA * |
| 467 // kDeviceDCIM2 -> kMountPointB | 463 // kDeviceDCIM2 -> kMountPointB |
| 468 // kDeviceDCIM1 -> kMountPointB | 464 // kDeviceDCIM1 -> kMountPointB |
| 469 MtabTestData test_data2[] = { | 465 MtabTestData test_data2[] = { |
| 470 MtabTestData(kDeviceDCIM1, test_path_b.value(), kValidFS), | 466 MtabTestData(kDeviceDCIM1, test_path_b.value(), kValidFS), |
| 471 }; | 467 }; |
| 472 EXPECT_CALL(observer(), OnRemovableStorageAttached(_, _, _)).Times(0); | |
| 473 EXPECT_CALL(observer(), OnRemovableStorageDetached(_)).Times(1); | |
| 474 AppendToMtabAndRunLoop(test_data2, arraysize(test_data2)); | 468 AppendToMtabAndRunLoop(test_data2, arraysize(test_data2)); |
| 469 EXPECT_EQ(2, observer().attach_calls()); | |
| 470 EXPECT_EQ(1, observer().detach_calls()); | |
| 475 | 471 |
| 476 // Detach |kDeviceDCIM1| from |kMountPointA|, causing a detach and attach | 472 // Detach |kDeviceDCIM1| from |kMountPointA|, causing a detach and attach |
| 477 // event. | 473 // event. |
| 478 // kDeviceDCIM2 -> kMountPointB | 474 // kDeviceDCIM2 -> kMountPointB |
| 479 // kDeviceDCIM1 -> kMountPointB * | 475 // kDeviceDCIM1 -> kMountPointB * |
| 480 MtabTestData test_data3[] = { | 476 MtabTestData test_data3[] = { |
| 481 MtabTestData(kDeviceDCIM2, test_path_b.value(), kValidFS), | 477 MtabTestData(kDeviceDCIM2, test_path_b.value(), kValidFS), |
| 482 MtabTestData(kDeviceDCIM1, test_path_b.value(), kValidFS), | 478 MtabTestData(kDeviceDCIM1, test_path_b.value(), kValidFS), |
| 483 }; | 479 }; |
| 484 EXPECT_CALL(observer(), OnRemovableStorageAttached(_, _, _)).Times(1); | |
| 485 EXPECT_CALL(observer(), OnRemovableStorageDetached(_)).Times(1); | |
| 486 OverwriteMtabAndRunLoop(test_data3, arraysize(test_data3)); | 480 OverwriteMtabAndRunLoop(test_data3, arraysize(test_data3)); |
| 481 EXPECT_EQ(3, observer().attach_calls()); | |
| 482 EXPECT_EQ(2, observer().detach_calls()); | |
| 487 | 483 |
| 488 // Attach |kDeviceDCIM1| to |kMountPointA|. | 484 // Attach |kDeviceDCIM1| to |kMountPointA|. |
| 489 // kDeviceDCIM2 -> kMountPointB | 485 // kDeviceDCIM2 -> kMountPointB |
| 490 // kDeviceDCIM1 -> kMountPointB * | 486 // kDeviceDCIM1 -> kMountPointB * |
| 491 // kDeviceDCIM1 -> kMountPointA | 487 // kDeviceDCIM1 -> kMountPointA |
| 492 MtabTestData test_data4[] = { | 488 MtabTestData test_data4[] = { |
| 493 MtabTestData(kDeviceDCIM1, test_path_a.value(), kValidFS), | 489 MtabTestData(kDeviceDCIM1, test_path_a.value(), kValidFS), |
| 494 }; | 490 }; |
| 495 EXPECT_CALL(observer(), OnRemovableStorageAttached(_, _, _)).Times(0); | |
| 496 EXPECT_CALL(observer(), OnRemovableStorageDetached(_)).Times(0); | |
| 497 AppendToMtabAndRunLoop(test_data4, arraysize(test_data4)); | 491 AppendToMtabAndRunLoop(test_data4, arraysize(test_data4)); |
| 492 EXPECT_EQ(3, observer().attach_calls()); | |
| 493 EXPECT_EQ(2, observer().detach_calls()); | |
| 498 | 494 |
| 499 // Detach |kDeviceDCIM1| from |kMountPointB|. | 495 // Detach |kDeviceDCIM1| from |kMountPointB|. |
| 500 // kDeviceDCIM1 -> kMountPointA * | 496 // kDeviceDCIM1 -> kMountPointA * |
| 501 // kDeviceDCIM2 -> kMountPointB * | 497 // kDeviceDCIM2 -> kMountPointB * |
| 502 EXPECT_CALL(observer(), OnRemovableStorageAttached(_, _, _)).Times(2); | |
| 503 EXPECT_CALL(observer(), OnRemovableStorageDetached(_)).Times(1); | |
| 504 OverwriteMtabAndRunLoop(test_data1, arraysize(test_data1)); | 498 OverwriteMtabAndRunLoop(test_data1, arraysize(test_data1)); |
| 499 EXPECT_EQ(5, observer().attach_calls()); | |
| 500 EXPECT_EQ(3, observer().detach_calls()); | |
| 505 | 501 |
| 506 // Detach all devices. | 502 // Detach all devices. |
| 507 EXPECT_CALL(observer(), OnRemovableStorageAttached(_, _, _)).Times(0); | |
| 508 EXPECT_CALL(observer(), OnRemovableStorageDetached(_)).Times(2); | |
| 509 WriteEmptyMtabAndRunLoop(); | 503 WriteEmptyMtabAndRunLoop(); |
| 504 EXPECT_EQ(5, observer().attach_calls()); | |
| 505 EXPECT_EQ(5, observer().detach_calls()); | |
| 510 } | 506 } |
| 511 | 507 |
| 512 TEST_F(RemovableDeviceNotificationLinuxTest, | 508 TEST_F(RemovableDeviceNotificationLinuxTest, |
| 513 MultipleMountPointsWithNonDCIMDevices) { | 509 MultipleMountPointsWithNonDCIMDevices) { |
| 514 FilePath test_path_a = CreateMountPointWithDCIMDir(kMountPointA); | 510 FilePath test_path_a = CreateMountPointWithDCIMDir(kMountPointA); |
| 515 FilePath test_path_b = CreateMountPointWithDCIMDir(kMountPointB); | 511 FilePath test_path_b = CreateMountPointWithDCIMDir(kMountPointB); |
| 516 ASSERT_FALSE(test_path_a.empty()); | 512 ASSERT_FALSE(test_path_a.empty()); |
| 517 ASSERT_FALSE(test_path_b.empty()); | 513 ASSERT_FALSE(test_path_b.empty()); |
| 518 | 514 |
| 519 // Attach to one first. (*'d mounts are those SystemMonitor knows about.) | 515 // Attach to one first. |
| 516 // (*'d mounts are those RemovableStorageNotifications knows about.) | |
| 520 // kDeviceDCIM1 -> kMountPointA * | 517 // kDeviceDCIM1 -> kMountPointA * |
| 521 MtabTestData test_data1[] = { | 518 MtabTestData test_data1[] = { |
| 522 MtabTestData(kDeviceDCIM1, test_path_a.value(), kValidFS), | 519 MtabTestData(kDeviceDCIM1, test_path_a.value(), kValidFS), |
| 523 }; | 520 }; |
| 524 EXPECT_CALL(observer(), OnRemovableStorageAttached(_, _, _)).Times(1); | |
| 525 EXPECT_CALL(observer(), OnRemovableStorageDetached(_)).Times(0); | |
| 526 AppendToMtabAndRunLoop(test_data1, arraysize(test_data1)); | 521 AppendToMtabAndRunLoop(test_data1, arraysize(test_data1)); |
| 522 EXPECT_EQ(1, observer().attach_calls()); | |
| 523 EXPECT_EQ(0, observer().detach_calls()); | |
| 527 | 524 |
| 528 // Attach |kDeviceDCIM1| to |kMountPointB|. | 525 // Attach |kDeviceDCIM1| to |kMountPointB|. |
| 529 // kDeviceDCIM1 -> kMountPointA * | 526 // kDeviceDCIM1 -> kMountPointA * |
| 530 // kDeviceDCIM1 -> kMountPointB | 527 // kDeviceDCIM1 -> kMountPointB |
| 531 MtabTestData test_data2[] = { | 528 MtabTestData test_data2[] = { |
| 532 MtabTestData(kDeviceDCIM1, test_path_b.value(), kValidFS), | 529 MtabTestData(kDeviceDCIM1, test_path_b.value(), kValidFS), |
| 533 }; | 530 }; |
| 534 EXPECT_CALL(observer(), OnRemovableStorageAttached(_, _, _)).Times(0); | |
| 535 EXPECT_CALL(observer(), OnRemovableStorageDetached(_)).Times(0); | |
| 536 AppendToMtabAndRunLoop(test_data2, arraysize(test_data2)); | 531 AppendToMtabAndRunLoop(test_data2, arraysize(test_data2)); |
| 532 EXPECT_EQ(1, observer().attach_calls()); | |
| 533 EXPECT_EQ(0, observer().detach_calls()); | |
| 537 | 534 |
| 538 // Attach |kDeviceFixed| (a non-removable device) to |kMountPointA|. | 535 // Attach |kDeviceFixed| (a non-removable device) to |kMountPointA|. |
| 539 // kDeviceDCIM1 -> kMountPointA | 536 // kDeviceDCIM1 -> kMountPointA |
| 540 // kDeviceDCIM1 -> kMountPointB * | 537 // kDeviceDCIM1 -> kMountPointB * |
| 541 // kDeviceFixed -> kMountPointA | 538 // kDeviceFixed -> kMountPointA |
| 542 MtabTestData test_data3[] = { | 539 MtabTestData test_data3[] = { |
| 543 MtabTestData(kDeviceFixed, test_path_a.value(), kValidFS), | 540 MtabTestData(kDeviceFixed, test_path_a.value(), kValidFS), |
| 544 }; | 541 }; |
| 545 EXPECT_CALL(observer(), OnRemovableStorageAttached(_, _, _)).Times(1); | |
| 546 EXPECT_CALL(observer(), OnRemovableStorageDetached(_)).Times(1); | |
| 547 RemoveDCIMDirFromMountPoint(kMountPointA); | 542 RemoveDCIMDirFromMountPoint(kMountPointA); |
| 548 AppendToMtabAndRunLoop(test_data3, arraysize(test_data3)); | 543 AppendToMtabAndRunLoop(test_data3, arraysize(test_data3)); |
| 544 EXPECT_EQ(2, observer().attach_calls()); | |
| 545 EXPECT_EQ(1, observer().detach_calls()); | |
| 549 | 546 |
| 550 // Detach |kDeviceFixed|. | 547 // Detach |kDeviceFixed|. |
| 551 // kDeviceDCIM1 -> kMountPointA | 548 // kDeviceDCIM1 -> kMountPointA |
| 552 // kDeviceDCIM1 -> kMountPointB * | 549 // kDeviceDCIM1 -> kMountPointB * |
| 553 MtabTestData test_data4[] = { | 550 MtabTestData test_data4[] = { |
| 554 MtabTestData(kDeviceDCIM1, test_path_a.value(), kValidFS), | 551 MtabTestData(kDeviceDCIM1, test_path_a.value(), kValidFS), |
| 555 MtabTestData(kDeviceDCIM1, test_path_b.value(), kValidFS), | 552 MtabTestData(kDeviceDCIM1, test_path_b.value(), kValidFS), |
| 556 }; | 553 }; |
| 557 EXPECT_CALL(observer(), OnRemovableStorageAttached(_, _, _)).Times(0); | |
| 558 EXPECT_CALL(observer(), OnRemovableStorageDetached(_)).Times(0); | |
| 559 CreateMountPointWithDCIMDir(kMountPointA); | 554 CreateMountPointWithDCIMDir(kMountPointA); |
| 560 OverwriteMtabAndRunLoop(test_data4, arraysize(test_data4)); | 555 OverwriteMtabAndRunLoop(test_data4, arraysize(test_data4)); |
| 556 EXPECT_EQ(2, observer().attach_calls()); | |
| 557 EXPECT_EQ(1, observer().detach_calls()); | |
| 561 | 558 |
| 562 // Attach |kDeviceNoDCIM| (a non-DCIM device) to |kMountPointB|. | 559 // Attach |kDeviceNoDCIM| (a non-DCIM device) to |kMountPointB|. |
| 563 // kDeviceDCIM1 -> kMountPointA * | 560 // kDeviceDCIM1 -> kMountPointA * |
| 564 // kDeviceDCIM1 -> kMountPointB | 561 // kDeviceDCIM1 -> kMountPointB |
| 565 // kDeviceNoDCIM -> kMountPointB * | 562 // kDeviceNoDCIM -> kMountPointB * |
| 566 MtabTestData test_data5[] = { | 563 MtabTestData test_data5[] = { |
| 567 MtabTestData(kDeviceNoDCIM, test_path_b.value(), kValidFS), | 564 MtabTestData(kDeviceNoDCIM, test_path_b.value(), kValidFS), |
| 568 }; | 565 }; |
| 569 EXPECT_CALL(observer(), OnRemovableStorageAttached(_, _, _)).Times(2); | |
| 570 EXPECT_CALL(observer(), OnRemovableStorageDetached(_)).Times(1); | |
| 571 file_util::Delete(test_path_b.Append(kDCIMDirectoryName), false); | 566 file_util::Delete(test_path_b.Append(kDCIMDirectoryName), false); |
| 572 AppendToMtabAndRunLoop(test_data5, arraysize(test_data5)); | 567 AppendToMtabAndRunLoop(test_data5, arraysize(test_data5)); |
| 568 EXPECT_EQ(4, observer().attach_calls()); | |
| 569 EXPECT_EQ(2, observer().detach_calls()); | |
| 573 | 570 |
| 574 // Detach |kDeviceNoDCIM|. | 571 // Detach |kDeviceNoDCIM|. |
| 575 // kDeviceDCIM1 -> kMountPointA * | 572 // kDeviceDCIM1 -> kMountPointA * |
| 576 // kDeviceDCIM1 -> kMountPointB | 573 // kDeviceDCIM1 -> kMountPointB |
| 577 MtabTestData test_data6[] = { | 574 MtabTestData test_data6[] = { |
| 578 MtabTestData(kDeviceDCIM1, test_path_a.value(), kValidFS), | 575 MtabTestData(kDeviceDCIM1, test_path_a.value(), kValidFS), |
| 579 MtabTestData(kDeviceDCIM1, test_path_b.value(), kValidFS), | 576 MtabTestData(kDeviceDCIM1, test_path_b.value(), kValidFS), |
| 580 }; | 577 }; |
| 581 EXPECT_CALL(observer(), OnRemovableStorageAttached(_, _, _)).Times(0); | |
| 582 EXPECT_CALL(observer(), OnRemovableStorageDetached(_)).Times(1); | |
| 583 CreateMountPointWithDCIMDir(kMountPointB); | 578 CreateMountPointWithDCIMDir(kMountPointB); |
| 584 OverwriteMtabAndRunLoop(test_data6, arraysize(test_data6)); | 579 OverwriteMtabAndRunLoop(test_data6, arraysize(test_data6)); |
| 580 EXPECT_EQ(4, observer().attach_calls()); | |
| 581 EXPECT_EQ(3, observer().detach_calls()); | |
| 585 | 582 |
| 586 // Detach |kDeviceDCIM1| from |kMountPointB|. | 583 // Detach |kDeviceDCIM1| from |kMountPointB|. |
| 587 // kDeviceDCIM1 -> kMountPointA * | 584 // kDeviceDCIM1 -> kMountPointA * |
| 588 EXPECT_CALL(observer(), OnRemovableStorageAttached(_, _, _)).Times(0); | |
| 589 EXPECT_CALL(observer(), OnRemovableStorageDetached(_)).Times(0); | |
| 590 OverwriteMtabAndRunLoop(test_data1, arraysize(test_data1)); | 585 OverwriteMtabAndRunLoop(test_data1, arraysize(test_data1)); |
| 586 EXPECT_EQ(4, observer().attach_calls()); | |
| 587 EXPECT_EQ(3, observer().detach_calls()); | |
| 591 | 588 |
| 592 // Detach all devices. | 589 // Detach all devices. |
| 593 EXPECT_CALL(observer(), OnRemovableStorageAttached(_, _, _)).Times(0); | |
| 594 EXPECT_CALL(observer(), OnRemovableStorageDetached(_)).Times(1); | |
| 595 WriteEmptyMtabAndRunLoop(); | 590 WriteEmptyMtabAndRunLoop(); |
| 591 EXPECT_EQ(4, observer().attach_calls()); | |
| 592 EXPECT_EQ(4, observer().detach_calls()); | |
| 596 } | 593 } |
| 597 | 594 |
| 598 TEST_F(RemovableDeviceNotificationLinuxTest, DeviceLookUp) { | 595 TEST_F(RemovableDeviceNotificationLinuxTest, DeviceLookUp) { |
| 599 FilePath test_path_a = CreateMountPointWithDCIMDir(kMountPointA); | 596 FilePath test_path_a = CreateMountPointWithDCIMDir(kMountPointA); |
| 600 FilePath test_path_b = CreateMountPointWithoutDCIMDir(kMountPointB); | 597 FilePath test_path_b = CreateMountPointWithoutDCIMDir(kMountPointB); |
| 601 FilePath test_path_c = CreateMountPointWithoutDCIMDir(kMountPointC); | 598 FilePath test_path_c = CreateMountPointWithoutDCIMDir(kMountPointC); |
| 602 ASSERT_FALSE(test_path_a.empty()); | 599 ASSERT_FALSE(test_path_a.empty()); |
| 603 ASSERT_FALSE(test_path_b.empty()); | 600 ASSERT_FALSE(test_path_b.empty()); |
| 604 ASSERT_FALSE(test_path_c.empty()); | 601 ASSERT_FALSE(test_path_c.empty()); |
| 605 | 602 |
| 606 // Attach to one first. (*'d mounts are those SystemMonitor knows about.) | 603 // Attach to one first. |
| 604 // (*'d mounts are those RemovableStorageNotifications knows about.) | |
| 607 // kDeviceDCIM1 -> kMountPointA * | 605 // kDeviceDCIM1 -> kMountPointA * |
| 608 // kDeviceNoDCIM -> kMountPointB * | 606 // kDeviceNoDCIM -> kMountPointB * |
| 609 // kDeviceFixed -> kMountPointC | 607 // kDeviceFixed -> kMountPointC |
| 610 MtabTestData test_data1[] = { | 608 MtabTestData test_data1[] = { |
| 611 MtabTestData(kDeviceDCIM1, test_path_a.value(), kValidFS), | 609 MtabTestData(kDeviceDCIM1, test_path_a.value(), kValidFS), |
| 612 MtabTestData(kDeviceNoDCIM, test_path_b.value(), kValidFS), | 610 MtabTestData(kDeviceNoDCIM, test_path_b.value(), kValidFS), |
| 613 MtabTestData(kDeviceFixed, test_path_c.value(), kValidFS), | 611 MtabTestData(kDeviceFixed, test_path_c.value(), kValidFS), |
| 614 }; | 612 }; |
| 615 EXPECT_CALL(observer(), OnRemovableStorageAttached(_, _, _)).Times(2); | |
| 616 EXPECT_CALL(observer(), OnRemovableStorageDetached(_)).Times(0); | |
| 617 AppendToMtabAndRunLoop(test_data1, arraysize(test_data1)); | 613 AppendToMtabAndRunLoop(test_data1, arraysize(test_data1)); |
| 614 EXPECT_EQ(2, observer().attach_calls()); | |
| 615 EXPECT_EQ(0, observer().detach_calls()); | |
| 618 | 616 |
| 619 base::SystemMonitor::RemovableStorageInfo device_info; | 617 RemovableStorageNotifications::StorageInfo device_info; |
| 620 EXPECT_TRUE(notifier()->GetDeviceInfoForPath(test_path_a, &device_info)); | 618 EXPECT_TRUE(notifier()->GetDeviceInfoForPath(test_path_a, &device_info)); |
| 621 EXPECT_EQ(GetDeviceId(kDeviceDCIM1), device_info.device_id); | 619 EXPECT_EQ(GetDeviceId(kDeviceDCIM1), device_info.device_id); |
| 622 EXPECT_EQ(test_path_a.value(), device_info.location); | 620 EXPECT_EQ(test_path_a.value(), device_info.location); |
| 623 EXPECT_EQ(GetDeviceName(kDeviceDCIM1), device_info.name); | 621 EXPECT_EQ(GetDeviceName(kDeviceDCIM1), device_info.name); |
| 624 | 622 |
| 625 EXPECT_TRUE(notifier()->GetDeviceInfoForPath(test_path_b, &device_info)); | 623 EXPECT_TRUE(notifier()->GetDeviceInfoForPath(test_path_b, &device_info)); |
| 626 EXPECT_EQ(GetDeviceId(kDeviceNoDCIM), device_info.device_id); | 624 EXPECT_EQ(GetDeviceId(kDeviceNoDCIM), device_info.device_id); |
| 627 EXPECT_EQ(test_path_b.value(), device_info.location); | 625 EXPECT_EQ(test_path_b.value(), device_info.location); |
| 628 EXPECT_EQ(GetDeviceName(kDeviceNoDCIM), device_info.name); | 626 EXPECT_EQ(GetDeviceName(kDeviceNoDCIM), device_info.name); |
| 629 | 627 |
| (...skipping 14 matching lines...) Expand all Loading... | |
| 644 | 642 |
| 645 // One device attached at multiple points. | 643 // One device attached at multiple points. |
| 646 // kDeviceDCIM1 -> kMountPointA * | 644 // kDeviceDCIM1 -> kMountPointA * |
| 647 // kDeviceFixed -> kMountPointB | 645 // kDeviceFixed -> kMountPointB |
| 648 // kDeviceFixed -> kMountPointC | 646 // kDeviceFixed -> kMountPointC |
| 649 MtabTestData test_data2[] = { | 647 MtabTestData test_data2[] = { |
| 650 MtabTestData(kDeviceDCIM1, test_path_a.value(), kValidFS), | 648 MtabTestData(kDeviceDCIM1, test_path_a.value(), kValidFS), |
| 651 MtabTestData(kDeviceFixed, test_path_b.value(), kValidFS), | 649 MtabTestData(kDeviceFixed, test_path_b.value(), kValidFS), |
| 652 MtabTestData(kDeviceFixed, test_path_c.value(), kValidFS), | 650 MtabTestData(kDeviceFixed, test_path_c.value(), kValidFS), |
| 653 }; | 651 }; |
| 654 EXPECT_CALL(observer(), OnRemovableStorageAttached(_, _, _)).Times(0); | |
| 655 EXPECT_CALL(observer(), OnRemovableStorageDetached(_)).Times(1); | |
| 656 AppendToMtabAndRunLoop(test_data2, arraysize(test_data2)); | 652 AppendToMtabAndRunLoop(test_data2, arraysize(test_data2)); |
| 657 | 653 |
| 658 EXPECT_TRUE(notifier()->GetDeviceInfoForPath(test_path_a, &device_info)); | 654 EXPECT_TRUE(notifier()->GetDeviceInfoForPath(test_path_a, &device_info)); |
| 659 EXPECT_EQ(GetDeviceId(kDeviceDCIM1), device_info.device_id); | 655 EXPECT_EQ(GetDeviceId(kDeviceDCIM1), device_info.device_id); |
| 660 | 656 |
| 661 EXPECT_TRUE(notifier()->GetDeviceInfoForPath(test_path_b, &device_info)); | 657 EXPECT_TRUE(notifier()->GetDeviceInfoForPath(test_path_b, &device_info)); |
| 662 EXPECT_EQ(GetDeviceId(kDeviceFixed), device_info.device_id); | 658 EXPECT_EQ(GetDeviceId(kDeviceFixed), device_info.device_id); |
| 663 | 659 |
| 664 EXPECT_TRUE(notifier()->GetDeviceInfoForPath(test_path_c, &device_info)); | 660 EXPECT_TRUE(notifier()->GetDeviceInfoForPath(test_path_c, &device_info)); |
| 665 EXPECT_EQ(GetDeviceId(kDeviceFixed), device_info.device_id); | 661 EXPECT_EQ(GetDeviceId(kDeviceFixed), device_info.device_id); |
| 662 | |
| 663 EXPECT_EQ(2, observer().attach_calls()); | |
| 664 EXPECT_EQ(1, observer().detach_calls()); | |
| 666 } | 665 } |
| 667 | 666 |
| 668 TEST_F(RemovableDeviceNotificationLinuxTest, DevicePartitionSize) { | 667 TEST_F(RemovableDeviceNotificationLinuxTest, DevicePartitionSize) { |
| 669 FilePath test_path_a = CreateMountPointWithDCIMDir(kMountPointA); | 668 FilePath test_path_a = CreateMountPointWithDCIMDir(kMountPointA); |
| 670 FilePath test_path_b = CreateMountPointWithoutDCIMDir(kMountPointB); | 669 FilePath test_path_b = CreateMountPointWithoutDCIMDir(kMountPointB); |
| 671 ASSERT_FALSE(test_path_a.empty()); | 670 ASSERT_FALSE(test_path_a.empty()); |
| 672 ASSERT_FALSE(test_path_b.empty()); | 671 ASSERT_FALSE(test_path_b.empty()); |
| 673 | 672 |
| 674 MtabTestData test_data1[] = { | 673 MtabTestData test_data1[] = { |
| 675 MtabTestData(kDeviceDCIM1, test_path_a.value(), kValidFS), | 674 MtabTestData(kDeviceDCIM1, test_path_a.value(), kValidFS), |
| 676 MtabTestData(kDeviceNoDCIM, test_path_b.value(), kValidFS), | 675 MtabTestData(kDeviceNoDCIM, test_path_b.value(), kValidFS), |
| 677 MtabTestData(kDeviceFixed, kInvalidPath, kInvalidFS), | 676 MtabTestData(kDeviceFixed, kInvalidPath, kInvalidFS), |
| 678 }; | 677 }; |
| 679 EXPECT_CALL(observer(), OnRemovableStorageAttached(_, _, _)).Times(2); | |
| 680 EXPECT_CALL(observer(), OnRemovableStorageDetached(_)).Times(0); | |
| 681 AppendToMtabAndRunLoop(test_data1, arraysize(test_data1)); | 678 AppendToMtabAndRunLoop(test_data1, arraysize(test_data1)); |
| 679 EXPECT_EQ(2, observer().attach_calls()); | |
| 680 EXPECT_EQ(0, observer().detach_calls()); | |
| 682 | 681 |
| 683 EXPECT_EQ(GetDevicePartitionSize(kDeviceDCIM1), | 682 EXPECT_EQ(GetDevicePartitionSize(kDeviceDCIM1), |
| 684 notifier()->GetStorageSize(test_path_a.value())); | 683 notifier()->GetStorageSize(test_path_a.value())); |
| 685 EXPECT_EQ(GetDevicePartitionSize(kDeviceNoDCIM), | 684 EXPECT_EQ(GetDevicePartitionSize(kDeviceNoDCIM), |
| 686 notifier()->GetStorageSize(test_path_b.value())); | 685 notifier()->GetStorageSize(test_path_b.value())); |
| 687 EXPECT_EQ(GetDevicePartitionSize(kInvalidPath), | 686 EXPECT_EQ(GetDevicePartitionSize(kInvalidPath), |
| 688 notifier()->GetStorageSize(kInvalidPath)); | 687 notifier()->GetStorageSize(kInvalidPath)); |
| 689 } | 688 } |
| 690 | 689 |
| 691 } // namespace | 690 } // namespace |
| 692 | 691 |
| 693 } // namespace chrome | 692 } // namespace chrome |
| OLD | NEW |