OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include <stddef.h> | 5 #include <stddef.h> |
6 #include <stdint.h> | 6 #include <stdint.h> |
7 | 7 |
8 #include <algorithm> | 8 #include <algorithm> |
9 #include <fstream> | 9 #include <fstream> |
| 10 #include <initializer_list> |
10 #include <set> | 11 #include <set> |
11 #include <utility> | 12 #include <utility> |
12 #include <vector> | 13 #include <vector> |
13 | 14 |
14 #include "base/base_paths.h" | 15 #include "base/base_paths.h" |
| 16 #include "base/bind.h" |
| 17 #include "base/bind_helpers.h" |
| 18 #include "base/callback_helpers.h" |
15 #include "base/environment.h" | 19 #include "base/environment.h" |
16 #include "base/files/file_enumerator.h" | 20 #include "base/files/file_enumerator.h" |
17 #include "base/files/file_path.h" | 21 #include "base/files/file_path.h" |
18 #include "base/files/file_util.h" | 22 #include "base/files/file_util.h" |
19 #include "base/files/scoped_file.h" | 23 #include "base/files/scoped_file.h" |
20 #include "base/files/scoped_temp_dir.h" | 24 #include "base/files/scoped_temp_dir.h" |
21 #include "base/macros.h" | 25 #include "base/macros.h" |
22 #include "base/path_service.h" | 26 #include "base/path_service.h" |
23 #include "base/strings/string_util.h" | 27 #include "base/strings/string_util.h" |
24 #include "base/strings/utf_string_conversions.h" | 28 #include "base/strings/utf_string_conversions.h" |
(...skipping 214 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
239 std::wstring ReadTextFile(const FilePath& filename) { | 243 std::wstring ReadTextFile(const FilePath& filename) { |
240 wchar_t contents[64]; | 244 wchar_t contents[64]; |
241 std::wifstream file; | 245 std::wifstream file; |
242 file.open(filename.value().c_str()); | 246 file.open(filename.value().c_str()); |
243 EXPECT_TRUE(file.is_open()); | 247 EXPECT_TRUE(file.is_open()); |
244 file.getline(contents, arraysize(contents)); | 248 file.getline(contents, arraysize(contents)); |
245 file.close(); | 249 file.close(); |
246 return std::wstring(contents); | 250 return std::wstring(contents); |
247 } | 251 } |
248 | 252 |
| 253 // Sets |is_inheritable| to indicate whether or not |stream| is set up to be |
| 254 // inerhited into child processes (i.e., HANDLE_FLAG_INHERIT is set on the |
| 255 // underlying handle on Windows, or FD_CLOEXEC is not set on the underlying file |
| 256 // descriptor on POSIX). Calls to this function must be wrapped with |
| 257 // ASSERT_NO_FATAL_FAILURE to properly abort tests in case of fatal failure. |
| 258 void GetIsInheritable(FILE* stream, bool* is_inheritable) { |
| 259 #if defined(OS_WIN) |
| 260 HANDLE handle = reinterpret_cast<HANDLE>(_get_osfhandle(_fileno(stream))); |
| 261 ASSERT_NE(INVALID_HANDLE_VALUE, handle); |
| 262 |
| 263 DWORD info = 0; |
| 264 ASSERT_EQ(TRUE, ::GetHandleInformation(handle, &info)); |
| 265 *is_inheritable = ((info & HANDLE_FLAG_INHERIT) != 0); |
| 266 #elif defined(OS_POSIX) |
| 267 int fd = fileno(stream); |
| 268 ASSERT_NE(-1, fd); |
| 269 int flags = fcntl(fd, F_GETFD, 0); |
| 270 ASSERT_NE(-1, flags); |
| 271 *is_inheritable = ((flags & FD_CLOEXEC) == 0); |
| 272 #else |
| 273 #error Not implemented |
| 274 #endif |
| 275 } |
| 276 |
249 TEST_F(FileUtilTest, FileAndDirectorySize) { | 277 TEST_F(FileUtilTest, FileAndDirectorySize) { |
250 // Create three files of 20, 30 and 3 chars (utf8). ComputeDirectorySize | 278 // Create three files of 20, 30 and 3 chars (utf8). ComputeDirectorySize |
251 // should return 53 bytes. | 279 // should return 53 bytes. |
252 FilePath file_01 = temp_dir_.GetPath().Append(FPL("The file 01.txt")); | 280 FilePath file_01 = temp_dir_.GetPath().Append(FPL("The file 01.txt")); |
253 CreateTextFile(file_01, L"12345678901234567890"); | 281 CreateTextFile(file_01, L"12345678901234567890"); |
254 int64_t size_f1 = 0; | 282 int64_t size_f1 = 0; |
255 ASSERT_TRUE(GetFileSize(file_01, &size_f1)); | 283 ASSERT_TRUE(GetFileSize(file_01, &size_f1)); |
256 EXPECT_EQ(20ll, size_f1); | 284 EXPECT_EQ(20ll, size_f1); |
257 | 285 |
258 FilePath subdir_path = temp_dir_.GetPath().Append(FPL("Level2")); | 286 FilePath subdir_path = temp_dir_.GetPath().Append(FPL("Level2")); |
(...skipping 1445 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1704 // Restore the original $TMP. | 1732 // Restore the original $TMP. |
1705 if (original_tmp) { | 1733 if (original_tmp) { |
1706 ::_tputenv_s(kTmpKey, original_tmp); | 1734 ::_tputenv_s(kTmpKey, original_tmp); |
1707 free(original_tmp); | 1735 free(original_tmp); |
1708 } else { | 1736 } else { |
1709 ::_tputenv_s(kTmpKey, _T("")); | 1737 ::_tputenv_s(kTmpKey, _T("")); |
1710 } | 1738 } |
1711 } | 1739 } |
1712 #endif // OS_WIN | 1740 #endif // OS_WIN |
1713 | 1741 |
| 1742 // Test that files opened by OpenFile are not set up for inheritance into child |
| 1743 // procs. |
| 1744 TEST_F(FileUtilTest, OpenFileNoInheritance) { |
| 1745 FilePath file_path(temp_dir_.GetPath().Append(FPL("a_file"))); |
| 1746 |
| 1747 for (const char* mode : {"wb", "r,ccs=UNICODE"}) { |
| 1748 SCOPED_TRACE(mode); |
| 1749 ASSERT_NO_FATAL_FAILURE(CreateTextFile(file_path, L"Geepers")); |
| 1750 FILE* file = OpenFile(file_path, mode); |
| 1751 ASSERT_NE(nullptr, file); |
| 1752 { |
| 1753 ScopedClosureRunner file_closer(Bind(IgnoreResult(&CloseFile), file)); |
| 1754 bool is_inheritable = true; |
| 1755 ASSERT_NO_FATAL_FAILURE(GetIsInheritable(file, &is_inheritable)); |
| 1756 EXPECT_FALSE(is_inheritable); |
| 1757 } |
| 1758 ASSERT_TRUE(DeleteFile(file_path, false)); |
| 1759 } |
| 1760 } |
| 1761 |
1714 TEST_F(FileUtilTest, CreateTemporaryFileTest) { | 1762 TEST_F(FileUtilTest, CreateTemporaryFileTest) { |
1715 FilePath temp_files[3]; | 1763 FilePath temp_files[3]; |
1716 for (int i = 0; i < 3; i++) { | 1764 for (int i = 0; i < 3; i++) { |
1717 ASSERT_TRUE(CreateTemporaryFile(&(temp_files[i]))); | 1765 ASSERT_TRUE(CreateTemporaryFile(&(temp_files[i]))); |
1718 EXPECT_TRUE(PathExists(temp_files[i])); | 1766 EXPECT_TRUE(PathExists(temp_files[i])); |
1719 EXPECT_FALSE(DirectoryExists(temp_files[i])); | 1767 EXPECT_FALSE(DirectoryExists(temp_files[i])); |
1720 } | 1768 } |
1721 for (int i = 0; i < 3; i++) | 1769 for (int i = 0; i < 3; i++) |
1722 EXPECT_FALSE(temp_files[i] == temp_files[(i+1)%3]); | 1770 EXPECT_FALSE(temp_files[i] == temp_files[(i+1)%3]); |
1723 for (int i = 0; i < 3; i++) | 1771 for (int i = 0; i < 3; i++) |
(...skipping 844 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2568 // Trying to close it should crash. This is important for security. | 2616 // Trying to close it should crash. This is important for security. |
2569 EXPECT_DEATH(CloseWithScopedFD(fds[1]), ""); | 2617 EXPECT_DEATH(CloseWithScopedFD(fds[1]), ""); |
2570 #endif | 2618 #endif |
2571 } | 2619 } |
2572 | 2620 |
2573 #endif // defined(OS_POSIX) | 2621 #endif // defined(OS_POSIX) |
2574 | 2622 |
2575 } // namespace | 2623 } // namespace |
2576 | 2624 |
2577 } // namespace base | 2625 } // namespace base |
OLD | NEW |