summaryrefslogtreecommitdiffstats
path: root/chrome/test/page_cycler/page_cycler_test.cc
diff options
context:
space:
mode:
authorevan@chromium.org <evan@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2010-05-19 11:07:55 +0000
committerevan@chromium.org <evan@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2010-05-19 11:07:55 +0000
commit4e074bae766e9e560da4227468689508b9cd96eb (patch)
tree60fe030b9e106b10e16b829097f06d9fb47225cd /chrome/test/page_cycler/page_cycler_test.cc
parenta841c35f2c3ca42558c76ff48ac4ae61f907d63e (diff)
downloadchromium_src-4e074bae766e9e560da4227468689508b9cd96eb.zip
chromium_src-4e074bae766e9e560da4227468689508b9cd96eb.tar.gz
chromium_src-4e074bae766e9e560da4227468689508b9cd96eb.tar.bz2
page cycler: Use buffer-cache priming code on all systems.
I noticed that the first time I run the page cycler the test numbers are worse, probably because the test pages are not in cache. We already have this code on Mac and I don't see why it shouldn't apply to all systems. Review URL: http://codereview.chromium.org/2096005 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@47650 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/test/page_cycler/page_cycler_test.cc')
-rw-r--r--chrome/test/page_cycler/page_cycler_test.cc37
1 files changed, 14 insertions, 23 deletions
diff --git a/chrome/test/page_cycler/page_cycler_test.cc b/chrome/test/page_cycler/page_cycler_test.cc
index 96f678e..1e3d080 100644
--- a/chrome/test/page_cycler/page_cycler_test.cc
+++ b/chrome/test/page_cycler/page_cycler_test.cc
@@ -4,7 +4,6 @@
#include "base/basictypes.h"
#include "base/command_line.h"
-#include "base/eintr_wrapper.h"
#include "base/file_path.h"
#include "base/file_util.h"
#include "base/path_service.h"
@@ -22,8 +21,6 @@
#include "net/base/net_util.h"
#if defined(OS_MACOSX)
-#include <errno.h>
-#include <fcntl.h>
#include <string.h>
#include <sys/resource.h>
#endif
@@ -76,14 +73,16 @@ void SetFileDescriptorLimit(rlim_t max_descriptors) {
PLOG(ERROR) << "Failed to get file descriptor limit";
}
}
+#endif // OS_MACOSX
-void PopulateUBC(const FilePath &test_dir) {
- // This will recursively walk the directory given and read all the files it
- // finds. This is done so the Mac UBC is likely to have as much loaded as
- // possible. Without this, the tests of this build gets one set of timings
- // and then the reference build test, gets slightly faster ones (even if the
- // reference build is the same binary). The hope is by forcing all the
- // possible data into the UBC we equalize the tests for comparing timing data.
+void PopulateBufferCache(const FilePath& test_dir) {
+ // This will recursively walk the directory given and read all the
+ // files it finds. This is done so the system file cache is likely
+ // to have as much loaded as possible. Without this, the tests of
+ // this build gets one set of timings and then the reference build
+ // test, gets slightly faster ones (even if the reference build is
+ // the same binary). The hope is by forcing all the possible data
+ // into the cache we equalize the tests for comparing timing data.
// We don't want to walk into .svn dirs, so we have to do the tree walk
// ourselves.
@@ -104,7 +103,6 @@ void PopulateUBC(const FilePath &test_dir) {
}
}
- char buf[1024];
unsigned int loaded = 0;
// We seem to have some files in the data dirs that are just there for
@@ -141,19 +139,14 @@ void PopulateUBC(const FilePath &test_dir) {
if (should_skip)
continue;
- // Read the file to get it into the UBC
- int fd = open(path.value().c_str(), O_RDONLY);
- if (fd >= 0) {
+ // Read the file fully to get it into the cache.
+ // We don't care what the contents are.
+ if (file_util::ReadFileToString(path, NULL))
++loaded;
- while (HANDLE_EINTR(read(fd, buf, sizeof(buf))) > 0) {
- }
- HANDLE_EINTR(close(fd));
- }
}
}
- LOG(INFO) << "UBC should be loaded with " << loaded << " files.";
+ LOG(INFO) << "Buffer cache should be primed with " << loaded << " files.";
}
-#endif // defined(OS_MACOSX)
class PageCyclerTest : public UITest {
protected:
@@ -208,9 +201,7 @@ class PageCyclerTest : public UITest {
ASSERT_TRUE(file_util::DirectoryExists(test_path))
<< "Missing test directory " << test_path.value();
-#if defined(OS_MACOSX)
- PopulateUBC(test_path);
-#endif
+ PopulateBufferCache(test_path);
GURL test_url;
if (use_http) {