diff options
author | agl@chromium.org <agl@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2008-11-11 18:07:40 +0000 |
---|---|---|
committer | agl@chromium.org <agl@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2008-11-11 18:07:40 +0000 |
commit | 0d8a7a1b0662e50c962cd3f14d7ef1a65d5a630b (patch) | |
tree | cdfdedd91eaa12cd3e46064984f2e66f2a562bd3 /net | |
parent | cfe54f8ffaee27afc1deda0c9e8ada192df514fd (diff) | |
download | chromium_src-0d8a7a1b0662e50c962cd3f14d7ef1a65d5a630b.zip chromium_src-0d8a7a1b0662e50c962cd3f14d7ef1a65d5a630b.tar.gz chromium_src-0d8a7a1b0662e50c962cd3f14d7ef1a65d5a630b.tar.bz2 |
* Revert "Por rt flush_cache tool."
This reverts commit 3bd600b37c5ee613c004c84736ee3cb69434562a.
Review URL: http://codereview.chromium.org/9774
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@5184 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'net')
-rw-r--r-- | net/disk_cache/disk_cache_perftest.cc | 100 |
1 files changed, 83 insertions, 17 deletions
diff --git a/net/disk_cache/disk_cache_perftest.cc b/net/disk_cache/disk_cache_perftest.cc index 8c61158..33cad54 100644 --- a/net/disk_cache/disk_cache_perftest.cc +++ b/net/disk_cache/disk_cache_perftest.cc @@ -2,13 +2,17 @@ // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. +#include <fcntl.h> + #include <string> #include "base/basictypes.h" -#include "base/file_path.h" #include "base/file_util.h" #include "base/perftimer.h" #include "base/platform_test.h" +#if defined(OS_WIN) +#include "base/scoped_handle.h" +#endif #include "base/string_util.h" #include "base/timer.h" #include "net/base/net_errors.h" @@ -28,6 +32,62 @@ typedef PlatformTest DiskCacheTest; namespace { +bool EvictFileFromSystemCache(const wchar_t* name) { +#if defined(OS_WIN) + // Overwrite it with no buffering. + ScopedHandle file(CreateFile(name, GENERIC_READ | GENERIC_WRITE, + FILE_SHARE_READ | FILE_SHARE_WRITE, NULL, + OPEN_EXISTING, FILE_FLAG_NO_BUFFERING, NULL)); + if (!file.IsValid()) + return false; + + // Execute in chunks. It could be optimized. We want to do few of these since + // these opterations will be slow without the cache. + char buffer[128 * 1024]; + int total_bytes = 0; + DWORD bytes_read; + for (;;) { + if (!ReadFile(file, buffer, sizeof(buffer), &bytes_read, NULL)) + return false; + if (bytes_read == 0) + break; + + bool final = false; + if (bytes_read < sizeof(buffer)) + final = true; + + DWORD to_write = final ? sizeof(buffer) : bytes_read; + + DWORD actual; + SetFilePointer(file, total_bytes, 0, FILE_BEGIN); + if (!WriteFile(file, buffer, to_write, &actual, NULL)) + return false; + total_bytes += bytes_read; + + if (final) { + SetFilePointer(file, total_bytes, 0, FILE_BEGIN); + SetEndOfFile(file); + break; + } + } + return true; +#elif defined(OS_LINUX) + int fd = open(WideToUTF8(std::wstring(name)).c_str(), O_RDONLY); + if (fd < 0) + return false; + if (fdatasync(fd) != 0) + return false; + if (posix_fadvise(fd, 0, 0, POSIX_FADV_DONTNEED) != 0) + return false; + close(fd); + return true; +#else + // TODO(port): Mac has its own way to do this. + NOTIMPLEMENTED(); + return false; +#endif +} + struct TestEntry { std::string key; int data_len; @@ -154,10 +214,9 @@ TEST_F(DiskCacheTest, Hash) { TEST_F(DiskCacheTest, CacheBackendPerformance) { MessageLoopForIO message_loop; - std::wstring path_wstring = GetCachePath(); - ASSERT_TRUE(DeleteCache(path_wstring.c_str())); - disk_cache::Backend* cache = disk_cache::CreateCacheBackend(path_wstring, - false, 0); + std::wstring path = GetCachePath(); + ASSERT_TRUE(DeleteCache(path.c_str())); + disk_cache::Backend* cache = disk_cache::CreateCacheBackend(path, false, 0); ASSERT_TRUE(NULL != cache); int seed = static_cast<int>(Time::Now().ToInternalValue()); @@ -172,18 +231,25 @@ TEST_F(DiskCacheTest, CacheBackendPerformance) { MessageLoop::current()->RunAllPending(); delete cache; - FilePath path = FilePath::FromWStringHack(path_wstring); - - ASSERT_TRUE(file_util::EvictFileFromSystemCache( - path.Append(FILE_PATH_LITERAL("index")))); - ASSERT_TRUE(file_util::EvictFileFromSystemCache( - path.Append(FILE_PATH_LITERAL("data_0")))); - ASSERT_TRUE(file_util::EvictFileFromSystemCache( - path.Append(FILE_PATH_LITERAL("data_1")))); - ASSERT_TRUE(file_util::EvictFileFromSystemCache( - path.Append(FILE_PATH_LITERAL("data_2")))); - ASSERT_TRUE(file_util::EvictFileFromSystemCache( - path.Append(FILE_PATH_LITERAL("data_3")))); + std::wstring filename(path); + file_util::AppendToPath(&filename, L"index"); + ASSERT_TRUE(EvictFileFromSystemCache(filename.c_str())); + + filename = path; + file_util::AppendToPath(&filename, L"data_0"); + ASSERT_TRUE(EvictFileFromSystemCache(filename.c_str())); + + filename = path; + file_util::AppendToPath(&filename, L"data_1"); + ASSERT_TRUE(EvictFileFromSystemCache(filename.c_str())); + + filename = path; + file_util::AppendToPath(&filename, L"data_2"); + ASSERT_TRUE(EvictFileFromSystemCache(filename.c_str())); + + filename = path; + file_util::AppendToPath(&filename, L"data_3"); + ASSERT_TRUE(EvictFileFromSystemCache(filename.c_str())); cache = disk_cache::CreateCacheBackend(path, false, 0); ASSERT_TRUE(NULL != cache); |