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 #ifndef BASE_TEST_TEST_FILE_UTIL_H_ | 5 #ifndef BASE_TEST_TEST_FILE_UTIL_H_ |
6 #define BASE_TEST_TEST_FILE_UTIL_H_ | 6 #define BASE_TEST_TEST_FILE_UTIL_H_ |
7 | 7 |
8 // File utility functions used only by tests. | 8 // File utility functions used only by tests. |
9 | 9 |
10 #include <string> | 10 #include <string> |
11 | 11 |
12 #include "base/compiler_specific.h" | 12 #include "base/compiler_specific.h" |
13 #include "base/files/file_path.h" | 13 #include "base/files/file_path.h" |
14 | 14 |
15 #if defined(OS_ANDROID) | |
16 #include <jni.h> | |
17 #include "base/basictypes.h" | |
18 #endif | |
19 | |
20 namespace base { | 15 namespace base { |
21 | 16 |
22 class FilePath; | 17 class FilePath; |
23 | 18 |
24 // Clear a specific file from the system cache like EvictFileFromSystemCache, | 19 // Clear a specific file from the system cache like EvictFileFromSystemCache, |
25 // but on failure it will sleep and retry. On the Windows buildbots, eviction | 20 // but on failure it will sleep and retry. On the Windows buildbots, eviction |
26 // can fail if the file is marked in use, and this will throw off timings that | 21 // can fail if the file is marked in use, and this will throw off timings that |
27 // rely on uncached files. | 22 // rely on uncached files. |
28 bool EvictFileFromSystemCacheWithRetry(const FilePath& file); | 23 bool EvictFileFromSystemCacheWithRetry(const FilePath& file); |
29 | 24 |
(...skipping 26 matching lines...) Expand all Loading... |
56 // string16 elsewhere for Unicode strings, but in tests it is frequently | 51 // string16 elsewhere for Unicode strings, but in tests it is frequently |
57 // convenient to be able to compare paths to literals like L"foobar". | 52 // convenient to be able to compare paths to literals like L"foobar". |
58 std::wstring FilePathAsWString(const base::FilePath& path); | 53 std::wstring FilePathAsWString(const base::FilePath& path); |
59 base::FilePath WStringAsFilePath(const std::wstring& path); | 54 base::FilePath WStringAsFilePath(const std::wstring& path); |
60 | 55 |
61 // For testing, make the file unreadable or unwritable. | 56 // For testing, make the file unreadable or unwritable. |
62 // In POSIX, this does not apply to the root user. | 57 // In POSIX, this does not apply to the root user. |
63 bool MakeFileUnreadable(const base::FilePath& path) WARN_UNUSED_RESULT; | 58 bool MakeFileUnreadable(const base::FilePath& path) WARN_UNUSED_RESULT; |
64 bool MakeFileUnwritable(const base::FilePath& path) WARN_UNUSED_RESULT; | 59 bool MakeFileUnwritable(const base::FilePath& path) WARN_UNUSED_RESULT; |
65 | 60 |
66 #if defined(OS_ANDROID) | |
67 // Register the ContentUriTestUrils JNI bindings. | |
68 bool RegisterContentUriTestUtils(JNIEnv* env); | |
69 | |
70 // Insert an image file into the MediaStore, and retrieve the content URI for | |
71 // testing purpose. | |
72 base::FilePath InsertImageIntoMediaStore(const base::FilePath& path); | |
73 #endif // defined(OS_ANDROID) | |
74 | |
75 // Saves the current permissions for a path, and restores it on destruction. | 61 // Saves the current permissions for a path, and restores it on destruction. |
76 class PermissionRestorer { | 62 class PermissionRestorer { |
77 public: | 63 public: |
78 explicit PermissionRestorer(const base::FilePath& path); | 64 explicit PermissionRestorer(const base::FilePath& path); |
79 ~PermissionRestorer(); | 65 ~PermissionRestorer(); |
80 | 66 |
81 private: | 67 private: |
82 const base::FilePath path_; | 68 const base::FilePath path_; |
83 void* info_; // The opaque stored permission information. | 69 void* info_; // The opaque stored permission information. |
84 size_t length_; // The length of the stored permission information. | 70 size_t length_; // The length of the stored permission information. |
85 | 71 |
86 DISALLOW_COPY_AND_ASSIGN(PermissionRestorer); | 72 DISALLOW_COPY_AND_ASSIGN(PermissionRestorer); |
87 }; | 73 }; |
88 | 74 |
89 } // namespace file_util | 75 } // namespace file_util |
90 | 76 |
91 #endif // BASE_TEST_TEST_FILE_UTIL_H_ | 77 #endif // BASE_TEST_TEST_FILE_UTIL_H_ |
OLD | NEW |