summaryrefslogtreecommitdiffstats
path: root/chrome/browser
diff options
context:
space:
mode:
authorphajdan.jr@chromium.org <phajdan.jr@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-08-15 00:02:40 +0000
committerphajdan.jr@chromium.org <phajdan.jr@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-08-15 00:02:40 +0000
commitb7a20d363af744159a2bb85bfe3db027d2d4819e (patch)
tree14a363b284d4456d6c0a4888a6b944af3e10b490 /chrome/browser
parent3f58d855ccb7c29abd2fd73cb60e11089abe8dd1 (diff)
downloadchromium_src-b7a20d363af744159a2bb85bfe3db027d2d4819e.zip
chromium_src-b7a20d363af744159a2bb85bfe3db027d2d4819e.tar.gz
chromium_src-b7a20d363af744159a2bb85bfe3db027d2d4819e.tar.bz2
Convert parts of errorpage_uitest.cc to be not flaky.
TEST=Covered by browser_tests. http://crbug.com/19361, http://crbug.com/19395 Review URL: http://codereview.chromium.org/169002 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@23500 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/browser')
-rw-r--r--chrome/browser/browser_focus_uitest.cc9
-rw-r--r--chrome/browser/crash_recovery_browsertest.cc6
-rw-r--r--chrome/browser/errorpage_browsertest.cc132
-rw-r--r--chrome/browser/errorpage_uitest.cc15
4 files changed, 152 insertions, 10 deletions
diff --git a/chrome/browser/browser_focus_uitest.cc b/chrome/browser/browser_focus_uitest.cc
index 33f0bfc..853f424 100644
--- a/chrome/browser/browser_focus_uitest.cc
+++ b/chrome/browser/browser_focus_uitest.cc
@@ -651,7 +651,8 @@ IN_PROC_BROWSER_TEST_F(BrowserFocusTest, FocusOnReload) {
// Open the new tab, reload.
browser()->NewTab();
- ui_test_utils::ReloadCurrentTab(browser());
+ browser()->Reload();
+ ASSERT_TRUE(ui_test_utils::WaitForNavigationInCurrentTab(browser()));
// Focus should stay on the location bar.
EXPECT_EQ(browser_view->GetLocationBarView(),
focus_manager->GetFocusedView());
@@ -661,7 +662,8 @@ IN_PROC_BROWSER_TEST_F(BrowserFocusTest, FocusOnReload) {
browser_view->GetLocationBarView()->FocusLocation();
EXPECT_EQ(browser_view->GetLocationBarView(),
focus_manager->GetFocusedView());
- ui_test_utils::ReloadCurrentTab(browser());
+ browser()->Reload();
+ ASSERT_TRUE(ui_test_utils::WaitForNavigationInCurrentTab(browser()));
// Focus should now be on the tab contents.
EXPECT_EQ(browser_view->GetTabContentsContainerView(),
focus_manager->GetFocusedView());
@@ -681,7 +683,8 @@ IN_PROC_BROWSER_TEST_F(BrowserFocusTest, FocusOnReloadCrashedTab) {
// Open a regular page, crash, reload.
ui_test_utils::NavigateToURL(browser(), server->TestServerPageW(kSimplePage));
ui_test_utils::CrashTab(browser()->GetSelectedTabContents());
- ui_test_utils::ReloadCurrentTab(browser());
+ browser()->Reload();
+ ASSERT_TRUE(ui_test_utils::WaitForNavigationInCurrentTab(browser()));
// Focus should now be on the tab contents.
EXPECT_EQ(browser_view->GetTabContentsContainerView(),
focus_manager->GetFocusedView());
diff --git a/chrome/browser/crash_recovery_browsertest.cc b/chrome/browser/crash_recovery_browsertest.cc
index 1a61b15..63ddf11 100644
--- a/chrome/browser/crash_recovery_browsertest.cc
+++ b/chrome/browser/crash_recovery_browsertest.cc
@@ -70,7 +70,8 @@ IN_PROC_BROWSER_TEST_F(CrashRecoveryBrowserTest, Reload) {
ASSERT_TRUE(ui_test_utils::GetCurrentTabTitle(browser(),
&title_before_crash));
SimulateRendererCrash(browser());
- ASSERT_TRUE(ui_test_utils::ReloadCurrentTab(browser()));
+ browser()->Reload();
+ ASSERT_TRUE(ui_test_utils::WaitForNavigationInCurrentTab(browser()));
ASSERT_TRUE(ui_test_utils::GetCurrentTabTitle(browser(),
&title_after_crash));
EXPECT_NE(title_before_crash, title_after_crash);
@@ -90,7 +91,8 @@ IN_PROC_BROWSER_TEST_F(CrashRecoveryBrowserTest, LoadInNewTab) {
ASSERT_TRUE(ui_test_utils::GetCurrentTabTitle(browser(),
&title_before_crash));
SimulateRendererCrash(browser());
- ASSERT_TRUE(ui_test_utils::ReloadCurrentTab(browser()));
+ browser()->Reload();
+ ASSERT_TRUE(ui_test_utils::WaitForNavigationInCurrentTab(browser()));
ASSERT_TRUE(ui_test_utils::GetCurrentTabTitle(browser(),
&title_after_crash));
EXPECT_EQ(title_before_crash, title_after_crash);
diff --git a/chrome/browser/errorpage_browsertest.cc b/chrome/browser/errorpage_browsertest.cc
new file mode 100644
index 0000000..338c521
--- /dev/null
+++ b/chrome/browser/errorpage_browsertest.cc
@@ -0,0 +1,132 @@
+// Copyright (c) 2009 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 "base/string_util.h"
+#include "chrome/browser/browser.h"
+#include "chrome/browser/net/url_request_failed_dns_job.h"
+#include "chrome/browser/net/url_request_mock_http_job.h"
+#include "chrome/test/in_process_browser_test.h"
+#include "chrome/test/ui_test_utils.h"
+#include "testing/gtest/include/gtest/gtest.h"
+#include "webkit/glue/window_open_disposition.h"
+
+namespace {
+
+class ErrorPageBrowserTest : public InProcessBrowserTest {
+ protected:
+ // We're generally not sure what the title will be exactly (it comes from
+ // external source, and may be localized etc), but it will alway contain the
+ // hostname, so we check for that.
+ // For a proper way to do that http://crbug.com/18365 has been filed.
+ void AssertCurrentTabTitleContains(const std::string& text) {
+ string16 title;
+ EXPECT_TRUE(ui_test_utils::GetCurrentTabTitle(browser(), &title));
+ EXPECT_NE(string16::npos, title.find(ASCIIToUTF16(text))) <<
+ "could not find \"" << text << "\" in \"" << title << "\"";
+ }
+};
+
+using ui_test_utils::NavigateToURL;
+
+// We want to wait for two navigations: first will be the failing one,
+// and the second will be the error page.
+using ui_test_utils::NavigateToURLBlockUntilNavigationsComplete;
+
+IN_PROC_BROWSER_TEST_F(ErrorPageBrowserTest, DNSError_Basic) {
+ GURL test_url(URLRequestFailedDnsJob::kTestUrl);
+ NavigateToURLBlockUntilNavigationsComplete(browser(), test_url, 2);
+ AssertCurrentTabTitleContains(test_url.host());
+}
+
+// Test that a DNS error occuring in the main frame does not result in an
+// additional session history entry.
+IN_PROC_BROWSER_TEST_F(ErrorPageBrowserTest, DNSError_GoBack1) {
+ GURL test_url(URLRequestFailedDnsJob::kTestUrl);
+
+ NavigateToURL(browser(), URLRequestMockHTTPJob::GetMockUrl(L"title2.html"));
+ NavigateToURLBlockUntilNavigationsComplete(browser(), test_url, 2);
+ AssertCurrentTabTitleContains(test_url.host());
+
+ browser()->GoBack(CURRENT_TAB);
+ ASSERT_TRUE(ui_test_utils::WaitForNavigationInCurrentTab(browser()));
+
+ string16 title;
+ ASSERT_TRUE(ui_test_utils::GetCurrentTabTitle(browser(), &title));
+ EXPECT_EQ(ASCIIToUTF16("Title Of Awesomeness"), title);
+}
+
+// Test that a DNS error occuring in the main frame does not result in an
+// additional session history entry.
+IN_PROC_BROWSER_TEST_F(ErrorPageBrowserTest, DNSError_GoBack2) {
+ GURL test_url(URLRequestFailedDnsJob::kTestUrl);
+
+ NavigateToURL(browser(), URLRequestMockHTTPJob::GetMockUrl(L"title2.html"));
+ NavigateToURLBlockUntilNavigationsComplete(browser(), test_url, 2);
+ AssertCurrentTabTitleContains(test_url.host());
+ NavigateToURL(browser(), URLRequestMockHTTPJob::GetMockUrl(L"title3.html"));
+
+ browser()->GoBack(CURRENT_TAB);
+ ASSERT_TRUE(ui_test_utils::WaitForNavigationsInCurrentTab(browser(), 2));
+ AssertCurrentTabTitleContains(test_url.host());
+
+ browser()->GoBack(CURRENT_TAB);
+ ASSERT_TRUE(ui_test_utils::WaitForNavigationInCurrentTab(browser()));
+
+ string16 title;
+ ASSERT_TRUE(ui_test_utils::GetCurrentTabTitle(browser(), &title));
+ EXPECT_EQ(ASCIIToUTF16("Title Of Awesomeness"), title);
+}
+
+// Test that a DNS error occuring in the main frame does not result in an
+// additional session history entry.
+IN_PROC_BROWSER_TEST_F(ErrorPageBrowserTest, DNSError_GoBackAndForward1) {
+ GURL test_url(URLRequestFailedDnsJob::kTestUrl);
+
+ NavigateToURL(browser(), URLRequestMockHTTPJob::GetMockUrl(L"title2.html"));
+ NavigateToURLBlockUntilNavigationsComplete(browser(), test_url, 2);
+ AssertCurrentTabTitleContains(test_url.host());
+ NavigateToURL(browser(), URLRequestMockHTTPJob::GetMockUrl(L"title3.html"));
+
+ browser()->GoBack(CURRENT_TAB);
+ ASSERT_TRUE(ui_test_utils::WaitForNavigationsInCurrentTab(browser(), 2));
+ AssertCurrentTabTitleContains(test_url.host());
+
+ browser()->GoBack(CURRENT_TAB);
+ ASSERT_TRUE(ui_test_utils::WaitForNavigationInCurrentTab(browser()));
+
+ browser()->GoForward(CURRENT_TAB);
+ ASSERT_TRUE(ui_test_utils::WaitForNavigationsInCurrentTab(browser(), 2));
+ AssertCurrentTabTitleContains(test_url.host());
+}
+
+// Test that a DNS error occuring in the main frame does not result in an
+// additional session history entry.
+IN_PROC_BROWSER_TEST_F(ErrorPageBrowserTest, DNSError_GoBackAndForward2) {
+ GURL test_url(URLRequestFailedDnsJob::kTestUrl);
+
+ NavigateToURL(browser(), URLRequestMockHTTPJob::GetMockUrl(L"title3.html"));
+ NavigateToURLBlockUntilNavigationsComplete(browser(), test_url, 2);
+ AssertCurrentTabTitleContains(test_url.host());
+ NavigateToURL(browser(), URLRequestMockHTTPJob::GetMockUrl(L"title2.html"));
+
+ browser()->GoBack(CURRENT_TAB);
+ ASSERT_TRUE(ui_test_utils::WaitForNavigationsInCurrentTab(browser(), 2));
+ AssertCurrentTabTitleContains(test_url.host());
+
+ browser()->GoBack(CURRENT_TAB);
+ ASSERT_TRUE(ui_test_utils::WaitForNavigationInCurrentTab(browser()));
+
+ browser()->GoForward(CURRENT_TAB);
+ ASSERT_TRUE(ui_test_utils::WaitForNavigationsInCurrentTab(browser(), 2));
+ AssertCurrentTabTitleContains(test_url.host());
+
+ browser()->GoForward(CURRENT_TAB);
+ ASSERT_TRUE(ui_test_utils::WaitForNavigationInCurrentTab(browser()));
+
+ string16 title;
+ ASSERT_TRUE(ui_test_utils::GetCurrentTabTitle(browser(), &title));
+ EXPECT_EQ(ASCIIToUTF16("Title Of Awesomeness"), title);
+}
+
+} // namespace
diff --git a/chrome/browser/errorpage_uitest.cc b/chrome/browser/errorpage_uitest.cc
index 4fa2125..fda144d 100644
--- a/chrome/browser/errorpage_uitest.cc
+++ b/chrome/browser/errorpage_uitest.cc
@@ -30,7 +30,8 @@ class ErrorPageTest : public UITest {
}
};
-TEST_F(ErrorPageTest, DNSError_Basic) {
+// Flaky, see http://crbug.com/19361 and http://crbug.com/19395.
+TEST_F(ErrorPageTest, DISABLED_DNSError_Basic) {
GURL test_url(URLRequestFailedDnsJob::kTestUrl);
NavigateToURL(test_url);
@@ -38,7 +39,8 @@ TEST_F(ErrorPageTest, DNSError_Basic) {
EXPECT_TRUE(WaitForTitleContaining(test_url.host()));
}
-TEST_F(ErrorPageTest, DNSError_GoBack1) {
+// Flaky, see http://crbug.com/19361 and http://crbug.com/19395.
+TEST_F(ErrorPageTest, DISABLED_DNSError_GoBack1) {
// Test that a DNS error occuring in the main frame does not result in an
// additional session history entry.
GURL test_url(URLRequestFailedDnsJob::kTestUrl);
@@ -52,7 +54,8 @@ TEST_F(ErrorPageTest, DNSError_GoBack1) {
EXPECT_TRUE(WaitForTitleMatching(L"Title Of Awesomeness"));
}
-TEST_F(ErrorPageTest, DNSError_GoBack2) {
+// Flaky, see http://crbug.com/19361 and http://crbug.com/19395.
+TEST_F(ErrorPageTest, DISABLED_DNSError_GoBack2) {
// Test that a DNS error occuring in the main frame does not result in an
// additional session history entry.
GURL test_url(URLRequestFailedDnsJob::kTestUrl);
@@ -69,7 +72,8 @@ TEST_F(ErrorPageTest, DNSError_GoBack2) {
EXPECT_TRUE(WaitForTitleMatching(L"Title Of Awesomeness"));
}
-TEST_F(ErrorPageTest, DNSError_GoBack2AndForward) {
+// Flaky, see http://crbug.com/19361 and http://crbug.com/19395.
+TEST_F(ErrorPageTest, DISABLED_DNSError_GoBack2AndForward) {
// Test that a DNS error occuring in the main frame does not result in an
// additional session history entry.
@@ -88,7 +92,8 @@ TEST_F(ErrorPageTest, DNSError_GoBack2AndForward) {
EXPECT_TRUE(WaitForTitleContaining(test_url.host()));
}
-TEST_F(ErrorPageTest, DNSError_GoBack2Forward2) {
+// Flaky, see http://crbug.com/19361 and http://crbug.com/19395.
+TEST_F(ErrorPageTest, DISABLED_DNSError_GoBack2Forward2) {
// Test that a DNS error occuring in the main frame does not result in an
// additional session history entry.