blob: 073dbae99975b59213361869b02feea6041909f8 [file] [log] [blame]
brettw@chromium.org86aca862009-10-09 02:38:30 +09001// Copyright (c) 2009 The Chromium Authors. All rights reserved.
license.botf003cfe2008-08-24 09:55:55 +09002// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
initial.commit3f4a7322008-07-27 06:49:38 +09004
erikkay@google.comc8ec9e92008-08-16 02:50:10 +09005#include "build/build_config.h"
6
erikkay@google.com014161d2008-08-16 02:45:13 +09007#if defined(OS_WIN)
initial.commit3f4a7322008-07-27 06:49:38 +09008#include <windows.h>
initial.commit3f4a7322008-07-27 06:49:38 +09009#include <shellapi.h>
10#include <shlobj.h>
tkent@chromium.org8da14162009-10-09 16:33:39 +090011#include <tchar.h>
erikkay@google.comdfb51b22008-08-16 02:32:10 +090012#endif
initial.commit3f4a7322008-07-27 06:49:38 +090013
14#include <fstream>
15#include <iostream>
erikkay@google.comdfb51b22008-08-16 02:32:10 +090016#include <set>
initial.commit3f4a7322008-07-27 06:49:38 +090017
18#include "base/base_paths.h"
evanm@google.com874d1672008-10-31 08:54:04 +090019#include "base/file_path.h"
initial.commit3f4a7322008-07-27 06:49:38 +090020#include "base/file_util.h"
21#include "base/logging.h"
22#include "base/path_service.h"
erikkay@google.com8d133f62009-04-24 00:05:19 +090023#include "base/platform_thread.h"
erikkay@google.com9ac26762009-04-18 09:42:48 +090024#include "base/time.h"
brettw@chromium.org50c94652009-10-07 11:10:20 +090025#include "base/utf_string_conversions.h"
initial.commit3f4a7322008-07-27 06:49:38 +090026#include "testing/gtest/include/gtest/gtest.h"
jeremy@chromium.org0d8eba72008-12-03 04:20:15 +090027#include "testing/platform_test.h"
initial.commit3f4a7322008-07-27 06:49:38 +090028
phajdan.jr@chromium.orgf9908a72009-04-04 02:17:58 +090029// This macro helps avoid wrapped lines in the test structs.
30#define FPL(x) FILE_PATH_LITERAL(x)
31
initial.commit3f4a7322008-07-27 06:49:38 +090032namespace {
33
yuzo@chromium.org2da0f822009-06-09 14:57:38 +090034const file_util::FileEnumerator::FILE_TYPE FILES_AND_DIRECTORIES =
35 static_cast<file_util::FileEnumerator::FILE_TYPE>(
36 file_util::FileEnumerator::FILES |
37 file_util::FileEnumerator::DIRECTORIES);
38
erikkay@google.comf2406842008-08-21 00:59:49 +090039// file_util winds up using autoreleased objects on the Mac, so this needs
40// to be a PlatformTest
41class FileUtilTest : public PlatformTest {
initial.commit3f4a7322008-07-27 06:49:38 +090042 protected:
43 virtual void SetUp() {
erikkay@google.comf2406842008-08-21 00:59:49 +090044 PlatformTest::SetUp();
initial.commit3f4a7322008-07-27 06:49:38 +090045 // Name a subdirectory of the temp directory.
46 ASSERT_TRUE(PathService::Get(base::DIR_TEMP, &test_dir_));
evanm@google.com874d1672008-10-31 08:54:04 +090047 test_dir_ = test_dir_.Append(FILE_PATH_LITERAL("FileUtilTest"));
initial.commit3f4a7322008-07-27 06:49:38 +090048
49 // Create a fresh, empty copy of this directory.
50 file_util::Delete(test_dir_, true);
evanm@google.com874d1672008-10-31 08:54:04 +090051 file_util::CreateDirectory(test_dir_);
initial.commit3f4a7322008-07-27 06:49:38 +090052 }
53 virtual void TearDown() {
erikkay@google.comf2406842008-08-21 00:59:49 +090054 PlatformTest::TearDown();
initial.commit3f4a7322008-07-27 06:49:38 +090055 // Clean up test directory
erikkay@google.comdfb51b22008-08-16 02:32:10 +090056 ASSERT_TRUE(file_util::Delete(test_dir_, true));
initial.commit3f4a7322008-07-27 06:49:38 +090057 ASSERT_FALSE(file_util::PathExists(test_dir_));
58 }
59
60 // the path to temporary directory used to contain the test operations
evanm@google.com874d1672008-10-31 08:54:04 +090061 FilePath test_dir_;
initial.commit3f4a7322008-07-27 06:49:38 +090062};
63
64// Collects all the results from the given file enumerator, and provides an
65// interface to query whether a given file is present.
66class FindResultCollector {
67 public:
evan@chromium.org1543ad32009-08-27 05:00:14 +090068 explicit FindResultCollector(file_util::FileEnumerator& enumerator) {
avi@google.com5cb79352008-12-11 23:55:12 +090069 FilePath cur_file;
70 while (!(cur_file = enumerator.Next()).value().empty()) {
71 FilePath::StringType path = cur_file.value();
initial.commit3f4a7322008-07-27 06:49:38 +090072 // The file should not be returned twice.
evanm@google.com874d1672008-10-31 08:54:04 +090073 EXPECT_TRUE(files_.end() == files_.find(path))
initial.commit3f4a7322008-07-27 06:49:38 +090074 << "Same file returned twice";
75
76 // Save for later.
evanm@google.com874d1672008-10-31 08:54:04 +090077 files_.insert(path);
initial.commit3f4a7322008-07-27 06:49:38 +090078 }
79 }
80
81 // Returns true if the enumerator found the file.
evanm@google.com874d1672008-10-31 08:54:04 +090082 bool HasFile(const FilePath& file) const {
83 return files_.find(file.value()) != files_.end();
initial.commit3f4a7322008-07-27 06:49:38 +090084 }
evanm@google.com874d1672008-10-31 08:54:04 +090085
erikkay@google.comdfb51b22008-08-16 02:32:10 +090086 int size() {
erikkay@google.comc8ec9e92008-08-16 02:50:10 +090087 return static_cast<int>(files_.size());
erikkay@google.comdfb51b22008-08-16 02:32:10 +090088 }
initial.commit3f4a7322008-07-27 06:49:38 +090089
90 private:
evanm@google.com874d1672008-10-31 08:54:04 +090091 std::set<FilePath::StringType> files_;
initial.commit3f4a7322008-07-27 06:49:38 +090092};
93
94// Simple function to dump some text into a new file.
evanm@google.com874d1672008-10-31 08:54:04 +090095void CreateTextFile(const FilePath& filename,
initial.commit3f4a7322008-07-27 06:49:38 +090096 const std::wstring& contents) {
97 std::ofstream file;
evanm@google.com874d1672008-10-31 08:54:04 +090098 file.open(WideToUTF8(filename.ToWStringHack()).c_str());
initial.commit3f4a7322008-07-27 06:49:38 +090099 ASSERT_TRUE(file.is_open());
100 file << contents;
101 file.close();
102}
103
104// Simple function to take out some text from a file.
evanm@google.com874d1672008-10-31 08:54:04 +0900105std::wstring ReadTextFile(const FilePath& filename) {
erikkay@google.comdfb51b22008-08-16 02:32:10 +0900106 wchar_t contents[64];
initial.commit3f4a7322008-07-27 06:49:38 +0900107 std::wifstream file;
evanm@google.com874d1672008-10-31 08:54:04 +0900108 file.open(WideToUTF8(filename.ToWStringHack()).c_str());
initial.commit3f4a7322008-07-27 06:49:38 +0900109 EXPECT_TRUE(file.is_open());
110 file.getline(contents, 64);
111 file.close();
112 return std::wstring(contents);
113}
114
erikkay@google.com014161d2008-08-16 02:45:13 +0900115#if defined(OS_WIN)
initial.commit3f4a7322008-07-27 06:49:38 +0900116uint64 FileTimeAsUint64(const FILETIME& ft) {
117 ULARGE_INTEGER u;
118 u.LowPart = ft.dwLowDateTime;
119 u.HighPart = ft.dwHighDateTime;
120 return u.QuadPart;
121}
erikkay@google.comdfb51b22008-08-16 02:32:10 +0900122#endif
initial.commit3f4a7322008-07-27 06:49:38 +0900123
124const struct append_case {
125 const wchar_t* path;
126 const wchar_t* ending;
127 const wchar_t* result;
128} append_cases[] = {
erikkay@google.com014161d2008-08-16 02:45:13 +0900129#if defined(OS_WIN)
initial.commit3f4a7322008-07-27 06:49:38 +0900130 {L"c:\\colon\\backslash", L"path", L"c:\\colon\\backslash\\path"},
131 {L"c:\\colon\\backslash\\", L"path", L"c:\\colon\\backslash\\path"},
132 {L"c:\\colon\\backslash\\\\", L"path", L"c:\\colon\\backslash\\\\path"},
133 {L"c:\\colon\\backslash\\", L"", L"c:\\colon\\backslash\\"},
134 {L"c:\\colon\\backslash", L"", L"c:\\colon\\backslash\\"},
135 {L"", L"path", L"\\path"},
136 {L"", L"", L"\\"},
erikkay@google.comdfb51b22008-08-16 02:32:10 +0900137#elif defined(OS_POSIX)
138 {L"/foo/bar", L"path", L"/foo/bar/path"},
139 {L"/foo/bar/", L"path", L"/foo/bar/path"},
140 {L"/foo/bar//", L"path", L"/foo/bar//path"},
141 {L"/foo/bar/", L"", L"/foo/bar/"},
142 {L"/foo/bar", L"", L"/foo/bar/"},
143 {L"", L"path", L"/path"},
144 {L"", L"", L"/"},
145#endif
initial.commit3f4a7322008-07-27 06:49:38 +0900146};
147
initial.commit3f4a7322008-07-27 06:49:38 +0900148TEST_F(FileUtilTest, AppendToPath) {
erikkay@google.comdfb51b22008-08-16 02:32:10 +0900149 for (unsigned int i = 0; i < arraysize(append_cases); ++i) {
initial.commit3f4a7322008-07-27 06:49:38 +0900150 const append_case& value = append_cases[i];
151 std::wstring result = value.path;
152 file_util::AppendToPath(&result, value.ending);
153 EXPECT_EQ(value.result, result);
154 }
155
156#ifdef NDEBUG
157 file_util::AppendToPath(NULL, L"path"); // asserts in debug mode
158#endif
159}
160
161static const struct InsertBeforeExtensionCase {
phajdan.jr@chromium.orgf9908a72009-04-04 02:17:58 +0900162 const FilePath::CharType* path;
163 const FilePath::CharType* suffix;
164 const FilePath::CharType* result;
initial.commit3f4a7322008-07-27 06:49:38 +0900165} kInsertBeforeExtension[] = {
phajdan.jr@chromium.orgf9908a72009-04-04 02:17:58 +0900166 {FPL(""), FPL(""), FPL("")},
167 {FPL(""), FPL("txt"), FPL("txt")},
168 {FPL("."), FPL("txt"), FPL("txt.")},
169 {FPL("."), FPL(""), FPL(".")},
170 {FPL("foo.dll"), FPL("txt"), FPL("footxt.dll")},
171 {FPL("foo.dll"), FPL(".txt"), FPL("foo.txt.dll")},
172 {FPL("foo"), FPL("txt"), FPL("footxt")},
173 {FPL("foo"), FPL(".txt"), FPL("foo.txt")},
174 {FPL("foo.baz.dll"), FPL("txt"), FPL("foo.baztxt.dll")},
175 {FPL("foo.baz.dll"), FPL(".txt"), FPL("foo.baz.txt.dll")},
176 {FPL("foo.dll"), FPL(""), FPL("foo.dll")},
177 {FPL("foo.dll"), FPL("."), FPL("foo..dll")},
178 {FPL("foo"), FPL(""), FPL("foo")},
179 {FPL("foo"), FPL("."), FPL("foo.")},
180 {FPL("foo.baz.dll"), FPL(""), FPL("foo.baz.dll")},
181 {FPL("foo.baz.dll"), FPL("."), FPL("foo.baz..dll")},
erikkay@google.com014161d2008-08-16 02:45:13 +0900182#if defined(OS_WIN)
phajdan.jr@chromium.orgf9908a72009-04-04 02:17:58 +0900183 {FPL("\\"), FPL(""), FPL("\\")},
184 {FPL("\\"), FPL("txt"), FPL("\\txt")},
185 {FPL("\\."), FPL("txt"), FPL("\\txt.")},
186 {FPL("\\."), FPL(""), FPL("\\.")},
187 {FPL("C:\\bar\\foo.dll"), FPL("txt"), FPL("C:\\bar\\footxt.dll")},
188 {FPL("C:\\bar.baz\\foodll"), FPL("txt"), FPL("C:\\bar.baz\\foodlltxt")},
189 {FPL("C:\\bar.baz\\foo.dll"), FPL("txt"), FPL("C:\\bar.baz\\footxt.dll")},
190 {FPL("C:\\bar.baz\\foo.dll.exe"), FPL("txt"),
191 FPL("C:\\bar.baz\\foo.dlltxt.exe")},
192 {FPL("C:\\bar.baz\\foo"), FPL(""), FPL("C:\\bar.baz\\foo")},
193 {FPL("C:\\bar.baz\\foo.exe"), FPL(""), FPL("C:\\bar.baz\\foo.exe")},
194 {FPL("C:\\bar.baz\\foo.dll.exe"), FPL(""), FPL("C:\\bar.baz\\foo.dll.exe")},
195 {FPL("C:\\bar\\baz\\foo.exe"), FPL(" (1)"), FPL("C:\\bar\\baz\\foo (1).exe")},
erikkay@google.comdfb51b22008-08-16 02:32:10 +0900196#elif defined(OS_POSIX)
phajdan.jr@chromium.orgf9908a72009-04-04 02:17:58 +0900197 {FPL("/"), FPL(""), FPL("/")},
198 {FPL("/"), FPL("txt"), FPL("/txt")},
199 {FPL("/."), FPL("txt"), FPL("/txt.")},
200 {FPL("/."), FPL(""), FPL("/.")},
201 {FPL("/bar/foo.dll"), FPL("txt"), FPL("/bar/footxt.dll")},
202 {FPL("/bar.baz/foodll"), FPL("txt"), FPL("/bar.baz/foodlltxt")},
203 {FPL("/bar.baz/foo.dll"), FPL("txt"), FPL("/bar.baz/footxt.dll")},
204 {FPL("/bar.baz/foo.dll.exe"), FPL("txt"), FPL("/bar.baz/foo.dlltxt.exe")},
205 {FPL("/bar.baz/foo"), FPL(""), FPL("/bar.baz/foo")},
206 {FPL("/bar.baz/foo.exe"), FPL(""), FPL("/bar.baz/foo.exe")},
207 {FPL("/bar.baz/foo.dll.exe"), FPL(""), FPL("/bar.baz/foo.dll.exe")},
208 {FPL("/bar/baz/foo.exe"), FPL(" (1)"), FPL("/bar/baz/foo (1).exe")},
erikkay@google.comdfb51b22008-08-16 02:32:10 +0900209#endif
initial.commit3f4a7322008-07-27 06:49:38 +0900210};
211
212TEST_F(FileUtilTest, InsertBeforeExtensionTest) {
erikkay@google.comdfb51b22008-08-16 02:32:10 +0900213 for (unsigned int i = 0; i < arraysize(kInsertBeforeExtension); ++i) {
phajdan.jr@chromium.orgf9908a72009-04-04 02:17:58 +0900214 FilePath path(kInsertBeforeExtension[i].path);
initial.commit3f4a7322008-07-27 06:49:38 +0900215 file_util::InsertBeforeExtension(&path, kInsertBeforeExtension[i].suffix);
phajdan.jr@chromium.orgf9908a72009-04-04 02:17:58 +0900216 EXPECT_EQ(kInsertBeforeExtension[i].result, path.value());
initial.commit3f4a7322008-07-27 06:49:38 +0900217 }
218}
219
220static const struct filename_case {
221 const wchar_t* path;
222 const wchar_t* filename;
223} filename_cases[] = {
erikkay@google.com014161d2008-08-16 02:45:13 +0900224#if defined(OS_WIN)
initial.commit3f4a7322008-07-27 06:49:38 +0900225 {L"c:\\colon\\backslash", L"backslash"},
226 {L"c:\\colon\\backslash\\", L""},
227 {L"\\\\filename.exe", L"filename.exe"},
228 {L"filename.exe", L"filename.exe"},
229 {L"", L""},
230 {L"\\\\\\", L""},
231 {L"c:/colon/backslash", L"backslash"},
232 {L"c:/colon/backslash/", L""},
233 {L"//////", L""},
234 {L"///filename.exe", L"filename.exe"},
erikkay@google.comdfb51b22008-08-16 02:32:10 +0900235#elif defined(OS_POSIX)
236 {L"/foo/bar", L"bar"},
237 {L"/foo/bar/", L""},
238 {L"/filename.exe", L"filename.exe"},
239 {L"filename.exe", L"filename.exe"},
240 {L"", L""},
241 {L"/", L""},
242#endif
initial.commit3f4a7322008-07-27 06:49:38 +0900243};
244
245TEST_F(FileUtilTest, GetFilenameFromPath) {
erikkay@google.comdfb51b22008-08-16 02:32:10 +0900246 for (unsigned int i = 0; i < arraysize(filename_cases); ++i) {
initial.commit3f4a7322008-07-27 06:49:38 +0900247 const filename_case& value = filename_cases[i];
248 std::wstring result = file_util::GetFilenameFromPath(value.path);
249 EXPECT_EQ(value.filename, result);
250 }
251}
252
253// Test finding the file type from a path name
254static const struct extension_case {
255 const wchar_t* path;
256 const wchar_t* extension;
257} extension_cases[] = {
erikkay@google.com014161d2008-08-16 02:45:13 +0900258#if defined(OS_WIN)
initial.commit3f4a7322008-07-27 06:49:38 +0900259 {L"C:\\colon\\backslash\\filename.extension", L"extension"},
260 {L"C:\\colon\\backslash\\filename.", L""},
261 {L"C:\\colon\\backslash\\filename", L""},
262 {L"C:\\colon\\backslash\\", L""},
263 {L"C:\\colon\\backslash.\\", L""},
264 {L"C:\\colon\\backslash\filename.extension.extension2", L"extension2"},
erikkay@google.comdfb51b22008-08-16 02:32:10 +0900265#elif defined(OS_POSIX)
266 {L"/foo/bar/filename.extension", L"extension"},
267 {L"/foo/bar/filename.", L""},
268 {L"/foo/bar/filename", L""},
269 {L"/foo/bar/", L""},
270 {L"/foo/bar./", L""},
271 {L"/foo/bar/filename.extension.extension2", L"extension2"},
272 {L".", L""},
273 {L"..", L""},
274 {L"./foo", L""},
275 {L"./foo.extension", L"extension"},
276 {L"/foo.extension1/bar.extension2", L"extension2"},
277#endif
initial.commit3f4a7322008-07-27 06:49:38 +0900278};
279
280TEST_F(FileUtilTest, GetFileExtensionFromPath) {
erikkay@google.comdfb51b22008-08-16 02:32:10 +0900281 for (unsigned int i = 0; i < arraysize(extension_cases); ++i) {
initial.commit3f4a7322008-07-27 06:49:38 +0900282 const extension_case& ext = extension_cases[i];
283 const std::wstring fext = file_util::GetFileExtensionFromPath(ext.path);
284 EXPECT_EQ(ext.extension, fext);
285 }
286}
287
288// Test finding the directory component of a path
289static const struct dir_case {
290 const wchar_t* full_path;
291 const wchar_t* directory;
292} dir_cases[] = {
erikkay@google.com014161d2008-08-16 02:45:13 +0900293#if defined(OS_WIN)
initial.commit3f4a7322008-07-27 06:49:38 +0900294 {L"C:\\WINDOWS\\system32\\gdi32.dll", L"C:\\WINDOWS\\system32"},
295 {L"C:\\WINDOWS\\system32\\not_exist_thx_1138", L"C:\\WINDOWS\\system32"},
296 {L"C:\\WINDOWS\\system32\\", L"C:\\WINDOWS\\system32"},
297 {L"C:\\WINDOWS\\system32\\\\", L"C:\\WINDOWS\\system32"},
298 {L"C:\\WINDOWS\\system32", L"C:\\WINDOWS"},
299 {L"C:\\WINDOWS\\system32.\\", L"C:\\WINDOWS\\system32."},
300 {L"C:\\", L"C:"},
erikkay@google.comdfb51b22008-08-16 02:32:10 +0900301#elif defined(OS_POSIX)
302 {L"/foo/bar/gdi32.dll", L"/foo/bar"},
303 {L"/foo/bar/not_exist_thx_1138", L"/foo/bar"},
304 {L"/foo/bar/", L"/foo/bar"},
305 {L"/foo/bar//", L"/foo/bar"},
306 {L"/foo/bar", L"/foo"},
307 {L"/foo/bar./", L"/foo/bar."},
308 {L"/", L"/"},
309 {L".", L"."},
evan@chromium.org1543ad32009-08-27 05:00:14 +0900310 {L"..", L"."}, // yes, ".." technically lives in "."
erikkay@google.comdfb51b22008-08-16 02:32:10 +0900311#endif
initial.commit3f4a7322008-07-27 06:49:38 +0900312};
313
314TEST_F(FileUtilTest, GetDirectoryFromPath) {
erikkay@google.comdfb51b22008-08-16 02:32:10 +0900315 for (unsigned int i = 0; i < arraysize(dir_cases); ++i) {
initial.commit3f4a7322008-07-27 06:49:38 +0900316 const dir_case& dir = dir_cases[i];
317 const std::wstring parent =
318 file_util::GetDirectoryFromPath(dir.full_path);
319 EXPECT_EQ(dir.directory, parent);
320 }
321}
322
323TEST_F(FileUtilTest, CountFilesCreatedAfter) {
324 // Create old file (that we don't want to count)
erikkay@google.com9ac26762009-04-18 09:42:48 +0900325 FilePath old_file_name = test_dir_.Append(FILE_PATH_LITERAL("Old File.txt"));
initial.commit3f4a7322008-07-27 06:49:38 +0900326 CreateTextFile(old_file_name, L"Just call me Mr. Creakybits");
327
328 // Age to perfection
evan@chromium.org37301322009-04-21 10:50:39 +0900329#if defined(OS_WIN)
erikkay@google.com8d133f62009-04-24 00:05:19 +0900330 PlatformThread::Sleep(100);
evan@chromium.org37301322009-04-21 10:50:39 +0900331#elif defined(OS_POSIX)
332 // We need to wait at least one second here because the precision of
333 // file creation time is one second.
erikkay@google.com8d133f62009-04-24 00:05:19 +0900334 PlatformThread::Sleep(1500);
evan@chromium.org37301322009-04-21 10:50:39 +0900335#endif
initial.commit3f4a7322008-07-27 06:49:38 +0900336
337 // Establish our cutoff time
erikkay@google.com9ac26762009-04-18 09:42:48 +0900338 base::Time now(base::Time::NowFromSystemTime());
339 EXPECT_EQ(0, file_util::CountFilesCreatedAfter(test_dir_, now));
initial.commit3f4a7322008-07-27 06:49:38 +0900340
341 // Create a new file (that we do want to count)
erikkay@google.com9ac26762009-04-18 09:42:48 +0900342 FilePath new_file_name = test_dir_.Append(FILE_PATH_LITERAL("New File.txt"));
initial.commit3f4a7322008-07-27 06:49:38 +0900343 CreateTextFile(new_file_name, L"Waaaaaaaaaaaaaah.");
344
345 // We should see only the new file.
erikkay@google.com9ac26762009-04-18 09:42:48 +0900346 EXPECT_EQ(1, file_util::CountFilesCreatedAfter(test_dir_, now));
initial.commit3f4a7322008-07-27 06:49:38 +0900347
348 // Delete new file, we should see no files after cutoff now
349 EXPECT_TRUE(file_util::Delete(new_file_name, false));
erikkay@google.com9ac26762009-04-18 09:42:48 +0900350 EXPECT_EQ(0, file_util::CountFilesCreatedAfter(test_dir_, now));
initial.commit3f4a7322008-07-27 06:49:38 +0900351}
352
353// Tests that the Delete function works as expected, especially
354// the recursion flag. Also coincidentally tests PathExists.
355TEST_F(FileUtilTest, Delete) {
356 // Create a file
evanm@google.com874d1672008-10-31 08:54:04 +0900357 FilePath file_name = test_dir_.Append(FILE_PATH_LITERAL("Test File.txt"));
initial.commit3f4a7322008-07-27 06:49:38 +0900358 CreateTextFile(file_name, L"I'm cannon fodder.");
359
360 ASSERT_TRUE(file_util::PathExists(file_name));
361
evanm@google.com874d1672008-10-31 08:54:04 +0900362 FilePath subdir_path = test_dir_.Append(FILE_PATH_LITERAL("Subdirectory"));
363 file_util::CreateDirectory(subdir_path);
initial.commit3f4a7322008-07-27 06:49:38 +0900364
365 ASSERT_TRUE(file_util::PathExists(subdir_path));
366
evanm@google.com874d1672008-10-31 08:54:04 +0900367 FilePath directory_contents = test_dir_;
erikkay@google.com014161d2008-08-16 02:45:13 +0900368#if defined(OS_WIN)
erikkay@google.comdfb51b22008-08-16 02:32:10 +0900369 // TODO(erikkay): see if anyone's actually using this feature of the API
evanm@google.com874d1672008-10-31 08:54:04 +0900370 directory_contents = directory_contents.Append(FILE_PATH_LITERAL("*"));
initial.commit3f4a7322008-07-27 06:49:38 +0900371 // Delete non-recursively and check that only the file is deleted
372 ASSERT_TRUE(file_util::Delete(directory_contents, false));
erikkay@google.comdfb51b22008-08-16 02:32:10 +0900373 EXPECT_FALSE(file_util::PathExists(file_name));
374 EXPECT_TRUE(file_util::PathExists(subdir_path));
375#endif
initial.commit3f4a7322008-07-27 06:49:38 +0900376
377 // Delete recursively and make sure all contents are deleted
378 ASSERT_TRUE(file_util::Delete(directory_contents, true));
erikkay@google.comdfb51b22008-08-16 02:32:10 +0900379 EXPECT_FALSE(file_util::PathExists(file_name));
380 EXPECT_FALSE(file_util::PathExists(subdir_path));
initial.commit3f4a7322008-07-27 06:49:38 +0900381}
382
383TEST_F(FileUtilTest, Move) {
384 // Create a directory
evanm@google.com874d1672008-10-31 08:54:04 +0900385 FilePath dir_name_from =
386 test_dir_.Append(FILE_PATH_LITERAL("Move_From_Subdir"));
387 file_util::CreateDirectory(dir_name_from);
initial.commit3f4a7322008-07-27 06:49:38 +0900388 ASSERT_TRUE(file_util::PathExists(dir_name_from));
389
390 // Create a file under the directory
evanm@google.com874d1672008-10-31 08:54:04 +0900391 FilePath file_name_from =
392 dir_name_from.Append(FILE_PATH_LITERAL("Move_Test_File.txt"));
initial.commit3f4a7322008-07-27 06:49:38 +0900393 CreateTextFile(file_name_from, L"Gooooooooooooooooooooogle");
394 ASSERT_TRUE(file_util::PathExists(file_name_from));
395
396 // Move the directory
evanm@google.com874d1672008-10-31 08:54:04 +0900397 FilePath dir_name_to = test_dir_.Append(FILE_PATH_LITERAL("Move_To_Subdir"));
398 FilePath file_name_to =
399 dir_name_to.Append(FILE_PATH_LITERAL("Move_Test_File.txt"));
initial.commit3f4a7322008-07-27 06:49:38 +0900400
401 ASSERT_FALSE(file_util::PathExists(dir_name_to));
402
403 EXPECT_TRUE(file_util::Move(dir_name_from, dir_name_to));
404
405 // Check everything has been moved.
406 EXPECT_FALSE(file_util::PathExists(dir_name_from));
407 EXPECT_FALSE(file_util::PathExists(file_name_from));
408 EXPECT_TRUE(file_util::PathExists(dir_name_to));
409 EXPECT_TRUE(file_util::PathExists(file_name_to));
410}
411
412TEST_F(FileUtilTest, CopyDirectoryRecursively) {
413 // Create a directory.
evanm@google.com874d1672008-10-31 08:54:04 +0900414 FilePath dir_name_from =
415 test_dir_.Append(FILE_PATH_LITERAL("Copy_From_Subdir"));
416 file_util::CreateDirectory(dir_name_from);
initial.commit3f4a7322008-07-27 06:49:38 +0900417 ASSERT_TRUE(file_util::PathExists(dir_name_from));
418
419 // Create a file under the directory.
evanm@google.com874d1672008-10-31 08:54:04 +0900420 FilePath file_name_from =
421 dir_name_from.Append(FILE_PATH_LITERAL("Copy_Test_File.txt"));
initial.commit3f4a7322008-07-27 06:49:38 +0900422 CreateTextFile(file_name_from, L"Gooooooooooooooooooooogle");
423 ASSERT_TRUE(file_util::PathExists(file_name_from));
424
425 // Create a subdirectory.
evanm@google.com874d1672008-10-31 08:54:04 +0900426 FilePath subdir_name_from =
427 dir_name_from.Append(FILE_PATH_LITERAL("Subdir"));
428 file_util::CreateDirectory(subdir_name_from);
initial.commit3f4a7322008-07-27 06:49:38 +0900429 ASSERT_TRUE(file_util::PathExists(subdir_name_from));
430
431 // Create a file under the subdirectory.
evanm@google.com874d1672008-10-31 08:54:04 +0900432 FilePath file_name2_from =
433 subdir_name_from.Append(FILE_PATH_LITERAL("Copy_Test_File.txt"));
initial.commit3f4a7322008-07-27 06:49:38 +0900434 CreateTextFile(file_name2_from, L"Gooooooooooooooooooooogle");
435 ASSERT_TRUE(file_util::PathExists(file_name2_from));
436
437 // Copy the directory recursively.
evanm@google.com874d1672008-10-31 08:54:04 +0900438 FilePath dir_name_to =
439 test_dir_.Append(FILE_PATH_LITERAL("Copy_To_Subdir"));
440 FilePath file_name_to =
441 dir_name_to.Append(FILE_PATH_LITERAL("Copy_Test_File.txt"));
442 FilePath subdir_name_to =
443 dir_name_to.Append(FILE_PATH_LITERAL("Subdir"));
444 FilePath file_name2_to =
445 subdir_name_to.Append(FILE_PATH_LITERAL("Copy_Test_File.txt"));
initial.commit3f4a7322008-07-27 06:49:38 +0900446
447 ASSERT_FALSE(file_util::PathExists(dir_name_to));
448
449 EXPECT_TRUE(file_util::CopyDirectory(dir_name_from, dir_name_to, true));
450
451 // Check everything has been copied.
452 EXPECT_TRUE(file_util::PathExists(dir_name_from));
453 EXPECT_TRUE(file_util::PathExists(file_name_from));
454 EXPECT_TRUE(file_util::PathExists(subdir_name_from));
455 EXPECT_TRUE(file_util::PathExists(file_name2_from));
456 EXPECT_TRUE(file_util::PathExists(dir_name_to));
457 EXPECT_TRUE(file_util::PathExists(file_name_to));
458 EXPECT_TRUE(file_util::PathExists(subdir_name_to));
459 EXPECT_TRUE(file_util::PathExists(file_name2_to));
460}
461
462TEST_F(FileUtilTest, CopyDirectory) {
463 // Create a directory.
evanm@google.com874d1672008-10-31 08:54:04 +0900464 FilePath dir_name_from =
465 test_dir_.Append(FILE_PATH_LITERAL("Copy_From_Subdir"));
466 file_util::CreateDirectory(dir_name_from);
initial.commit3f4a7322008-07-27 06:49:38 +0900467 ASSERT_TRUE(file_util::PathExists(dir_name_from));
468
469 // Create a file under the directory.
evanm@google.com874d1672008-10-31 08:54:04 +0900470 FilePath file_name_from =
471 dir_name_from.Append(FILE_PATH_LITERAL("Copy_Test_File.txt"));
initial.commit3f4a7322008-07-27 06:49:38 +0900472 CreateTextFile(file_name_from, L"Gooooooooooooooooooooogle");
473 ASSERT_TRUE(file_util::PathExists(file_name_from));
474
475 // Create a subdirectory.
evanm@google.com874d1672008-10-31 08:54:04 +0900476 FilePath subdir_name_from =
477 dir_name_from.Append(FILE_PATH_LITERAL("Subdir"));
478 file_util::CreateDirectory(subdir_name_from);
initial.commit3f4a7322008-07-27 06:49:38 +0900479 ASSERT_TRUE(file_util::PathExists(subdir_name_from));
480
481 // Create a file under the subdirectory.
evanm@google.com874d1672008-10-31 08:54:04 +0900482 FilePath file_name2_from =
483 subdir_name_from.Append(FILE_PATH_LITERAL("Copy_Test_File.txt"));
initial.commit3f4a7322008-07-27 06:49:38 +0900484 CreateTextFile(file_name2_from, L"Gooooooooooooooooooooogle");
485 ASSERT_TRUE(file_util::PathExists(file_name2_from));
486
487 // Copy the directory not recursively.
evanm@google.com874d1672008-10-31 08:54:04 +0900488 FilePath dir_name_to =
489 test_dir_.Append(FILE_PATH_LITERAL("Copy_To_Subdir"));
490 FilePath file_name_to =
491 dir_name_to.Append(FILE_PATH_LITERAL("Copy_Test_File.txt"));
492 FilePath subdir_name_to =
493 dir_name_to.Append(FILE_PATH_LITERAL("Subdir"));
initial.commit3f4a7322008-07-27 06:49:38 +0900494
495 ASSERT_FALSE(file_util::PathExists(dir_name_to));
496
497 EXPECT_TRUE(file_util::CopyDirectory(dir_name_from, dir_name_to, false));
498
499 // Check everything has been copied.
500 EXPECT_TRUE(file_util::PathExists(dir_name_from));
501 EXPECT_TRUE(file_util::PathExists(file_name_from));
502 EXPECT_TRUE(file_util::PathExists(subdir_name_from));
503 EXPECT_TRUE(file_util::PathExists(file_name2_from));
504 EXPECT_TRUE(file_util::PathExists(dir_name_to));
505 EXPECT_TRUE(file_util::PathExists(file_name_to));
506 EXPECT_FALSE(file_util::PathExists(subdir_name_to));
507}
508
509TEST_F(FileUtilTest, CopyFile) {
510 // Create a directory
evanm@google.com874d1672008-10-31 08:54:04 +0900511 FilePath dir_name_from =
512 test_dir_.Append(FILE_PATH_LITERAL("Copy_From_Subdir"));
513 file_util::CreateDirectory(dir_name_from);
initial.commit3f4a7322008-07-27 06:49:38 +0900514 ASSERT_TRUE(file_util::PathExists(dir_name_from));
515
516 // Create a file under the directory
evanm@google.com874d1672008-10-31 08:54:04 +0900517 FilePath file_name_from =
518 dir_name_from.Append(FILE_PATH_LITERAL("Copy_Test_File.txt"));
initial.commit3f4a7322008-07-27 06:49:38 +0900519 const std::wstring file_contents(L"Gooooooooooooooooooooogle");
520 CreateTextFile(file_name_from, file_contents);
521 ASSERT_TRUE(file_util::PathExists(file_name_from));
522
523 // Copy the file.
evanm@google.com874d1672008-10-31 08:54:04 +0900524 FilePath dest_file = dir_name_from.Append(FILE_PATH_LITERAL("DestFile.txt"));
initial.commit3f4a7322008-07-27 06:49:38 +0900525 ASSERT_TRUE(file_util::CopyFile(file_name_from, dest_file));
mmoss@google.com733df6b2008-09-12 01:09:11 +0900526
erikkay@google.comdfb51b22008-08-16 02:32:10 +0900527 // Copy the file to another location using '..' in the path.
evan@chromium.org1543ad32009-08-27 05:00:14 +0900528 FilePath dest_file2(dir_name_from);
529 dest_file2 = dest_file2.AppendASCII("..");
530 dest_file2 = dest_file2.AppendASCII("DestFile.txt");
531 ASSERT_TRUE(file_util::CopyFile(file_name_from, dest_file2));
532
533 FilePath dest_file2_test(dir_name_from);
534 dest_file2_test = dest_file2_test.DirName();
535 dest_file2_test = dest_file2_test.AppendASCII("DestFile.txt");
initial.commit3f4a7322008-07-27 06:49:38 +0900536
537 // Check everything has been copied.
538 EXPECT_TRUE(file_util::PathExists(file_name_from));
539 EXPECT_TRUE(file_util::PathExists(dest_file));
540 const std::wstring read_contents = ReadTextFile(dest_file);
541 EXPECT_EQ(file_contents, read_contents);
evan@chromium.org1543ad32009-08-27 05:00:14 +0900542 EXPECT_TRUE(file_util::PathExists(dest_file2_test));
543 EXPECT_TRUE(file_util::PathExists(dest_file2));
initial.commit3f4a7322008-07-27 06:49:38 +0900544}
545
erikkay@google.comdfb51b22008-08-16 02:32:10 +0900546// TODO(erikkay): implement
erikkay@google.com014161d2008-08-16 02:45:13 +0900547#if defined(OS_WIN)
initial.commit3f4a7322008-07-27 06:49:38 +0900548TEST_F(FileUtilTest, GetFileCreationLocalTime) {
evanm@google.com874d1672008-10-31 08:54:04 +0900549 FilePath file_name = test_dir_.Append(L"Test File.txt");
initial.commit3f4a7322008-07-27 06:49:38 +0900550
551 SYSTEMTIME start_time;
552 GetLocalTime(&start_time);
553 Sleep(100);
554 CreateTextFile(file_name, L"New file!");
555 Sleep(100);
556 SYSTEMTIME end_time;
557 GetLocalTime(&end_time);
558
559 SYSTEMTIME file_creation_time;
evanm@google.com874d1672008-10-31 08:54:04 +0900560 file_util::GetFileCreationLocalTime(file_name.value(), &file_creation_time);
initial.commit3f4a7322008-07-27 06:49:38 +0900561
562 FILETIME start_filetime;
563 SystemTimeToFileTime(&start_time, &start_filetime);
564 FILETIME end_filetime;
565 SystemTimeToFileTime(&end_time, &end_filetime);
566 FILETIME file_creation_filetime;
567 SystemTimeToFileTime(&file_creation_time, &file_creation_filetime);
568
569 EXPECT_EQ(-1, CompareFileTime(&start_filetime, &file_creation_filetime)) <<
570 "start time: " << FileTimeAsUint64(start_filetime) << ", " <<
571 "creation time: " << FileTimeAsUint64(file_creation_filetime);
572
573 EXPECT_EQ(-1, CompareFileTime(&file_creation_filetime, &end_filetime)) <<
574 "creation time: " << FileTimeAsUint64(file_creation_filetime) << ", " <<
575 "end time: " << FileTimeAsUint64(end_filetime);
576
evanm@google.com874d1672008-10-31 08:54:04 +0900577 ASSERT_TRUE(DeleteFile(file_name.value().c_str()));
initial.commit3f4a7322008-07-27 06:49:38 +0900578}
erikkay@google.comdfb51b22008-08-16 02:32:10 +0900579#endif
initial.commit3f4a7322008-07-27 06:49:38 +0900580
erikkay@google.comf2406842008-08-21 00:59:49 +0900581// file_util winds up using autoreleased objects on the Mac, so this needs
evanm@google.com874d1672008-10-31 08:54:04 +0900582// to be a PlatformTest.
erikkay@google.comf2406842008-08-21 00:59:49 +0900583typedef PlatformTest ReadOnlyFileUtilTest;
initial.commit3f4a7322008-07-27 06:49:38 +0900584
erikkay@google.comf2406842008-08-21 00:59:49 +0900585TEST_F(ReadOnlyFileUtilTest, ContentsEqual) {
evanm@google.com874d1672008-10-31 08:54:04 +0900586 FilePath data_dir;
initial.commit3f4a7322008-07-27 06:49:38 +0900587 ASSERT_TRUE(PathService::Get(base::DIR_SOURCE_ROOT, &data_dir));
evanm@google.com874d1672008-10-31 08:54:04 +0900588 data_dir = data_dir.Append(FILE_PATH_LITERAL("base"))
589 .Append(FILE_PATH_LITERAL("data"))
590 .Append(FILE_PATH_LITERAL("file_util_unittest"));
initial.commit3f4a7322008-07-27 06:49:38 +0900591 ASSERT_TRUE(file_util::PathExists(data_dir));
592
evanm@google.com874d1672008-10-31 08:54:04 +0900593 FilePath original_file =
594 data_dir.Append(FILE_PATH_LITERAL("original.txt"));
595 FilePath same_file =
596 data_dir.Append(FILE_PATH_LITERAL("same.txt"));
597 FilePath same_length_file =
598 data_dir.Append(FILE_PATH_LITERAL("same_length.txt"));
599 FilePath different_file =
600 data_dir.Append(FILE_PATH_LITERAL("different.txt"));
601 FilePath different_first_file =
602 data_dir.Append(FILE_PATH_LITERAL("different_first.txt"));
603 FilePath different_last_file =
604 data_dir.Append(FILE_PATH_LITERAL("different_last.txt"));
605 FilePath empty1_file =
606 data_dir.Append(FILE_PATH_LITERAL("empty1.txt"));
607 FilePath empty2_file =
608 data_dir.Append(FILE_PATH_LITERAL("empty2.txt"));
609 FilePath shortened_file =
610 data_dir.Append(FILE_PATH_LITERAL("shortened.txt"));
611 FilePath binary_file =
612 data_dir.Append(FILE_PATH_LITERAL("binary_file.bin"));
613 FilePath binary_file_same =
614 data_dir.Append(FILE_PATH_LITERAL("binary_file_same.bin"));
615 FilePath binary_file_diff =
616 data_dir.Append(FILE_PATH_LITERAL("binary_file_diff.bin"));
initial.commit3f4a7322008-07-27 06:49:38 +0900617
618 EXPECT_TRUE(file_util::ContentsEqual(original_file, original_file));
619 EXPECT_TRUE(file_util::ContentsEqual(original_file, same_file));
620 EXPECT_FALSE(file_util::ContentsEqual(original_file, same_length_file));
621 EXPECT_FALSE(file_util::ContentsEqual(original_file, different_file));
622 EXPECT_FALSE(file_util::ContentsEqual(L"bogusname", L"bogusname"));
623 EXPECT_FALSE(file_util::ContentsEqual(original_file, different_first_file));
624 EXPECT_FALSE(file_util::ContentsEqual(original_file, different_last_file));
625 EXPECT_TRUE(file_util::ContentsEqual(empty1_file, empty2_file));
626 EXPECT_FALSE(file_util::ContentsEqual(original_file, shortened_file));
627 EXPECT_FALSE(file_util::ContentsEqual(shortened_file, original_file));
628 EXPECT_TRUE(file_util::ContentsEqual(binary_file, binary_file_same));
629 EXPECT_FALSE(file_util::ContentsEqual(binary_file, binary_file_diff));
630}
631
mark@chromium.org95c9ec92009-06-27 06:17:24 +0900632TEST_F(ReadOnlyFileUtilTest, TextContentsEqual) {
633 FilePath data_dir;
634 ASSERT_TRUE(PathService::Get(base::DIR_SOURCE_ROOT, &data_dir));
635 data_dir = data_dir.Append(FILE_PATH_LITERAL("base"))
636 .Append(FILE_PATH_LITERAL("data"))
637 .Append(FILE_PATH_LITERAL("file_util_unittest"));
638 ASSERT_TRUE(file_util::PathExists(data_dir));
639
640 FilePath original_file =
641 data_dir.Append(FILE_PATH_LITERAL("original.txt"));
642 FilePath same_file =
643 data_dir.Append(FILE_PATH_LITERAL("same.txt"));
644 FilePath crlf_file =
645 data_dir.Append(FILE_PATH_LITERAL("crlf.txt"));
646 FilePath shortened_file =
647 data_dir.Append(FILE_PATH_LITERAL("shortened.txt"));
648 FilePath different_file =
649 data_dir.Append(FILE_PATH_LITERAL("different.txt"));
650 FilePath different_first_file =
651 data_dir.Append(FILE_PATH_LITERAL("different_first.txt"));
652 FilePath different_last_file =
653 data_dir.Append(FILE_PATH_LITERAL("different_last.txt"));
654 FilePath first1_file =
655 data_dir.Append(FILE_PATH_LITERAL("first1.txt"));
656 FilePath first2_file =
657 data_dir.Append(FILE_PATH_LITERAL("first2.txt"));
658 FilePath empty1_file =
659 data_dir.Append(FILE_PATH_LITERAL("empty1.txt"));
660 FilePath empty2_file =
661 data_dir.Append(FILE_PATH_LITERAL("empty2.txt"));
662 FilePath blank_line_file =
663 data_dir.Append(FILE_PATH_LITERAL("blank_line.txt"));
664 FilePath blank_line_crlf_file =
665 data_dir.Append(FILE_PATH_LITERAL("blank_line_crlf.txt"));
666
667 EXPECT_TRUE(file_util::TextContentsEqual(original_file, same_file));
668 EXPECT_TRUE(file_util::TextContentsEqual(original_file, crlf_file));
669 EXPECT_FALSE(file_util::TextContentsEqual(original_file, shortened_file));
670 EXPECT_FALSE(file_util::TextContentsEqual(original_file, different_file));
671 EXPECT_FALSE(file_util::TextContentsEqual(original_file,
672 different_first_file));
673 EXPECT_FALSE(file_util::TextContentsEqual(original_file,
674 different_last_file));
675 EXPECT_FALSE(file_util::TextContentsEqual(first1_file, first2_file));
676 EXPECT_TRUE(file_util::TextContentsEqual(empty1_file, empty2_file));
677 EXPECT_FALSE(file_util::TextContentsEqual(original_file, empty1_file));
678 EXPECT_TRUE(file_util::TextContentsEqual(blank_line_file,
679 blank_line_crlf_file));
680}
681
erikkay@google.comdfb51b22008-08-16 02:32:10 +0900682// We don't need equivalent functionality outside of Windows.
erikkay@google.com014161d2008-08-16 02:45:13 +0900683#if defined(OS_WIN)
initial.commit3f4a7322008-07-27 06:49:38 +0900684TEST_F(FileUtilTest, ResolveShortcutTest) {
evanm@google.com874d1672008-10-31 08:54:04 +0900685 FilePath target_file = test_dir_.Append(L"Target.txt");
initial.commit3f4a7322008-07-27 06:49:38 +0900686 CreateTextFile(target_file, L"This is the target.");
687
evanm@google.com874d1672008-10-31 08:54:04 +0900688 FilePath link_file = test_dir_.Append(L"Link.lnk");
initial.commit3f4a7322008-07-27 06:49:38 +0900689
690 HRESULT result;
691 IShellLink *shell = NULL;
692 IPersistFile *persist = NULL;
693
694 CoInitialize(NULL);
695 // Temporarily create a shortcut for test
696 result = CoCreateInstance(CLSID_ShellLink, NULL,
697 CLSCTX_INPROC_SERVER, IID_IShellLink,
698 reinterpret_cast<LPVOID*>(&shell));
699 EXPECT_TRUE(SUCCEEDED(result));
700 result = shell->QueryInterface(IID_IPersistFile,
701 reinterpret_cast<LPVOID*>(&persist));
702 EXPECT_TRUE(SUCCEEDED(result));
evanm@google.com874d1672008-10-31 08:54:04 +0900703 result = shell->SetPath(target_file.value().c_str());
initial.commit3f4a7322008-07-27 06:49:38 +0900704 EXPECT_TRUE(SUCCEEDED(result));
705 result = shell->SetDescription(L"ResolveShortcutTest");
706 EXPECT_TRUE(SUCCEEDED(result));
evanm@google.com874d1672008-10-31 08:54:04 +0900707 result = persist->Save(link_file.value().c_str(), TRUE);
initial.commit3f4a7322008-07-27 06:49:38 +0900708 EXPECT_TRUE(SUCCEEDED(result));
709 if (persist)
710 persist->Release();
711 if (shell)
712 shell->Release();
713
714 bool is_solved;
evan@chromium.orga4899042009-08-25 10:51:44 +0900715 is_solved = file_util::ResolveShortcut(&link_file);
initial.commit3f4a7322008-07-27 06:49:38 +0900716 EXPECT_TRUE(is_solved);
717 std::wstring contents;
evan@chromium.orga4899042009-08-25 10:51:44 +0900718 contents = ReadTextFile(link_file);
initial.commit3f4a7322008-07-27 06:49:38 +0900719 EXPECT_EQ(L"This is the target.", contents);
720
ericroman@google.comdbff4f52008-08-19 01:00:38 +0900721 // Cleaning
evanm@google.com874d1672008-10-31 08:54:04 +0900722 DeleteFile(target_file.value().c_str());
evan@chromium.orga4899042009-08-25 10:51:44 +0900723 DeleteFile(link_file.value().c_str());
initial.commit3f4a7322008-07-27 06:49:38 +0900724 CoUninitialize();
725}
726
727TEST_F(FileUtilTest, CreateShortcutTest) {
728 const wchar_t file_contents[] = L"This is another target.";
evanm@google.com874d1672008-10-31 08:54:04 +0900729 FilePath target_file = test_dir_.Append(L"Target1.txt");
initial.commit3f4a7322008-07-27 06:49:38 +0900730 CreateTextFile(target_file, file_contents);
731
evanm@google.com874d1672008-10-31 08:54:04 +0900732 FilePath link_file = test_dir_.Append(L"Link1.lnk");
initial.commit3f4a7322008-07-27 06:49:38 +0900733
734 CoInitialize(NULL);
evanm@google.com874d1672008-10-31 08:54:04 +0900735 EXPECT_TRUE(file_util::CreateShortcutLink(target_file.value().c_str(),
736 link_file.value().c_str(),
initial.commit3f4a7322008-07-27 06:49:38 +0900737 NULL, NULL, NULL, NULL, 0));
evan@chromium.orga4899042009-08-25 10:51:44 +0900738 FilePath resolved_name = link_file;
initial.commit3f4a7322008-07-27 06:49:38 +0900739 EXPECT_TRUE(file_util::ResolveShortcut(&resolved_name));
evan@chromium.orga4899042009-08-25 10:51:44 +0900740 std::wstring read_contents = ReadTextFile(resolved_name);
initial.commit3f4a7322008-07-27 06:49:38 +0900741 EXPECT_EQ(file_contents, read_contents);
742
evanm@google.com874d1672008-10-31 08:54:04 +0900743 DeleteFile(target_file.value().c_str());
744 DeleteFile(link_file.value().c_str());
initial.commit3f4a7322008-07-27 06:49:38 +0900745 CoUninitialize();
746}
huanr@chromium.org7f2c6af2009-03-12 03:37:48 +0900747
748TEST_F(FileUtilTest, CopyAndDeleteDirectoryTest) {
749 // Create a directory
750 FilePath dir_name_from =
751 test_dir_.Append(FILE_PATH_LITERAL("CopyAndDelete_From_Subdir"));
752 file_util::CreateDirectory(dir_name_from);
753 ASSERT_TRUE(file_util::PathExists(dir_name_from));
754
755 // Create a file under the directory
756 FilePath file_name_from =
757 dir_name_from.Append(FILE_PATH_LITERAL("CopyAndDelete_Test_File.txt"));
758 CreateTextFile(file_name_from, L"Gooooooooooooooooooooogle");
759 ASSERT_TRUE(file_util::PathExists(file_name_from));
760
761 // Move the directory by using CopyAndDeleteDirectory
762 FilePath dir_name_to = test_dir_.Append(
763 FILE_PATH_LITERAL("CopyAndDelete_To_Subdir"));
764 FilePath file_name_to =
765 dir_name_to.Append(FILE_PATH_LITERAL("CopyAndDelete_Test_File.txt"));
766
767 ASSERT_FALSE(file_util::PathExists(dir_name_to));
768
769 EXPECT_TRUE(file_util::CopyAndDeleteDirectory(dir_name_from, dir_name_to));
770
771 // Check everything has been moved.
772 EXPECT_FALSE(file_util::PathExists(dir_name_from));
773 EXPECT_FALSE(file_util::PathExists(file_name_from));
774 EXPECT_TRUE(file_util::PathExists(dir_name_to));
775 EXPECT_TRUE(file_util::PathExists(file_name_to));
776}
tkent@chromium.org8da14162009-10-09 16:33:39 +0900777
778TEST_F(FileUtilTest, GetTempDirTest) {
779 static const TCHAR* kTmpKey = _T("TMP");
780 static const TCHAR* kTmpValues[] = {
781 _T(""), _T("C:"), _T("C:\\"), _T("C:\\tmp"), _T("C:\\tmp\\")
782 };
783 // Save the original $TMP.
784 size_t original_tmp_size;
785 TCHAR* original_tmp;
786 ASSERT_EQ(0, ::_tdupenv_s(&original_tmp, &original_tmp_size, kTmpKey));
787 // original_tmp may be NULL.
788
789 for (unsigned int i = 0; i < arraysize(kTmpValues); ++i) {
790 FilePath path;
791 ::_tputenv_s(kTmpKey, kTmpValues[i]);
792 file_util::GetTempDir(&path);
793 EXPECT_TRUE(path.IsAbsolute()) << "$TMP=" << kTmpValues[i] <<
794 " result=" << path.value();
795 }
796
797 // Restore the original $TMP.
798 if (original_tmp) {
799 ::_tputenv_s(kTmpKey, original_tmp);
800 free(original_tmp);
801 } else {
802 ::_tputenv_s(kTmpKey, _T(""));
803 }
804}
805#endif // OS_WIN
initial.commit3f4a7322008-07-27 06:49:38 +0900806
erikkay@chromium.org18f0dde2009-08-19 01:07:55 +0900807TEST_F(FileUtilTest, CreateTemporaryFileTest) {
808 FilePath temp_files[3];
jrg@chromium.orgd505c3a2009-02-04 09:58:39 +0900809 for (int i = 0; i < 3; i++) {
erikkay@chromium.org18f0dde2009-08-19 01:07:55 +0900810 ASSERT_TRUE(file_util::CreateTemporaryFile(&(temp_files[i])));
jrg@chromium.orgd505c3a2009-02-04 09:58:39 +0900811 EXPECT_TRUE(file_util::PathExists(temp_files[i]));
812 EXPECT_FALSE(file_util::DirectoryExists(temp_files[i]));
813 }
814 for (int i = 0; i < 3; i++)
815 EXPECT_FALSE(temp_files[i] == temp_files[(i+1)%3]);
816 for (int i = 0; i < 3; i++)
817 EXPECT_TRUE(file_util::Delete(temp_files[i], false));
818}
819
erikkay@chromium.org18f0dde2009-08-19 01:07:55 +0900820TEST_F(FileUtilTest, CreateAndOpenTemporaryFileTest) {
jrg@chromium.orgd505c3a2009-02-04 09:58:39 +0900821 FilePath names[3];
822 FILE *fps[3];
823 int i;
824
825 // Create; make sure they are open and exist.
826 for (i = 0; i < 3; ++i) {
827 fps[i] = file_util::CreateAndOpenTemporaryFile(&(names[i]));
828 ASSERT_TRUE(fps[i]);
829 EXPECT_TRUE(file_util::PathExists(names[i]));
830 }
831
832 // Make sure all names are unique.
833 for (i = 0; i < 3; ++i) {
834 EXPECT_FALSE(names[i] == names[(i+1)%3]);
835 }
836
837 // Close and delete.
838 for (i = 0; i < 3; ++i) {
839 EXPECT_TRUE(file_util::CloseFile(fps[i]));
840 EXPECT_TRUE(file_util::Delete(names[i], false));
841 }
initial.commit3f4a7322008-07-27 06:49:38 +0900842}
843
844TEST_F(FileUtilTest, CreateNewTempDirectoryTest) {
evan@chromium.org1543ad32009-08-27 05:00:14 +0900845 FilePath temp_dir;
846 ASSERT_TRUE(file_util::CreateNewTempDirectory(FilePath::StringType(),
847 &temp_dir));
mmoss@google.com733df6b2008-09-12 01:09:11 +0900848 EXPECT_TRUE(file_util::PathExists(temp_dir));
849 EXPECT_TRUE(file_util::Delete(temp_dir, false));
initial.commit3f4a7322008-07-27 06:49:38 +0900850}
851
jrg@chromium.orgd505c3a2009-02-04 09:58:39 +0900852TEST_F(FileUtilTest, GetShmemTempDirTest) {
853 FilePath dir;
854 EXPECT_TRUE(file_util::GetShmemTempDir(&dir));
855 EXPECT_TRUE(file_util::DirectoryExists(dir));
856}
857
initial.commit3f4a7322008-07-27 06:49:38 +0900858TEST_F(FileUtilTest, CreateDirectoryTest) {
evanm@google.com874d1672008-10-31 08:54:04 +0900859 FilePath test_root =
860 test_dir_.Append(FILE_PATH_LITERAL("create_directory_test"));
erikkay@google.com014161d2008-08-16 02:45:13 +0900861#if defined(OS_WIN)
evanm@google.com874d1672008-10-31 08:54:04 +0900862 FilePath test_path =
863 test_root.Append(FILE_PATH_LITERAL("dir\\tree\\likely\\doesnt\\exist\\"));
erikkay@google.comdfb51b22008-08-16 02:32:10 +0900864#elif defined(OS_POSIX)
evanm@google.com874d1672008-10-31 08:54:04 +0900865 FilePath test_path =
866 test_root.Append(FILE_PATH_LITERAL("dir/tree/likely/doesnt/exist/"));
erikkay@google.comdfb51b22008-08-16 02:32:10 +0900867#endif
mmoss@google.com733df6b2008-09-12 01:09:11 +0900868
869 EXPECT_FALSE(file_util::PathExists(test_path));
870 EXPECT_TRUE(file_util::CreateDirectory(test_path));
871 EXPECT_TRUE(file_util::PathExists(test_path));
872 // CreateDirectory returns true if the DirectoryExists returns true.
873 EXPECT_TRUE(file_util::CreateDirectory(test_path));
874
875 // Doesn't work to create it on top of a non-dir
evanm@google.com874d1672008-10-31 08:54:04 +0900876 test_path = test_path.Append(FILE_PATH_LITERAL("foobar.txt"));
mmoss@google.com733df6b2008-09-12 01:09:11 +0900877 EXPECT_FALSE(file_util::PathExists(test_path));
878 CreateTextFile(test_path, L"test file");
879 EXPECT_TRUE(file_util::PathExists(test_path));
880 EXPECT_FALSE(file_util::CreateDirectory(test_path));
881
882 EXPECT_TRUE(file_util::Delete(test_root, true));
883 EXPECT_FALSE(file_util::PathExists(test_root));
884 EXPECT_FALSE(file_util::PathExists(test_path));
885}
886
887TEST_F(FileUtilTest, DetectDirectoryTest) {
888 // Check a directory
evanm@google.com874d1672008-10-31 08:54:04 +0900889 FilePath test_root =
890 test_dir_.Append(FILE_PATH_LITERAL("detect_directory_test"));
mmoss@google.com733df6b2008-09-12 01:09:11 +0900891 EXPECT_FALSE(file_util::PathExists(test_root));
892 EXPECT_TRUE(file_util::CreateDirectory(test_root));
893 EXPECT_TRUE(file_util::PathExists(test_root));
894 EXPECT_TRUE(file_util::DirectoryExists(test_root));
895
896 // Check a file
evanm@google.com874d1672008-10-31 08:54:04 +0900897 FilePath test_path =
898 test_root.Append(FILE_PATH_LITERAL("foobar.txt"));
mmoss@google.com733df6b2008-09-12 01:09:11 +0900899 EXPECT_FALSE(file_util::PathExists(test_path));
900 CreateTextFile(test_path, L"test file");
901 EXPECT_TRUE(file_util::PathExists(test_path));
902 EXPECT_FALSE(file_util::DirectoryExists(test_path));
903 EXPECT_TRUE(file_util::Delete(test_path, false));
904
905 EXPECT_TRUE(file_util::Delete(test_root, true));
initial.commit3f4a7322008-07-27 06:49:38 +0900906}
907
initial.commit3f4a7322008-07-27 06:49:38 +0900908static const struct ReplaceExtensionCase {
909 std::wstring file_name;
estade@chromium.org63343202008-12-05 05:46:06 +0900910 FilePath::StringType extension;
initial.commit3f4a7322008-07-27 06:49:38 +0900911 std::wstring result;
912} kReplaceExtension[] = {
estade@chromium.org63343202008-12-05 05:46:06 +0900913 {L"", FILE_PATH_LITERAL(""), L""},
914 {L"", FILE_PATH_LITERAL("txt"), L".txt"},
915 {L".", FILE_PATH_LITERAL("txt"), L".txt"},
916 {L".", FILE_PATH_LITERAL(""), L""},
917 {L"foo.dll", FILE_PATH_LITERAL("txt"), L"foo.txt"},
918 {L"foo.dll", FILE_PATH_LITERAL(".txt"), L"foo.txt"},
919 {L"foo", FILE_PATH_LITERAL("txt"), L"foo.txt"},
920 {L"foo", FILE_PATH_LITERAL(".txt"), L"foo.txt"},
921 {L"foo.baz.dll", FILE_PATH_LITERAL("txt"), L"foo.baz.txt"},
922 {L"foo.baz.dll", FILE_PATH_LITERAL(".txt"), L"foo.baz.txt"},
923 {L"foo.dll", FILE_PATH_LITERAL(""), L"foo"},
924 {L"foo.dll", FILE_PATH_LITERAL("."), L"foo"},
925 {L"foo", FILE_PATH_LITERAL(""), L"foo"},
926 {L"foo", FILE_PATH_LITERAL("."), L"foo"},
927 {L"foo.baz.dll", FILE_PATH_LITERAL(""), L"foo.baz"},
928 {L"foo.baz.dll", FILE_PATH_LITERAL("."), L"foo.baz"},
initial.commit3f4a7322008-07-27 06:49:38 +0900929};
930
931TEST_F(FileUtilTest, ReplaceExtensionTest) {
erikkay@google.comdfb51b22008-08-16 02:32:10 +0900932 for (unsigned int i = 0; i < arraysize(kReplaceExtension); ++i) {
estade@chromium.org63343202008-12-05 05:46:06 +0900933 FilePath path = FilePath::FromWStringHack(kReplaceExtension[i].file_name);
934 file_util::ReplaceExtension(&path, kReplaceExtension[i].extension);
935 EXPECT_EQ(kReplaceExtension[i].result, path.ToWStringHack());
initial.commit3f4a7322008-07-27 06:49:38 +0900936 }
937}
938
sky@google.com71e7c6f2008-09-20 02:32:18 +0900939// Make sure ReplaceExtension doesn't replace an extension that occurs as one of
940// the directory names of the path.
941TEST_F(FileUtilTest, ReplaceExtensionTestWithPathSeparators) {
estade@chromium.org63343202008-12-05 05:46:06 +0900942 FilePath path;
943 path = path.Append(FILE_PATH_LITERAL("foo.bar"));
944 path = path.Append(FILE_PATH_LITERAL("foo"));
sky@google.com71e7c6f2008-09-20 02:32:18 +0900945 // '/foo.bar/foo' with extension '.baz'
estade@chromium.org63343202008-12-05 05:46:06 +0900946 FilePath result_path = path;
947 file_util::ReplaceExtension(&result_path, FILE_PATH_LITERAL(".baz"));
phajdan.jr@chromium.orgf9908a72009-04-04 02:17:58 +0900948 EXPECT_EQ(path.value() + FILE_PATH_LITERAL(".baz"),
949 result_path.value());
sky@google.com71e7c6f2008-09-20 02:32:18 +0900950}
951
initial.commit3f4a7322008-07-27 06:49:38 +0900952TEST_F(FileUtilTest, FileEnumeratorTest) {
953 // Test an empty directory.
yuzo@chromium.org2da0f822009-06-09 14:57:38 +0900954 file_util::FileEnumerator f0(test_dir_, true, FILES_AND_DIRECTORIES);
avi@google.com5cb79352008-12-11 23:55:12 +0900955 EXPECT_EQ(f0.Next().value(), FILE_PATH_LITERAL(""));
956 EXPECT_EQ(f0.Next().value(), FILE_PATH_LITERAL(""));
initial.commit3f4a7322008-07-27 06:49:38 +0900957
yuzo@chromium.org2da0f822009-06-09 14:57:38 +0900958 // Test an empty directory, non-recursively, including "..".
959 file_util::FileEnumerator f0_dotdot(test_dir_, false,
960 static_cast<file_util::FileEnumerator::FILE_TYPE>(
961 FILES_AND_DIRECTORIES | file_util::FileEnumerator::INCLUDE_DOT_DOT));
962 EXPECT_EQ(test_dir_.Append(FILE_PATH_LITERAL("..")).value(),
963 f0_dotdot.Next().value());
964 EXPECT_EQ(FILE_PATH_LITERAL(""),
965 f0_dotdot.Next().value());
966
erikkay@google.comdfb51b22008-08-16 02:32:10 +0900967 // create the directories
evanm@google.com874d1672008-10-31 08:54:04 +0900968 FilePath dir1 = test_dir_.Append(FILE_PATH_LITERAL("dir1"));
erikkay@google.comdfb51b22008-08-16 02:32:10 +0900969 EXPECT_TRUE(file_util::CreateDirectory(dir1));
evanm@google.com874d1672008-10-31 08:54:04 +0900970 FilePath dir2 = test_dir_.Append(FILE_PATH_LITERAL("dir2"));
erikkay@google.comdfb51b22008-08-16 02:32:10 +0900971 EXPECT_TRUE(file_util::CreateDirectory(dir2));
evanm@google.com874d1672008-10-31 08:54:04 +0900972 FilePath dir2inner = dir2.Append(FILE_PATH_LITERAL("inner"));
erikkay@google.comdfb51b22008-08-16 02:32:10 +0900973 EXPECT_TRUE(file_util::CreateDirectory(dir2inner));
evanm@google.com874d1672008-10-31 08:54:04 +0900974
erikkay@google.comdfb51b22008-08-16 02:32:10 +0900975 // create the files
evanm@google.com874d1672008-10-31 08:54:04 +0900976 FilePath dir2file = dir2.Append(FILE_PATH_LITERAL("dir2file.txt"));
erikkay@google.comdfb51b22008-08-16 02:32:10 +0900977 CreateTextFile(dir2file, L"");
evanm@google.com874d1672008-10-31 08:54:04 +0900978 FilePath dir2innerfile = dir2inner.Append(FILE_PATH_LITERAL("innerfile.txt"));
erikkay@google.comdfb51b22008-08-16 02:32:10 +0900979 CreateTextFile(dir2innerfile, L"");
evanm@google.com874d1672008-10-31 08:54:04 +0900980 FilePath file1 = test_dir_.Append(FILE_PATH_LITERAL("file1.txt"));
erikkay@google.comdfb51b22008-08-16 02:32:10 +0900981 CreateTextFile(file1, L"");
evanm@google.com874d1672008-10-31 08:54:04 +0900982 FilePath file2_rel =
983 dir2.Append(FilePath::kParentDirectory)
984 .Append(FILE_PATH_LITERAL("file2.txt"));
erikkay@google.comdfb51b22008-08-16 02:32:10 +0900985 CreateTextFile(file2_rel, L"");
evanm@google.com874d1672008-10-31 08:54:04 +0900986 FilePath file2_abs = test_dir_.Append(FILE_PATH_LITERAL("file2.txt"));
initial.commit3f4a7322008-07-27 06:49:38 +0900987
988 // Only enumerate files.
avi@google.com5cb79352008-12-11 23:55:12 +0900989 file_util::FileEnumerator f1(test_dir_, true,
initial.commit3f4a7322008-07-27 06:49:38 +0900990 file_util::FileEnumerator::FILES);
991 FindResultCollector c1(f1);
erikkay@google.comdfb51b22008-08-16 02:32:10 +0900992 EXPECT_TRUE(c1.HasFile(file1));
993 EXPECT_TRUE(c1.HasFile(file2_abs));
994 EXPECT_TRUE(c1.HasFile(dir2file));
995 EXPECT_TRUE(c1.HasFile(dir2innerfile));
996 EXPECT_EQ(c1.size(), 4);
initial.commit3f4a7322008-07-27 06:49:38 +0900997
998 // Only enumerate directories.
avi@google.com5cb79352008-12-11 23:55:12 +0900999 file_util::FileEnumerator f2(test_dir_, true,
initial.commit3f4a7322008-07-27 06:49:38 +09001000 file_util::FileEnumerator::DIRECTORIES);
1001 FindResultCollector c2(f2);
erikkay@google.comdfb51b22008-08-16 02:32:10 +09001002 EXPECT_TRUE(c2.HasFile(dir1));
1003 EXPECT_TRUE(c2.HasFile(dir2));
1004 EXPECT_TRUE(c2.HasFile(dir2inner));
1005 EXPECT_EQ(c2.size(), 3);
initial.commit3f4a7322008-07-27 06:49:38 +09001006
tim@chromium.org989d0972008-10-16 11:42:45 +09001007 // Only enumerate directories non-recursively.
1008 file_util::FileEnumerator f2_non_recursive(
avi@google.com5cb79352008-12-11 23:55:12 +09001009 test_dir_, false, file_util::FileEnumerator::DIRECTORIES);
tim@chromium.org989d0972008-10-16 11:42:45 +09001010 FindResultCollector c2_non_recursive(f2_non_recursive);
1011 EXPECT_TRUE(c2_non_recursive.HasFile(dir1));
1012 EXPECT_TRUE(c2_non_recursive.HasFile(dir2));
1013 EXPECT_EQ(c2_non_recursive.size(), 2);
1014
yuzo@chromium.org2da0f822009-06-09 14:57:38 +09001015 // Only enumerate directories, non-recursively, including "..".
1016 file_util::FileEnumerator f2_dotdot(
1017 test_dir_, false,
1018 static_cast<file_util::FileEnumerator::FILE_TYPE>(
1019 file_util::FileEnumerator::DIRECTORIES |
1020 file_util::FileEnumerator::INCLUDE_DOT_DOT));
1021 FindResultCollector c2_dotdot(f2_dotdot);
1022 EXPECT_TRUE(c2_dotdot.HasFile(dir1));
1023 EXPECT_TRUE(c2_dotdot.HasFile(dir2));
1024 EXPECT_TRUE(c2_dotdot.HasFile(test_dir_.Append(FILE_PATH_LITERAL(".."))));
1025 EXPECT_EQ(c2_dotdot.size(), 3);
1026
initial.commit3f4a7322008-07-27 06:49:38 +09001027 // Enumerate files and directories.
yuzo@chromium.org2da0f822009-06-09 14:57:38 +09001028 file_util::FileEnumerator f3(test_dir_, true, FILES_AND_DIRECTORIES);
initial.commit3f4a7322008-07-27 06:49:38 +09001029 FindResultCollector c3(f3);
erikkay@google.comdfb51b22008-08-16 02:32:10 +09001030 EXPECT_TRUE(c3.HasFile(dir1));
1031 EXPECT_TRUE(c3.HasFile(dir2));
1032 EXPECT_TRUE(c3.HasFile(file1));
1033 EXPECT_TRUE(c3.HasFile(file2_abs));
1034 EXPECT_TRUE(c3.HasFile(dir2file));
1035 EXPECT_TRUE(c3.HasFile(dir2inner));
1036 EXPECT_TRUE(c3.HasFile(dir2innerfile));
1037 EXPECT_EQ(c3.size(), 7);
initial.commit3f4a7322008-07-27 06:49:38 +09001038
1039 // Non-recursive operation.
yuzo@chromium.org2da0f822009-06-09 14:57:38 +09001040 file_util::FileEnumerator f4(test_dir_, false, FILES_AND_DIRECTORIES);
initial.commit3f4a7322008-07-27 06:49:38 +09001041 FindResultCollector c4(f4);
erikkay@google.comdfb51b22008-08-16 02:32:10 +09001042 EXPECT_TRUE(c4.HasFile(dir2));
1043 EXPECT_TRUE(c4.HasFile(dir2));
1044 EXPECT_TRUE(c4.HasFile(file1));
1045 EXPECT_TRUE(c4.HasFile(file2_abs));
1046 EXPECT_EQ(c4.size(), 4);
initial.commit3f4a7322008-07-27 06:49:38 +09001047
1048 // Enumerate with a pattern.
yuzo@chromium.org2da0f822009-06-09 14:57:38 +09001049 file_util::FileEnumerator f5(test_dir_, true, FILES_AND_DIRECTORIES,
avi@google.com5cb79352008-12-11 23:55:12 +09001050 FILE_PATH_LITERAL("dir*"));
initial.commit3f4a7322008-07-27 06:49:38 +09001051 FindResultCollector c5(f5);
erikkay@google.comdfb51b22008-08-16 02:32:10 +09001052 EXPECT_TRUE(c5.HasFile(dir1));
1053 EXPECT_TRUE(c5.HasFile(dir2));
1054 EXPECT_TRUE(c5.HasFile(dir2file));
1055 EXPECT_TRUE(c5.HasFile(dir2inner));
1056 EXPECT_TRUE(c5.HasFile(dir2innerfile));
1057 EXPECT_EQ(c5.size(), 5);
initial.commit3f4a7322008-07-27 06:49:38 +09001058
1059 // Make sure the destructor closes the find handle while in the middle of a
1060 // query to allow TearDown to delete the directory.
yuzo@chromium.org2da0f822009-06-09 14:57:38 +09001061 file_util::FileEnumerator f6(test_dir_, true, FILES_AND_DIRECTORIES);
avi@google.com5cb79352008-12-11 23:55:12 +09001062 EXPECT_FALSE(f6.Next().value().empty()); // Should have found something
1063 // (we don't care what).
initial.commit3f4a7322008-07-27 06:49:38 +09001064}
license.botf003cfe2008-08-24 09:55:55 +09001065
aa@chromium.orga4dbdf22009-01-10 07:14:27 +09001066TEST_F(FileUtilTest, Contains) {
thestig@chromium.org4cfbf7a2009-03-11 03:20:44 +09001067 FilePath data_dir = test_dir_.Append(FILE_PATH_LITERAL("FilePathTest"));
aa@chromium.orga4dbdf22009-01-10 07:14:27 +09001068
1069 // Create a fresh, empty copy of this directory.
rvargas@google.com5a0ae3b2009-01-31 10:19:57 +09001070 if (file_util::PathExists(data_dir)) {
1071 ASSERT_TRUE(file_util::Delete(data_dir, true));
1072 }
aa@chromium.orga4dbdf22009-01-10 07:14:27 +09001073 ASSERT_TRUE(file_util::CreateDirectory(data_dir));
1074
1075 FilePath foo(data_dir.Append(FILE_PATH_LITERAL("foo")));
1076 FilePath bar(foo.Append(FILE_PATH_LITERAL("bar.txt")));
1077 FilePath baz(data_dir.Append(FILE_PATH_LITERAL("baz.txt")));
1078 FilePath foobar(data_dir.Append(FILE_PATH_LITERAL("foobar.txt")));
1079
1080 // Annoyingly, the directories must actually exist in order for realpath(),
1081 // which Contains() relies on in posix, to work.
1082 ASSERT_TRUE(file_util::CreateDirectory(foo));
1083 std::string data("hello");
phajdan.jr@chromium.orgf9908a72009-04-04 02:17:58 +09001084 ASSERT_TRUE(file_util::WriteFile(bar, data.c_str(), data.length()));
1085 ASSERT_TRUE(file_util::WriteFile(baz, data.c_str(), data.length()));
1086 ASSERT_TRUE(file_util::WriteFile(foobar, data.c_str(), data.length()));
aa@chromium.orga4dbdf22009-01-10 07:14:27 +09001087
1088 EXPECT_TRUE(file_util::ContainsPath(foo, bar));
1089 EXPECT_FALSE(file_util::ContainsPath(foo, baz));
1090 EXPECT_FALSE(file_util::ContainsPath(foo, foobar));
1091 EXPECT_FALSE(file_util::ContainsPath(foo, foo));
1092
1093// Platform-specific concerns
1094 FilePath foo_caps(data_dir.Append(FILE_PATH_LITERAL("FOO")));
1095#if defined(OS_WIN)
1096 EXPECT_TRUE(file_util::ContainsPath(foo,
1097 foo_caps.Append(FILE_PATH_LITERAL("bar.txt"))));
jrg@chromium.orgd505c3a2009-02-04 09:58:39 +09001098 EXPECT_TRUE(file_util::ContainsPath(foo,
aa@chromium.orga4dbdf22009-01-10 07:14:27 +09001099 FilePath(foo.value() + FILE_PATH_LITERAL("/bar.txt"))));
1100#elif defined(OS_LINUX)
1101 EXPECT_FALSE(file_util::ContainsPath(foo,
1102 foo_caps.Append(FILE_PATH_LITERAL("bar.txt"))));
1103#else
1104 // We can't really do this test on osx since the case-sensitivity of the
1105 // filesystem is configurable.
1106#endif
1107}
1108
mark@chromium.org17684802008-09-10 09:16:28 +09001109} // namespace