diff options
Diffstat (limited to 'chrome/test/page_cycler')
-rw-r--r-- | chrome/test/page_cycler/page_cycler_test.cc | 66 |
1 files changed, 59 insertions, 7 deletions
diff --git a/chrome/test/page_cycler/page_cycler_test.cc b/chrome/test/page_cycler/page_cycler_test.cc index 9d2f01e..04d563c 100644 --- a/chrome/test/page_cycler/page_cycler_test.cc +++ b/chrome/test/page_cycler/page_cycler_test.cc @@ -20,6 +20,12 @@ #include "googleurl/src/gurl.h" #include "net/base/net_util.h" +#if defined(OS_MACOSX) +#include <errno.h> +#include <string.h> +#include <sys/resource.h> +#endif + #ifndef NDEBUG #define TEST_ITERATIONS "2" #else @@ -32,7 +38,44 @@ static const char kBaseUrl[] = "http://localhost:8000/"; namespace { +#if defined(OS_MACOSX) +// TODO(tvl/stuart): remove all this fd limit setting on the Mac when/if we +// replace the Mac reference build. The trunk raises the limit within the +// browser app, but we do this here also so the current reference build without +// that code will pass the intl[12] tests. This keeps us on an older +// reference build for all the other reference tests (javascript benchmarks, +// tab switch, etc.). +rlim_t GetFileDescriptorLimit(void) { + struct rlimit limits; + if (getrlimit(RLIMIT_NOFILE, &limits) == 0) { + return limits.rlim_cur; + } + LOG(ERROR) << "Failed to get file descriptor limit: " << strerror(errno); + return 0; +} + +void SetFileDescriptorLimit(rlim_t max_descriptors) { + struct rlimit limits; + if (getrlimit(RLIMIT_NOFILE, &limits) == 0) { + if (limits.rlim_max == 0) { + limits.rlim_cur = max_descriptors; + } else { + limits.rlim_cur = std::min(max_descriptors, limits.rlim_max); + } + if (setrlimit(RLIMIT_NOFILE, &limits) != 0) { + LOG(ERROR) << "Failed to set file descriptor limit: " << strerror(errno); + } + } else { + LOG(ERROR) << "Failed to get file descriptor limit: " << strerror(errno); + } +} +#endif + class PageCyclerTest : public UITest { +#if defined(OS_MACOSX) + protected: + rlim_t fd_limit_; +#endif public: PageCyclerTest() { show_window_ = true; @@ -40,6 +83,17 @@ class PageCyclerTest : public UITest { // Expose garbage collection for the page cycler tests. launch_arguments_.AppendSwitchWithValue(switches::kJavaScriptFlags, L"--expose_gc"); +#if defined(OS_MACOSX) + static rlim_t initial_fd_limit = GetFileDescriptorLimit(); + fd_limit_ = initial_fd_limit; +#endif + } + + void SetUp() { +#if defined(OS_MACOSX) + SetFileDescriptorLimit(fd_limit_); +#endif + UITest::SetUp(); } // For HTTP tests, the name must be safe for use in a URL without escaping. @@ -232,6 +286,10 @@ class PageCyclerReferenceTest : public PageCyclerTest { // override the browser directory that is used by UITest::SetUp to cause it // to use the reference build instead. void SetUp() { +#if defined(OS_MACOSX) + fd_limit_ = 1024; +#endif + FilePath dir; PathService::Get(chrome::DIR_TEST_TOOLS, &dir); dir = dir.AppendASCII("reference_build"); @@ -243,7 +301,7 @@ class PageCyclerReferenceTest : public PageCyclerTest { dir = dir.AppendASCII("chrome_mac"); #endif browser_directory_ = dir; - UITest::SetUp(); + PageCyclerTest::SetUp(); } void RunTest(const char* name, bool use_http) { @@ -270,9 +328,6 @@ TEST_F(PageCyclerReferenceTest, MozFile) { RunTest("moz", false); } -#if !defined(OS_MACOSX) -// TODO(nirnimesh): Intl1File, Intl2File, Intl1Http, Intl2Http crash Chromium -// on Mac. Revisit later. TEST_F(PageCyclerTest, Intl1File) { RunTest("intl1", false); } @@ -288,7 +343,6 @@ TEST_F(PageCyclerTest, Intl2File) { TEST_F(PageCyclerReferenceTest, Intl2File) { RunTest("intl2", false); } -#endif // !defined(OS_MACOSX) TEST_F(PageCyclerTest, DomFile) { RunTest("dom", false); @@ -315,7 +369,6 @@ TEST_F(PageCyclerReferenceTest, MozHttp) { RunTest("moz", true); } -#if !defined(OS_MACOSX) TEST_F(PageCyclerTest, Intl1Http) { RunTest("intl1", true); } @@ -331,7 +384,6 @@ TEST_F(PageCyclerTest, Intl2Http) { TEST_F(PageCyclerReferenceTest, Intl2Http) { RunTest("intl2", true); } -#endif // !defined(OS_MACOSX) TEST_F(PageCyclerTest, DomHttp) { RunTest("dom", true); |