blob: 94aa8efc4625b22b62f882cd7790fd8cdf396c7d [file] [log] [blame]
// Copyright 2014 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef STORAGE_BROWSER_TEST_ASYNC_FILE_TEST_HELPER_H_
#define STORAGE_BROWSER_TEST_ASYNC_FILE_TEST_HELPER_H_
#include <stddef.h>
#include <stdint.h>
#include <string_view>
#include "storage/browser/file_system/file_system_operation.h"
#include "storage/common/file_system/file_system_types.h"
#include "third_party/blink/public/mojom/quota/quota_types.mojom.h"
namespace blink {
class StorageKey;
}
namespace storage {
class FileSystemContext;
class FileSystemURL;
class QuotaManagerProxy;
}
namespace storage {
// A helper class to perform async file operations in a synchronous way.
class AsyncFileTestHelper {
public:
using FileEntryList = FileSystemOperation::FileEntryList;
static const int64_t kDontCheckSize;
// Performs Copy from |src| to |dest| and returns the status code.
static base::File::Error Copy(FileSystemContext* context,
const FileSystemURL& src,
const FileSystemURL& dest);
// Same as Copy, but this supports |copy_or_move_hook_delegate|.
static base::File::Error CopyWithHookDelegate(
FileSystemContext* context,
const FileSystemURL& src,
const FileSystemURL& dest,
FileSystemOperation::ErrorBehavior error_behavior,
std::unique_ptr<CopyOrMoveHookDelegate> copy_or_move_hook_delegate);
// Performs CopyFileLocal from |src| to |dest| and returns the status code.
static base::File::Error CopyFileLocal(FileSystemContext* context,
const FileSystemURL& src,
const FileSystemURL& dest);
// Performs Move from |src| to |dest| and returns the status code.
static base::File::Error Move(FileSystemContext* context,
const FileSystemURL& src,
const FileSystemURL& dest);
// Same as Move, but this supports |copy_or_move_hook_delegate|.
static base::File::Error MoveWithHookDelegate(
FileSystemContext* context,
const FileSystemURL& src,
const FileSystemURL& dest,
FileSystemOperation::ErrorBehavior error_behavior,
std::unique_ptr<CopyOrMoveHookDelegate> copy_or_move_hook_delegate);
// Performs MoveFileLocal from |src| to |dest| and returns the status code.
static base::File::Error MoveFileLocal(FileSystemContext* context,
const FileSystemURL& src,
const FileSystemURL& dest);
// Removes the given |url|.
static base::File::Error Remove(FileSystemContext* context,
const FileSystemURL& url,
bool recursive);
// Performs ReadDirectory on |url|.
static base::File::Error ReadDirectory(FileSystemContext* context,
const FileSystemURL& url,
FileEntryList* entries);
// Creates a directory at |url|.
static base::File::Error CreateDirectory(FileSystemContext* context,
const FileSystemURL& url);
// Creates a file at |url|.
static base::File::Error CreateFile(FileSystemContext* context,
const FileSystemURL& url);
// Creates a file at |url| and fills with |buf|.
static base::File::Error CreateFileWithData(FileSystemContext* context,
const FileSystemURL& url,
std::string_view data);
// Truncates the file |url| to |size|.
static base::File::Error TruncateFile(FileSystemContext* context,
const FileSystemURL& url,
size_t size);
// Retrieves File::Info for |url| and populates |file_info|.
static base::File::Error GetMetadata(FileSystemContext* context,
const FileSystemURL& url,
base::File::Info* file_info);
// Retrieves FilePath for |url| and populates |platform_path|.
static base::File::Error GetPlatformPath(FileSystemContext* context,
const FileSystemURL& url,
base::FilePath* platform_path);
// Returns true if a file exists at |url| with |size|. If |size| is
// kDontCheckSize it doesn't check the file size (but just check its
// existence).
static bool FileExists(FileSystemContext* context,
const FileSystemURL& url,
int64_t size);
// Returns true if a directory exists at |url|.
static bool DirectoryExists(FileSystemContext* context,
const FileSystemURL& url);
// Returns usage and quota. It's valid to pass nullptr to |usage| and/or
// |quota|.
static blink::mojom::QuotaStatusCode GetUsageAndQuota(
QuotaManagerProxy* quota_manager_proxy,
const blink::StorageKey& storage_key,
FileSystemType type,
int64_t* usage,
int64_t* quota);
// Modifies timestamps of a file or directory at |url| with
// |last_access_time| and |last_modified_time|. The function DOES NOT
// create a file unlike 'touch' command on Linux.
static base::File::Error TouchFile(FileSystemContext* context,
const FileSystemURL& url,
const base::Time& last_access_time,
const base::Time& last_modified_time);
};
} // namespace storage
#endif // STORAGE_BROWSER_TEST_ASYNC_FILE_TEST_HELPER_H_