| Index: chrome/browser/storage_monitor/removable_device_notifications_linux_unittest.cc
|
| diff --git a/chrome/browser/storage_monitor/removable_device_notifications_linux_unittest.cc b/chrome/browser/storage_monitor/removable_device_notifications_linux_unittest.cc
|
| deleted file mode 100644
|
| index 7fe78f7f662bdb707b636b2b46ee9ae5c93ad470..0000000000000000000000000000000000000000
|
| --- a/chrome/browser/storage_monitor/removable_device_notifications_linux_unittest.cc
|
| +++ /dev/null
|
| @@ -1,702 +0,0 @@
|
| -// Copyright (c) 2012 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.
|
| -
|
| -// RemovableDeviceNotificationsLinux unit tests.
|
| -
|
| -#include "chrome/browser/storage_monitor/removable_device_notifications_linux.h"
|
| -
|
| -#include <mntent.h>
|
| -#include <stdio.h>
|
| -
|
| -#include <string>
|
| -
|
| -#include "base/file_util.h"
|
| -#include "base/files/scoped_temp_dir.h"
|
| -#include "base/logging.h"
|
| -#include "base/memory/scoped_ptr.h"
|
| -#include "base/message_loop.h"
|
| -#include "base/utf_string_conversions.h"
|
| -#include "chrome/browser/storage_monitor/media_device_notifications_utils.h"
|
| -#include "chrome/browser/storage_monitor/media_storage_util.h"
|
| -#include "chrome/browser/storage_monitor/mock_removable_storage_observer.h"
|
| -#include "chrome/browser/storage_monitor/removable_device_constants.h"
|
| -#include "chrome/browser/storage_monitor/storage_monitor.h"
|
| -#include "content/public/test/test_browser_thread.h"
|
| -#include "testing/gtest/include/gtest/gtest.h"
|
| -
|
| -namespace chrome {
|
| -
|
| -namespace {
|
| -
|
| -const char kValidFS[] = "vfat";
|
| -const char kInvalidFS[] = "invalidfs";
|
| -
|
| -const char kInvalidPath[] = "invalid path does not exist";
|
| -
|
| -const char kDeviceDCIM1[] = "d1";
|
| -const char kDeviceDCIM2[] = "d2";
|
| -const char kDeviceDCIM3[] = "d3";
|
| -const char kDeviceNoDCIM[] = "d4";
|
| -const char kDeviceFixed[] = "d5";
|
| -
|
| -const char kInvalidDevice[] = "invalid_device";
|
| -
|
| -const char kMountPointA[] = "mnt_a";
|
| -const char kMountPointB[] = "mnt_b";
|
| -const char kMountPointC[] = "mnt_c";
|
| -
|
| -struct TestDeviceData {
|
| - const char* device_path;
|
| - const char* unique_id;
|
| - const char* device_name;
|
| - MediaStorageUtil::Type type;
|
| - uint64 partition_size_in_bytes;
|
| -};
|
| -
|
| -const TestDeviceData kTestDeviceData[] = {
|
| - { kDeviceDCIM1, "UUID:FFF0-000F", "TEST_USB_MODEL_1",
|
| - MediaStorageUtil::REMOVABLE_MASS_STORAGE_WITH_DCIM, 88788 },
|
| - { kDeviceDCIM2, "VendorModelSerial:ComName:Model2010:8989",
|
| - "TEST_USB_MODEL_2", MediaStorageUtil::REMOVABLE_MASS_STORAGE_WITH_DCIM,
|
| - 8773 },
|
| - { kDeviceDCIM3, "VendorModelSerial:::WEM319X792", "TEST_USB_MODEL_3",
|
| - MediaStorageUtil::REMOVABLE_MASS_STORAGE_WITH_DCIM, 22837 },
|
| - { kDeviceNoDCIM, "UUID:ABCD-1234", "TEST_USB_MODEL_4",
|
| - MediaStorageUtil::REMOVABLE_MASS_STORAGE_NO_DCIM, 512 },
|
| - { kDeviceFixed, "UUID:743A-2349", "743A-2349",
|
| - MediaStorageUtil::FIXED_MASS_STORAGE, 17282 },
|
| -};
|
| -
|
| -void GetDeviceInfo(const base::FilePath& device_path,
|
| - std::string* id,
|
| - string16* name,
|
| - bool* removable,
|
| - uint64* partition_size_in_bytes) {
|
| - for (size_t i = 0; i < arraysize(kTestDeviceData); i++) {
|
| - if (device_path.value() == kTestDeviceData[i].device_path) {
|
| - if (id)
|
| - *id = kTestDeviceData[i].unique_id;
|
| - if (name)
|
| - *name = ASCIIToUTF16(kTestDeviceData[i].device_name);
|
| - if (removable) {
|
| - MediaStorageUtil::Type type = kTestDeviceData[i].type;
|
| - *removable =
|
| - (type == MediaStorageUtil::REMOVABLE_MASS_STORAGE_WITH_DCIM) ||
|
| - (type == MediaStorageUtil::REMOVABLE_MASS_STORAGE_NO_DCIM);
|
| - }
|
| - if (partition_size_in_bytes)
|
| - *partition_size_in_bytes = kTestDeviceData[i].partition_size_in_bytes;
|
| - return;
|
| - }
|
| - }
|
| - NOTREACHED();
|
| -}
|
| -
|
| -uint64 GetDevicePartitionSize(const std::string& device) {
|
| - for (size_t i = 0; i < arraysize(kTestDeviceData); ++i) {
|
| - if (device == kTestDeviceData[i].device_path)
|
| - return kTestDeviceData[i].partition_size_in_bytes;
|
| - }
|
| - return 0;
|
| -}
|
| -
|
| -std::string GetDeviceId(const std::string& device) {
|
| - for (size_t i = 0; i < arraysize(kTestDeviceData); ++i) {
|
| - if (device == kTestDeviceData[i].device_path) {
|
| - return MediaStorageUtil::MakeDeviceId(kTestDeviceData[i].type,
|
| - kTestDeviceData[i].unique_id);
|
| - }
|
| - }
|
| - if (device == kInvalidDevice) {
|
| - return MediaStorageUtil::MakeDeviceId(MediaStorageUtil::FIXED_MASS_STORAGE,
|
| - kInvalidDevice);
|
| - }
|
| - return std::string();
|
| -}
|
| -
|
| -string16 GetDeviceNameWithSizeDetails(const std::string& device) {
|
| - for (size_t i = 0; i < arraysize(kTestDeviceData); ++i) {
|
| - if (device == kTestDeviceData[i].device_path) {
|
| - return GetDisplayNameForDevice(
|
| - kTestDeviceData[i].partition_size_in_bytes,
|
| - ASCIIToUTF16(kTestDeviceData[i].device_name));
|
| - }
|
| - }
|
| - return string16();
|
| -}
|
| -
|
| -string16 GetDeviceName(const std::string& device) {
|
| - for (size_t i = 0; i < arraysize(kTestDeviceData); i++) {
|
| - if (device == kTestDeviceData[i].device_path)
|
| - return ASCIIToUTF16(kTestDeviceData[i].device_name);
|
| - }
|
| - return string16();
|
| -}
|
| -
|
| -class RemovableDeviceNotificationsLinuxTestWrapper
|
| - : public RemovableDeviceNotificationsLinux {
|
| - public:
|
| - RemovableDeviceNotificationsLinuxTestWrapper(const base::FilePath& path,
|
| - MessageLoop* message_loop)
|
| - : RemovableDeviceNotificationsLinux(path, &GetDeviceInfo),
|
| - message_loop_(message_loop) {
|
| - }
|
| -
|
| - private:
|
| - // Avoids code deleting the object while there are references to it.
|
| - // Aside from the base::RefCountedThreadSafe friend class, any attempts to
|
| - // call this dtor will result in a compile-time error.
|
| - virtual ~RemovableDeviceNotificationsLinuxTestWrapper() {}
|
| -
|
| - virtual void OnFilePathChanged(const base::FilePath& path,
|
| - bool error) OVERRIDE {
|
| - RemovableDeviceNotificationsLinux::OnFilePathChanged(path, error);
|
| - message_loop_->PostTask(FROM_HERE, MessageLoop::QuitClosure());
|
| - }
|
| -
|
| - MessageLoop* message_loop_;
|
| -
|
| - DISALLOW_COPY_AND_ASSIGN(RemovableDeviceNotificationsLinuxTestWrapper);
|
| -};
|
| -
|
| -class RemovableDeviceNotificationLinuxTest : public testing::Test {
|
| - public:
|
| - struct MtabTestData {
|
| - MtabTestData(const std::string& mount_device,
|
| - const std::string& mount_point,
|
| - const std::string& mount_type)
|
| - : mount_device(mount_device),
|
| - mount_point(mount_point),
|
| - mount_type(mount_type) {
|
| - }
|
| -
|
| - const std::string mount_device;
|
| - const std::string mount_point;
|
| - const std::string mount_type;
|
| - };
|
| -
|
| - RemovableDeviceNotificationLinuxTest()
|
| - : message_loop_(MessageLoop::TYPE_IO),
|
| - file_thread_(content::BrowserThread::FILE, &message_loop_) {
|
| - }
|
| - virtual ~RemovableDeviceNotificationLinuxTest() {}
|
| -
|
| - protected:
|
| - virtual void SetUp() OVERRIDE {
|
| - // Create and set up a temp dir with files for the test.
|
| - ASSERT_TRUE(scoped_temp_dir_.CreateUniqueTempDir());
|
| - base::FilePath test_dir = scoped_temp_dir_.path().AppendASCII("test_etc");
|
| - ASSERT_TRUE(file_util::CreateDirectory(test_dir));
|
| - mtab_file_ = test_dir.AppendASCII("test_mtab");
|
| - MtabTestData initial_test_data[] = {
|
| - MtabTestData("dummydevice", "dummydir", kInvalidFS),
|
| - };
|
| - WriteToMtab(initial_test_data,
|
| - arraysize(initial_test_data),
|
| - true /* overwrite */);
|
| -
|
| - // Initialize the test subject.
|
| - notifications_ = new RemovableDeviceNotificationsLinuxTestWrapper(
|
| - mtab_file_, &message_loop_);
|
| - mock_storage_observer_.reset(new MockRemovableStorageObserver);
|
| - notifications_->AddObserver(mock_storage_observer_.get());
|
| -
|
| - notifications_->Init();
|
| - message_loop_.RunUntilIdle();
|
| - }
|
| -
|
| - virtual void TearDown() OVERRIDE {
|
| - message_loop_.RunUntilIdle();
|
| - notifications_->RemoveObserver(mock_storage_observer_.get());
|
| - notifications_ = NULL;
|
| - }
|
| -
|
| - // Append mtab entries from the |data| array of size |data_size| to the mtab
|
| - // file, and run the message loop.
|
| - void AppendToMtabAndRunLoop(const MtabTestData* data, size_t data_size) {
|
| - WriteToMtab(data, data_size, false /* do not overwrite */);
|
| - message_loop_.Run();
|
| - }
|
| -
|
| - // Overwrite the mtab file with mtab entries from the |data| array of size
|
| - // |data_size|, and run the message loop.
|
| - void OverwriteMtabAndRunLoop(const MtabTestData* data, size_t data_size) {
|
| - WriteToMtab(data, data_size, true /* overwrite */);
|
| - message_loop_.Run();
|
| - }
|
| -
|
| - // Simplied version of OverwriteMtabAndRunLoop() that just deletes all the
|
| - // entries in the mtab file.
|
| - void WriteEmptyMtabAndRunLoop() {
|
| - OverwriteMtabAndRunLoop(NULL, // No data.
|
| - 0); // No data length.
|
| - }
|
| -
|
| - // Create a directory named |dir| relative to the test directory.
|
| - // It has a DCIM directory, so RemovableDeviceNotificationsLinux recognizes it
|
| - // as a media directory.
|
| - base::FilePath CreateMountPointWithDCIMDir(const std::string& dir) {
|
| - return CreateMountPoint(dir, true /* create DCIM dir */);
|
| - }
|
| -
|
| - // Create a directory named |dir| relative to the test directory.
|
| - // It does not have a DCIM directory, so RemovableDeviceNotificationsLinux
|
| - // does not recognizes it as a media directory.
|
| - base::FilePath CreateMountPointWithoutDCIMDir(const std::string& dir) {
|
| - return CreateMountPoint(dir, false /* do not create DCIM dir */);
|
| - }
|
| -
|
| - void RemoveDCIMDirFromMountPoint(const std::string& dir) {
|
| - base::FilePath dcim =
|
| - scoped_temp_dir_.path().AppendASCII(dir).Append(kDCIMDirectoryName);
|
| - file_util::Delete(dcim, false);
|
| - }
|
| -
|
| - MockRemovableStorageObserver& observer() {
|
| - return *mock_storage_observer_;
|
| - }
|
| -
|
| - RemovableDeviceNotificationsLinux* notifier() {
|
| - return notifications_.get();
|
| - }
|
| -
|
| - private:
|
| - // Create a directory named |dir| relative to the test directory.
|
| - // Set |with_dcim_dir| to true if the created directory will have a "DCIM"
|
| - // subdirectory.
|
| - // Returns the full path to the created directory on success, or an empty
|
| - // path on failure.
|
| - base::FilePath CreateMountPoint(const std::string& dir, bool with_dcim_dir) {
|
| - base::FilePath return_path(scoped_temp_dir_.path());
|
| - return_path = return_path.AppendASCII(dir);
|
| - base::FilePath path(return_path);
|
| - if (with_dcim_dir)
|
| - path = path.Append(kDCIMDirectoryName);
|
| - if (!file_util::CreateDirectory(path))
|
| - return base::FilePath();
|
| - return return_path;
|
| - }
|
| -
|
| - // Write the test mtab data to |mtab_file_|.
|
| - // |data| is an array of mtab entries.
|
| - // |data_size| is the array size of |data|.
|
| - // |overwrite| specifies whether to overwrite |mtab_file_|.
|
| - void WriteToMtab(const MtabTestData* data,
|
| - size_t data_size,
|
| - bool overwrite) {
|
| - FILE* file = setmntent(mtab_file_.value().c_str(), overwrite ? "w" : "a");
|
| - ASSERT_TRUE(file);
|
| -
|
| - // Due to the glibc *mntent() interface design, which is out of our
|
| - // control, the mtnent struct has several char* fields, even though
|
| - // addmntent() does not write to them in the calls below. To make the
|
| - // compiler happy while avoiding making additional copies of strings,
|
| - // we just const_cast() the strings' c_str()s.
|
| - // Assuming addmntent() does not write to the char* fields, this is safe.
|
| - // It is unlikely the platforms this test suite runs on will have an
|
| - // addmntent() implementation that does change the char* fields. If that
|
| - // was ever the case, the test suite will start crashing or failing.
|
| - mntent entry;
|
| - static const char kMountOpts[] = "rw";
|
| - entry.mnt_opts = const_cast<char*>(kMountOpts);
|
| - entry.mnt_freq = 0;
|
| - entry.mnt_passno = 0;
|
| - for (size_t i = 0; i < data_size; ++i) {
|
| - entry.mnt_fsname = const_cast<char*>(data[i].mount_device.c_str());
|
| - entry.mnt_dir = const_cast<char*>(data[i].mount_point.c_str());
|
| - entry.mnt_type = const_cast<char*>(data[i].mount_type.c_str());
|
| - ASSERT_EQ(0, addmntent(file, &entry));
|
| - }
|
| - ASSERT_EQ(1, endmntent(file));
|
| - }
|
| -
|
| - // The message loop and file thread to run tests on.
|
| - MessageLoop message_loop_;
|
| - content::TestBrowserThread file_thread_;
|
| -
|
| - scoped_ptr<MockRemovableStorageObserver> mock_storage_observer_;
|
| -
|
| - // Temporary directory for created test data.
|
| - base::ScopedTempDir scoped_temp_dir_;
|
| - // Path to the test mtab file.
|
| - base::FilePath mtab_file_;
|
| -
|
| - scoped_refptr<RemovableDeviceNotificationsLinuxTestWrapper> notifications_;
|
| -
|
| - DISALLOW_COPY_AND_ASSIGN(RemovableDeviceNotificationLinuxTest);
|
| -};
|
| -
|
| -// Simple test case where we attach and detach a media device.
|
| -TEST_F(RemovableDeviceNotificationLinuxTest, BasicAttachDetach) {
|
| - base::FilePath test_path = CreateMountPointWithDCIMDir(kMountPointA);
|
| - ASSERT_FALSE(test_path.empty());
|
| - MtabTestData test_data[] = {
|
| - MtabTestData(kDeviceDCIM2, test_path.value(), kValidFS),
|
| - MtabTestData(kDeviceFixed, kInvalidPath, kValidFS),
|
| - };
|
| - // Only |kDeviceDCIM2| should be attached, since |kDeviceFixed| has a bad
|
| - // path.
|
| - AppendToMtabAndRunLoop(test_data, arraysize(test_data));
|
| -
|
| - EXPECT_EQ(1, observer().attach_calls());
|
| - EXPECT_EQ(0, observer().detach_calls());
|
| - EXPECT_EQ(GetDeviceId(kDeviceDCIM2), observer().last_attached().device_id);
|
| - EXPECT_EQ(GetDeviceNameWithSizeDetails(kDeviceDCIM2),
|
| - observer().last_attached().name);
|
| - EXPECT_EQ(test_path.value(),
|
| - observer().last_attached().location);
|
| -
|
| - // |kDeviceDCIM2| should be detached here.
|
| - WriteEmptyMtabAndRunLoop();
|
| - EXPECT_EQ(1, observer().attach_calls());
|
| - EXPECT_EQ(1, observer().detach_calls());
|
| - EXPECT_EQ(GetDeviceId(kDeviceDCIM2), observer().last_detached().device_id);
|
| -}
|
| -
|
| -// Only removable devices are recognized.
|
| -TEST_F(RemovableDeviceNotificationLinuxTest, Removable) {
|
| - base::FilePath test_path_a = CreateMountPointWithDCIMDir(kMountPointA);
|
| - ASSERT_FALSE(test_path_a.empty());
|
| - MtabTestData test_data1[] = {
|
| - MtabTestData(kDeviceDCIM1, test_path_a.value(), kValidFS),
|
| - };
|
| - // |kDeviceDCIM1| should be attached as expected.
|
| - AppendToMtabAndRunLoop(test_data1, arraysize(test_data1));
|
| -
|
| - EXPECT_EQ(1, observer().attach_calls());
|
| - EXPECT_EQ(0, observer().detach_calls());
|
| - EXPECT_EQ(GetDeviceId(kDeviceDCIM1), observer().last_attached().device_id);
|
| - EXPECT_EQ(GetDeviceNameWithSizeDetails(kDeviceDCIM1),
|
| - observer().last_attached().name);
|
| - EXPECT_EQ(test_path_a.value(),
|
| - observer().last_attached().location);
|
| -
|
| - // This should do nothing, since |kDeviceFixed| is not removable.
|
| - base::FilePath test_path_b = CreateMountPointWithoutDCIMDir(kMountPointB);
|
| - ASSERT_FALSE(test_path_b.empty());
|
| - MtabTestData test_data2[] = {
|
| - MtabTestData(kDeviceFixed, test_path_b.value(), kValidFS),
|
| - };
|
| - AppendToMtabAndRunLoop(test_data2, arraysize(test_data2));
|
| - EXPECT_EQ(1, observer().attach_calls());
|
| - EXPECT_EQ(0, observer().detach_calls());
|
| -
|
| - // |kDeviceDCIM1| should be detached as expected.
|
| - WriteEmptyMtabAndRunLoop();
|
| - EXPECT_EQ(1, observer().attach_calls());
|
| - EXPECT_EQ(1, observer().detach_calls());
|
| - EXPECT_EQ(GetDeviceId(kDeviceDCIM1), observer().last_detached().device_id);
|
| -
|
| - // |kDeviceNoDCIM| should be attached as expected.
|
| - MtabTestData test_data3[] = {
|
| - MtabTestData(kDeviceNoDCIM, test_path_b.value(), kValidFS),
|
| - };
|
| - AppendToMtabAndRunLoop(test_data3, arraysize(test_data3));
|
| - EXPECT_EQ(2, observer().attach_calls());
|
| - EXPECT_EQ(1, observer().detach_calls());
|
| - EXPECT_EQ(GetDeviceId(kDeviceNoDCIM), observer().last_attached().device_id);
|
| - EXPECT_EQ(GetDeviceNameWithSizeDetails(kDeviceNoDCIM),
|
| - observer().last_attached().name);
|
| - EXPECT_EQ(test_path_b.value(),
|
| - observer().last_attached().location);
|
| -
|
| - // |kDeviceNoDCIM| should be detached as expected.
|
| - WriteEmptyMtabAndRunLoop();
|
| - EXPECT_EQ(2, observer().attach_calls());
|
| - EXPECT_EQ(2, observer().detach_calls());
|
| - EXPECT_EQ(GetDeviceId(kDeviceNoDCIM), observer().last_detached().device_id);
|
| -}
|
| -
|
| -// More complicated test case with multiple devices on multiple mount points.
|
| -TEST_F(RemovableDeviceNotificationLinuxTest, SwapMountPoints) {
|
| - base::FilePath test_path_a = CreateMountPointWithDCIMDir(kMountPointA);
|
| - base::FilePath test_path_b = CreateMountPointWithDCIMDir(kMountPointB);
|
| - ASSERT_FALSE(test_path_a.empty());
|
| - ASSERT_FALSE(test_path_b.empty());
|
| -
|
| - // Attach two devices.
|
| - // (*'d mounts are those RemovableStorageNotifications knows about.)
|
| - // kDeviceDCIM1 -> kMountPointA *
|
| - // kDeviceDCIM2 -> kMountPointB *
|
| - MtabTestData test_data1[] = {
|
| - MtabTestData(kDeviceDCIM1, test_path_a.value(), kValidFS),
|
| - MtabTestData(kDeviceDCIM2, test_path_b.value(), kValidFS),
|
| - };
|
| - AppendToMtabAndRunLoop(test_data1, arraysize(test_data1));
|
| - EXPECT_EQ(2, observer().attach_calls());
|
| - EXPECT_EQ(0, observer().detach_calls());
|
| -
|
| - // Detach two devices from old mount points and attach the devices at new
|
| - // mount points.
|
| - // kDeviceDCIM1 -> kMountPointB *
|
| - // kDeviceDCIM2 -> kMountPointA *
|
| - MtabTestData test_data2[] = {
|
| - MtabTestData(kDeviceDCIM1, test_path_b.value(), kValidFS),
|
| - MtabTestData(kDeviceDCIM2, test_path_a.value(), kValidFS),
|
| - };
|
| - OverwriteMtabAndRunLoop(test_data2, arraysize(test_data2));
|
| - EXPECT_EQ(4, observer().attach_calls());
|
| - EXPECT_EQ(2, observer().detach_calls());
|
| -
|
| - // Detach all devices.
|
| - WriteEmptyMtabAndRunLoop();
|
| - EXPECT_EQ(4, observer().attach_calls());
|
| - EXPECT_EQ(4, observer().detach_calls());
|
| -}
|
| -
|
| -// More complicated test case with multiple devices on multiple mount points.
|
| -TEST_F(RemovableDeviceNotificationLinuxTest, MultiDevicesMultiMountPoints) {
|
| - base::FilePath test_path_a = CreateMountPointWithDCIMDir(kMountPointA);
|
| - base::FilePath test_path_b = CreateMountPointWithDCIMDir(kMountPointB);
|
| - ASSERT_FALSE(test_path_a.empty());
|
| - ASSERT_FALSE(test_path_b.empty());
|
| -
|
| - // Attach two devices.
|
| - // (*'d mounts are those RemovableStorageNotifications knows about.)
|
| - // kDeviceDCIM1 -> kMountPointA *
|
| - // kDeviceDCIM2 -> kMountPointB *
|
| - MtabTestData test_data1[] = {
|
| - MtabTestData(kDeviceDCIM1, test_path_a.value(), kValidFS),
|
| - MtabTestData(kDeviceDCIM2, test_path_b.value(), kValidFS),
|
| - };
|
| - AppendToMtabAndRunLoop(test_data1, arraysize(test_data1));
|
| - EXPECT_EQ(2, observer().attach_calls());
|
| - EXPECT_EQ(0, observer().detach_calls());
|
| -
|
| - // Attach |kDeviceDCIM1| to |kMountPointB|.
|
| - // |kDeviceDCIM2| is inaccessible, so it is detached. |kDeviceDCIM1| has been
|
| - // attached at |kMountPointB|, but is still accessible from |kMountPointA|.
|
| - // kDeviceDCIM1 -> kMountPointA *
|
| - // kDeviceDCIM2 -> kMountPointB
|
| - // kDeviceDCIM1 -> kMountPointB
|
| - MtabTestData test_data2[] = {
|
| - MtabTestData(kDeviceDCIM1, test_path_b.value(), kValidFS),
|
| - };
|
| - AppendToMtabAndRunLoop(test_data2, arraysize(test_data2));
|
| - EXPECT_EQ(2, observer().attach_calls());
|
| - EXPECT_EQ(1, observer().detach_calls());
|
| -
|
| - // Detach |kDeviceDCIM1| from |kMountPointA|, causing a detach and attach
|
| - // event.
|
| - // kDeviceDCIM2 -> kMountPointB
|
| - // kDeviceDCIM1 -> kMountPointB *
|
| - MtabTestData test_data3[] = {
|
| - MtabTestData(kDeviceDCIM2, test_path_b.value(), kValidFS),
|
| - MtabTestData(kDeviceDCIM1, test_path_b.value(), kValidFS),
|
| - };
|
| - OverwriteMtabAndRunLoop(test_data3, arraysize(test_data3));
|
| - EXPECT_EQ(3, observer().attach_calls());
|
| - EXPECT_EQ(2, observer().detach_calls());
|
| -
|
| - // Attach |kDeviceDCIM1| to |kMountPointA|.
|
| - // kDeviceDCIM2 -> kMountPointB
|
| - // kDeviceDCIM1 -> kMountPointB *
|
| - // kDeviceDCIM1 -> kMountPointA
|
| - MtabTestData test_data4[] = {
|
| - MtabTestData(kDeviceDCIM1, test_path_a.value(), kValidFS),
|
| - };
|
| - AppendToMtabAndRunLoop(test_data4, arraysize(test_data4));
|
| - EXPECT_EQ(3, observer().attach_calls());
|
| - EXPECT_EQ(2, observer().detach_calls());
|
| -
|
| - // Detach |kDeviceDCIM1| from |kMountPointB|.
|
| - // kDeviceDCIM1 -> kMountPointA *
|
| - // kDeviceDCIM2 -> kMountPointB *
|
| - OverwriteMtabAndRunLoop(test_data1, arraysize(test_data1));
|
| - EXPECT_EQ(5, observer().attach_calls());
|
| - EXPECT_EQ(3, observer().detach_calls());
|
| -
|
| - // Detach all devices.
|
| - WriteEmptyMtabAndRunLoop();
|
| - EXPECT_EQ(5, observer().attach_calls());
|
| - EXPECT_EQ(5, observer().detach_calls());
|
| -}
|
| -
|
| -TEST_F(RemovableDeviceNotificationLinuxTest,
|
| - MultipleMountPointsWithNonDCIMDevices) {
|
| - base::FilePath test_path_a = CreateMountPointWithDCIMDir(kMountPointA);
|
| - base::FilePath test_path_b = CreateMountPointWithDCIMDir(kMountPointB);
|
| - ASSERT_FALSE(test_path_a.empty());
|
| - ASSERT_FALSE(test_path_b.empty());
|
| -
|
| - // Attach to one first.
|
| - // (*'d mounts are those RemovableStorageNotifications knows about.)
|
| - // kDeviceDCIM1 -> kMountPointA *
|
| - MtabTestData test_data1[] = {
|
| - MtabTestData(kDeviceDCIM1, test_path_a.value(), kValidFS),
|
| - };
|
| - AppendToMtabAndRunLoop(test_data1, arraysize(test_data1));
|
| - EXPECT_EQ(1, observer().attach_calls());
|
| - EXPECT_EQ(0, observer().detach_calls());
|
| -
|
| - // Attach |kDeviceDCIM1| to |kMountPointB|.
|
| - // kDeviceDCIM1 -> kMountPointA *
|
| - // kDeviceDCIM1 -> kMountPointB
|
| - MtabTestData test_data2[] = {
|
| - MtabTestData(kDeviceDCIM1, test_path_b.value(), kValidFS),
|
| - };
|
| - AppendToMtabAndRunLoop(test_data2, arraysize(test_data2));
|
| - EXPECT_EQ(1, observer().attach_calls());
|
| - EXPECT_EQ(0, observer().detach_calls());
|
| -
|
| - // Attach |kDeviceFixed| (a non-removable device) to |kMountPointA|.
|
| - // kDeviceDCIM1 -> kMountPointA
|
| - // kDeviceDCIM1 -> kMountPointB *
|
| - // kDeviceFixed -> kMountPointA
|
| - MtabTestData test_data3[] = {
|
| - MtabTestData(kDeviceFixed, test_path_a.value(), kValidFS),
|
| - };
|
| - RemoveDCIMDirFromMountPoint(kMountPointA);
|
| - AppendToMtabAndRunLoop(test_data3, arraysize(test_data3));
|
| - EXPECT_EQ(2, observer().attach_calls());
|
| - EXPECT_EQ(1, observer().detach_calls());
|
| -
|
| - // Detach |kDeviceFixed|.
|
| - // kDeviceDCIM1 -> kMountPointA
|
| - // kDeviceDCIM1 -> kMountPointB *
|
| - MtabTestData test_data4[] = {
|
| - MtabTestData(kDeviceDCIM1, test_path_a.value(), kValidFS),
|
| - MtabTestData(kDeviceDCIM1, test_path_b.value(), kValidFS),
|
| - };
|
| - CreateMountPointWithDCIMDir(kMountPointA);
|
| - OverwriteMtabAndRunLoop(test_data4, arraysize(test_data4));
|
| - EXPECT_EQ(2, observer().attach_calls());
|
| - EXPECT_EQ(1, observer().detach_calls());
|
| -
|
| - // Attach |kDeviceNoDCIM| (a non-DCIM device) to |kMountPointB|.
|
| - // kDeviceDCIM1 -> kMountPointA *
|
| - // kDeviceDCIM1 -> kMountPointB
|
| - // kDeviceNoDCIM -> kMountPointB *
|
| - MtabTestData test_data5[] = {
|
| - MtabTestData(kDeviceNoDCIM, test_path_b.value(), kValidFS),
|
| - };
|
| - file_util::Delete(test_path_b.Append(kDCIMDirectoryName), false);
|
| - AppendToMtabAndRunLoop(test_data5, arraysize(test_data5));
|
| - EXPECT_EQ(4, observer().attach_calls());
|
| - EXPECT_EQ(2, observer().detach_calls());
|
| -
|
| - // Detach |kDeviceNoDCIM|.
|
| - // kDeviceDCIM1 -> kMountPointA *
|
| - // kDeviceDCIM1 -> kMountPointB
|
| - MtabTestData test_data6[] = {
|
| - MtabTestData(kDeviceDCIM1, test_path_a.value(), kValidFS),
|
| - MtabTestData(kDeviceDCIM1, test_path_b.value(), kValidFS),
|
| - };
|
| - CreateMountPointWithDCIMDir(kMountPointB);
|
| - OverwriteMtabAndRunLoop(test_data6, arraysize(test_data6));
|
| - EXPECT_EQ(4, observer().attach_calls());
|
| - EXPECT_EQ(3, observer().detach_calls());
|
| -
|
| - // Detach |kDeviceDCIM1| from |kMountPointB|.
|
| - // kDeviceDCIM1 -> kMountPointA *
|
| - OverwriteMtabAndRunLoop(test_data1, arraysize(test_data1));
|
| - EXPECT_EQ(4, observer().attach_calls());
|
| - EXPECT_EQ(3, observer().detach_calls());
|
| -
|
| - // Detach all devices.
|
| - WriteEmptyMtabAndRunLoop();
|
| - EXPECT_EQ(4, observer().attach_calls());
|
| - EXPECT_EQ(4, observer().detach_calls());
|
| -}
|
| -
|
| -TEST_F(RemovableDeviceNotificationLinuxTest, DeviceLookUp) {
|
| - base::FilePath test_path_a = CreateMountPointWithDCIMDir(kMountPointA);
|
| - base::FilePath test_path_b = CreateMountPointWithoutDCIMDir(kMountPointB);
|
| - base::FilePath test_path_c = CreateMountPointWithoutDCIMDir(kMountPointC);
|
| - ASSERT_FALSE(test_path_a.empty());
|
| - ASSERT_FALSE(test_path_b.empty());
|
| - ASSERT_FALSE(test_path_c.empty());
|
| -
|
| - // Attach to one first.
|
| - // (*'d mounts are those RemovableStorageNotifications knows about.)
|
| - // kDeviceDCIM1 -> kMountPointA *
|
| - // kDeviceNoDCIM -> kMountPointB *
|
| - // kDeviceFixed -> kMountPointC
|
| - MtabTestData test_data1[] = {
|
| - MtabTestData(kDeviceDCIM1, test_path_a.value(), kValidFS),
|
| - MtabTestData(kDeviceNoDCIM, test_path_b.value(), kValidFS),
|
| - MtabTestData(kDeviceFixed, test_path_c.value(), kValidFS),
|
| - };
|
| - AppendToMtabAndRunLoop(test_data1, arraysize(test_data1));
|
| - EXPECT_EQ(2, observer().attach_calls());
|
| - EXPECT_EQ(0, observer().detach_calls());
|
| -
|
| - StorageMonitor::StorageInfo device_info;
|
| - EXPECT_TRUE(notifier()->GetStorageInfoForPath(test_path_a, &device_info));
|
| - EXPECT_EQ(GetDeviceId(kDeviceDCIM1), device_info.device_id);
|
| - EXPECT_EQ(test_path_a.value(), device_info.location);
|
| - EXPECT_EQ(GetDeviceName(kDeviceDCIM1), device_info.name);
|
| -
|
| - EXPECT_TRUE(notifier()->GetStorageInfoForPath(test_path_b, &device_info));
|
| - EXPECT_EQ(GetDeviceId(kDeviceNoDCIM), device_info.device_id);
|
| - EXPECT_EQ(test_path_b.value(), device_info.location);
|
| - EXPECT_EQ(GetDeviceName(kDeviceNoDCIM), device_info.name);
|
| -
|
| - EXPECT_TRUE(notifier()->GetStorageInfoForPath(test_path_c, &device_info));
|
| - EXPECT_EQ(GetDeviceId(kDeviceFixed), device_info.device_id);
|
| - EXPECT_EQ(test_path_c.value(), device_info.location);
|
| - EXPECT_EQ(GetDeviceName(kDeviceFixed), device_info.name);
|
| -
|
| - // An invalid path.
|
| - EXPECT_FALSE(
|
| - notifier()->GetStorageInfoForPath(base::FilePath(kInvalidPath), NULL));
|
| -
|
| - // Test filling in of the mount point.
|
| - EXPECT_TRUE(
|
| - notifier()->GetStorageInfoForPath(test_path_a.Append("some/other/path"),
|
| - &device_info));
|
| - EXPECT_EQ(GetDeviceId(kDeviceDCIM1), device_info.device_id);
|
| - EXPECT_EQ(test_path_a.value(), device_info.location);
|
| - EXPECT_EQ(GetDeviceName(kDeviceDCIM1), device_info.name);
|
| -
|
| - // One device attached at multiple points.
|
| - // kDeviceDCIM1 -> kMountPointA *
|
| - // kDeviceFixed -> kMountPointB
|
| - // kDeviceFixed -> kMountPointC
|
| - MtabTestData test_data2[] = {
|
| - MtabTestData(kDeviceDCIM1, test_path_a.value(), kValidFS),
|
| - MtabTestData(kDeviceFixed, test_path_b.value(), kValidFS),
|
| - MtabTestData(kDeviceFixed, test_path_c.value(), kValidFS),
|
| - };
|
| - AppendToMtabAndRunLoop(test_data2, arraysize(test_data2));
|
| -
|
| - EXPECT_TRUE(notifier()->GetStorageInfoForPath(test_path_a, &device_info));
|
| - EXPECT_EQ(GetDeviceId(kDeviceDCIM1), device_info.device_id);
|
| -
|
| - EXPECT_TRUE(notifier()->GetStorageInfoForPath(test_path_b, &device_info));
|
| - EXPECT_EQ(GetDeviceId(kDeviceFixed), device_info.device_id);
|
| -
|
| - EXPECT_TRUE(notifier()->GetStorageInfoForPath(test_path_c, &device_info));
|
| - EXPECT_EQ(GetDeviceId(kDeviceFixed), device_info.device_id);
|
| -
|
| - EXPECT_EQ(2, observer().attach_calls());
|
| - EXPECT_EQ(1, observer().detach_calls());
|
| -}
|
| -
|
| -TEST_F(RemovableDeviceNotificationLinuxTest, DevicePartitionSize) {
|
| - base::FilePath test_path_a = CreateMountPointWithDCIMDir(kMountPointA);
|
| - base::FilePath test_path_b = CreateMountPointWithoutDCIMDir(kMountPointB);
|
| - ASSERT_FALSE(test_path_a.empty());
|
| - ASSERT_FALSE(test_path_b.empty());
|
| -
|
| - MtabTestData test_data1[] = {
|
| - MtabTestData(kDeviceDCIM1, test_path_a.value(), kValidFS),
|
| - MtabTestData(kDeviceNoDCIM, test_path_b.value(), kValidFS),
|
| - MtabTestData(kDeviceFixed, kInvalidPath, kInvalidFS),
|
| - };
|
| - AppendToMtabAndRunLoop(test_data1, arraysize(test_data1));
|
| - EXPECT_EQ(2, observer().attach_calls());
|
| - EXPECT_EQ(0, observer().detach_calls());
|
| -
|
| - EXPECT_EQ(GetDevicePartitionSize(kDeviceDCIM1),
|
| - notifier()->GetStorageSize(test_path_a.value()));
|
| - EXPECT_EQ(GetDevicePartitionSize(kDeviceNoDCIM),
|
| - notifier()->GetStorageSize(test_path_b.value()));
|
| - EXPECT_EQ(GetDevicePartitionSize(kInvalidPath),
|
| - notifier()->GetStorageSize(kInvalidPath));
|
| -}
|
| -
|
| -} // namespace
|
| -
|
| -} // namespace chrome
|
|
|