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.
7 #include "base/file_util.h"
8 #include "base/files/scoped_temp_dir.h"
9 #include "base/run_loop.h"
10 #include "base/strings/utf_string_conversions.h"
11 #include "base/synchronization/waitable_event.h"
12 #include "chrome/browser/storage_monitor/media_storage_util.h"
13 #include "chrome/browser/storage_monitor/removable_device_constants.h"
14 #include "chrome/browser/storage_monitor/storage_monitor.h"
15 #include "chrome/browser/storage_monitor/test_storage_monitor.h"
16 #include "chrome/test/base/testing_browser_process.h"
17 #include "content/public/browser/browser_thread.h"
18 #include "content/public/test/test_browser_thread_bundle.h"
19 #include "testing/gtest/include/gtest/gtest.h"
23 const char kImageCaptureDeviceId
[] = "ic:xyz";
27 using content::BrowserThread
;
29 class MediaStorageUtilTest
: public testing::Test
{
31 MediaStorageUtilTest()
32 : thread_bundle_(content::TestBrowserThreadBundle::REAL_FILE_THREAD
) {}
33 virtual ~MediaStorageUtilTest() {}
35 // Verify mounted device type.
36 void CheckDCIMDeviceType(const base::FilePath
& mount_point
) {
37 EXPECT_TRUE(MediaStorageUtil::HasDcim(mount_point
));
40 void CheckNonDCIMDeviceType(const base::FilePath
& mount_point
) {
41 EXPECT_FALSE(MediaStorageUtil::HasDcim(mount_point
));
44 void ProcessAttach(const std::string
& id
,
45 const base::string16
& name
,
46 const base::FilePath::StringType
& location
) {
47 StorageInfo
info(id
, name
, location
, base::string16(), base::string16(),
49 monitor_
->receiver()->ProcessAttach(info
);
53 // Create mount point for the test device.
54 base::FilePath
CreateMountPoint(bool create_dcim_dir
) {
55 base::FilePath
path(scoped_temp_dir_
.path());
57 path
= path
.Append(kDCIMDirectoryName
);
58 if (!base::CreateDirectory(path
))
59 return base::FilePath();
60 return scoped_temp_dir_
.path();
63 virtual void SetUp() OVERRIDE
{
64 monitor_
= TestStorageMonitor::CreateAndInstall();
65 ASSERT_TRUE(scoped_temp_dir_
.CreateUniqueTempDir());
68 virtual void TearDown() OVERRIDE
{
70 TestStorageMonitor::RemoveSingleton();
73 static void PostQuitToUIThread() {
74 BrowserThread::PostTask(BrowserThread::UI
,
76 base::MessageLoop::QuitClosure());
79 static void WaitForFileThread() {
80 BrowserThread::PostTask(BrowserThread::FILE,
82 base::Bind(&PostQuitToUIThread
));
83 base::MessageLoop::current()->Run();
87 content::TestBrowserThreadBundle thread_bundle_
;
88 TestStorageMonitor
* monitor_
;
89 base::ScopedTempDir scoped_temp_dir_
;
92 // Test to verify that HasDcim() function returns true for the given media
93 // device mount point.
94 TEST_F(MediaStorageUtilTest
, MediaDeviceAttached
) {
95 // Create a dummy mount point with DCIM Directory.
96 base::FilePath
mount_point(CreateMountPoint(true));
97 ASSERT_FALSE(mount_point
.empty());
98 BrowserThread::PostTask(
99 BrowserThread::FILE, FROM_HERE
,
100 base::Bind(&MediaStorageUtilTest::CheckDCIMDeviceType
,
101 base::Unretained(this), mount_point
));
102 base::RunLoop().RunUntilIdle();
105 // Test to verify that HasDcim() function returns false for a given non-media
106 // device mount point.
107 TEST_F(MediaStorageUtilTest
, NonMediaDeviceAttached
) {
108 // Create a dummy mount point without DCIM Directory.
109 base::FilePath
mount_point(CreateMountPoint(false));
110 ASSERT_FALSE(mount_point
.empty());
111 BrowserThread::PostTask(
112 BrowserThread::FILE, FROM_HERE
,
113 base::Bind(&MediaStorageUtilTest::CheckNonDCIMDeviceType
,
114 base::Unretained(this), mount_point
));
115 base::RunLoop().RunUntilIdle();
118 TEST_F(MediaStorageUtilTest
, CanCreateFileSystemForImageCapture
) {
119 EXPECT_TRUE(MediaStorageUtil::CanCreateFileSystem(kImageCaptureDeviceId
,
121 EXPECT_FALSE(MediaStorageUtil::CanCreateFileSystem(
122 "dcim:xyz", base::FilePath(FILE_PATH_LITERAL("relative"))));
123 EXPECT_FALSE(MediaStorageUtil::CanCreateFileSystem(
124 "dcim:xyz", base::FilePath(FILE_PATH_LITERAL("../refparent"))));
127 TEST_F(MediaStorageUtilTest
, DetectDeviceFiltered
) {
128 MediaStorageUtil::DeviceIdSet devices
;
129 devices
.insert(kImageCaptureDeviceId
);
131 base::WaitableEvent
event(true, false);
132 base::Closure signal_event
=
133 base::Bind(&base::WaitableEvent::Signal
, base::Unretained(&event
));
135 // We need signal_event to be executed on the FILE thread, as the test thread
136 // is blocked. Therefore, we invoke FilterAttachedDevices on the FILE thread.
137 BrowserThread::PostTask(BrowserThread::FILE, FROM_HERE
,
138 base::Bind(&MediaStorageUtil::FilterAttachedDevices
,
139 base::Unretained(&devices
), signal_event
));
141 EXPECT_FALSE(devices
.find(kImageCaptureDeviceId
) != devices
.end());
143 ProcessAttach(kImageCaptureDeviceId
, base::ASCIIToUTF16("name"),
144 FILE_PATH_LITERAL("/location"));
145 devices
.insert(kImageCaptureDeviceId
);
147 BrowserThread::PostTask(BrowserThread::FILE, FROM_HERE
,
148 base::Bind(&MediaStorageUtil::FilterAttachedDevices
,
149 base::Unretained(&devices
), signal_event
));
152 EXPECT_TRUE(devices
.find(kImageCaptureDeviceId
) != devices
.end());