mirror of
https://github.com/klzgrad/naiveproxy.git
synced 2024-11-28 08:16:09 +03:00
136 lines
5.0 KiB
C++
136 lines
5.0 KiB
C++
|
// Copyright 2013 The Chromium Authors. All rights reserved.
|
||
|
// Use of this source code is governed by a BSD-style license that can be
|
||
|
// found in the LICENSE file.
|
||
|
|
||
|
#include "net/disk_cache/simple/simple_test_util.h"
|
||
|
|
||
|
#include "base/files/file.h"
|
||
|
#include "base/files/file_path.h"
|
||
|
#include "net/base/hash_value.h"
|
||
|
#include "net/disk_cache/simple/simple_entry_format.h"
|
||
|
#include "net/disk_cache/simple/simple_util.h"
|
||
|
|
||
|
namespace disk_cache {
|
||
|
namespace simple_util {
|
||
|
|
||
|
using base::File;
|
||
|
using base::FilePath;
|
||
|
|
||
|
bool CreateCorruptFileForTests(const std::string& key,
|
||
|
const FilePath& cache_path) {
|
||
|
FilePath entry_file_path = cache_path.AppendASCII(
|
||
|
disk_cache::simple_util::GetFilenameFromKeyAndFileIndex(key, 0));
|
||
|
int flags = File::FLAG_CREATE_ALWAYS | File::FLAG_WRITE;
|
||
|
File entry_file(entry_file_path, flags);
|
||
|
|
||
|
if (!entry_file.IsValid())
|
||
|
return false;
|
||
|
|
||
|
return entry_file.Write(0, "dummy", 1) == 1;
|
||
|
}
|
||
|
|
||
|
bool RemoveKeySHA256FromEntry(const std::string& key,
|
||
|
const FilePath& cache_path) {
|
||
|
FilePath entry_file_path = cache_path.AppendASCII(
|
||
|
disk_cache::simple_util::GetFilenameFromKeyAndFileIndex(key, 0));
|
||
|
int flags = File::FLAG_OPEN | File::FLAG_READ | File::FLAG_WRITE;
|
||
|
File entry_file(entry_file_path, flags);
|
||
|
if (!entry_file.IsValid())
|
||
|
return false;
|
||
|
int64_t file_length = entry_file.GetLength();
|
||
|
SimpleFileEOF eof_record;
|
||
|
if (file_length < static_cast<int64_t>(sizeof(eof_record)))
|
||
|
return false;
|
||
|
if (entry_file.Read(file_length - sizeof(eof_record),
|
||
|
reinterpret_cast<char*>(&eof_record),
|
||
|
sizeof(eof_record)) != sizeof(eof_record)) {
|
||
|
return false;
|
||
|
}
|
||
|
if (eof_record.final_magic_number != disk_cache::kSimpleFinalMagicNumber ||
|
||
|
(eof_record.flags & SimpleFileEOF::FLAG_HAS_KEY_SHA256) !=
|
||
|
SimpleFileEOF::FLAG_HAS_KEY_SHA256) {
|
||
|
return false;
|
||
|
}
|
||
|
// Remove the key SHA256 flag, and rewrite the header on top of the
|
||
|
// SHA256. Truncate the file afterwards, and we have an identical entry
|
||
|
// lacking a key SHA256.
|
||
|
eof_record.flags &= ~SimpleFileEOF::FLAG_HAS_KEY_SHA256;
|
||
|
if (entry_file.Write(
|
||
|
file_length - sizeof(eof_record) - sizeof(net::SHA256HashValue),
|
||
|
reinterpret_cast<char*>(&eof_record),
|
||
|
sizeof(eof_record)) != sizeof(eof_record)) {
|
||
|
return false;
|
||
|
}
|
||
|
if (!entry_file.SetLength(file_length - sizeof(net::SHA256HashValue))) {
|
||
|
return false;
|
||
|
}
|
||
|
return true;
|
||
|
}
|
||
|
|
||
|
bool CorruptKeySHA256FromEntry(const std::string& key,
|
||
|
const base::FilePath& cache_path) {
|
||
|
FilePath entry_file_path = cache_path.AppendASCII(
|
||
|
disk_cache::simple_util::GetFilenameFromKeyAndFileIndex(key, 0));
|
||
|
int flags = File::FLAG_OPEN | File::FLAG_READ | File::FLAG_WRITE;
|
||
|
File entry_file(entry_file_path, flags);
|
||
|
if (!entry_file.IsValid())
|
||
|
return false;
|
||
|
int64_t file_length = entry_file.GetLength();
|
||
|
SimpleFileEOF eof_record;
|
||
|
if (file_length < static_cast<int64_t>(sizeof(eof_record)))
|
||
|
return false;
|
||
|
if (entry_file.Read(file_length - sizeof(eof_record),
|
||
|
reinterpret_cast<char*>(&eof_record),
|
||
|
sizeof(eof_record)) != sizeof(eof_record)) {
|
||
|
return false;
|
||
|
}
|
||
|
if (eof_record.final_magic_number != disk_cache::kSimpleFinalMagicNumber ||
|
||
|
(eof_record.flags & SimpleFileEOF::FLAG_HAS_KEY_SHA256) !=
|
||
|
SimpleFileEOF::FLAG_HAS_KEY_SHA256) {
|
||
|
return false;
|
||
|
}
|
||
|
|
||
|
const char corrupt_data[] = "corrupt data";
|
||
|
static_assert(sizeof(corrupt_data) <= sizeof(net::SHA256HashValue),
|
||
|
"corrupt data should not be larger than a SHA-256");
|
||
|
if (entry_file.Write(
|
||
|
file_length - sizeof(eof_record) - sizeof(net::SHA256HashValue),
|
||
|
corrupt_data, sizeof(corrupt_data)) != sizeof(corrupt_data)) {
|
||
|
return false;
|
||
|
}
|
||
|
return true;
|
||
|
}
|
||
|
|
||
|
bool CorruptStream0LengthFromEntry(const std::string& key,
|
||
|
const base::FilePath& cache_path) {
|
||
|
FilePath entry_file_path = cache_path.AppendASCII(
|
||
|
disk_cache::simple_util::GetFilenameFromKeyAndFileIndex(key, 0));
|
||
|
int flags = File::FLAG_OPEN | File::FLAG_READ | File::FLAG_WRITE;
|
||
|
File entry_file(entry_file_path, flags);
|
||
|
if (!entry_file.IsValid())
|
||
|
return false;
|
||
|
int64_t file_length = entry_file.GetLength();
|
||
|
SimpleFileEOF eof_record;
|
||
|
if (file_length < static_cast<int64_t>(sizeof(eof_record)))
|
||
|
return false;
|
||
|
if (entry_file.Read(file_length - sizeof(eof_record),
|
||
|
reinterpret_cast<char*>(&eof_record),
|
||
|
sizeof(eof_record)) != sizeof(eof_record)) {
|
||
|
return false;
|
||
|
}
|
||
|
if (eof_record.final_magic_number != disk_cache::kSimpleFinalMagicNumber)
|
||
|
return false;
|
||
|
|
||
|
// Set the stream size to a clearly invalidly large value.
|
||
|
eof_record.stream_size = std::numeric_limits<uint32_t>::max() - 50;
|
||
|
if (entry_file.Write(file_length - sizeof(eof_record),
|
||
|
reinterpret_cast<char*>(&eof_record),
|
||
|
sizeof(eof_record)) != sizeof(eof_record)) {
|
||
|
return false;
|
||
|
}
|
||
|
return true;
|
||
|
}
|
||
|
|
||
|
} // namespace simple_util
|
||
|
} // namespace disk_cache
|