// Copyright 2024 The Chromium Authors // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef BASE_TEST_ANDROID_CONTENT_URI_TEST_UTILS_H_ #define BASE_TEST_ANDROID_CONTENT_URI_TEST_UTILS_H_ #include namespace base { class FilePath; namespace test::android { // Returns a content-URI for FileProvider org.chromium.native_test.fileprovider // representing `path` if it is a valid file or dir under the android app cache // dir such as a path created in a ScopedTempDir, else returns std::nullopt. std::optional GetContentUriFromCacheDirFilePath(const FilePath& path); // Similar to GetContentUriFromCacheDirFilePath() but files are first read into // memory and any file descriptor will not be backed by a local file. This // mimics how an in-memory or network-backed ContentProvider will behave. std::optional GetInMemoryContentUriFromCacheDirFilePath( const FilePath& path); // Returns a DocumentFile Tree URI for the specified directory which must be // under the cache dir, else returns std::nullopt. This mimics how a // DocumentsProvider will work with ACTION_OPEN_DOCUMENT_TREE. std::optional GetInMemoryContentTreeUriFromCacheDirDirectory( const FilePath& directory); } // namespace test::android } // namespace base #endif // BASE_TEST_ANDROID_CONTENT_URI_TEST_UTILS_H_