summaryrefslogtreecommitdiffstats
path: root/chrome/browser/ui/views/find_bar_host_uitest.cc
diff options
context:
space:
mode:
Diffstat (limited to 'chrome/browser/ui/views/find_bar_host_uitest.cc')
-rw-r--r--chrome/browser/ui/views/find_bar_host_uitest.cc88
1 files changed, 88 insertions, 0 deletions
diff --git a/chrome/browser/ui/views/find_bar_host_uitest.cc b/chrome/browser/ui/views/find_bar_host_uitest.cc
new file mode 100644
index 0000000..8dd6dbb
--- /dev/null
+++ b/chrome/browser/ui/views/find_bar_host_uitest.cc
@@ -0,0 +1,88 @@
+// 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 "chrome/app/chrome_command_ids.h"
+#include "chrome/test/automation/browser_proxy.h"
+#include "chrome/test/automation/tab_proxy.h"
+#include "chrome/test/ui/ui_test.h"
+#include "net/test/test_server.h"
+
+class FindInPageControllerTest : public UITest {
+ public:
+ FindInPageControllerTest() {
+ show_window_ = true;
+ }
+};
+
+const std::string kSimplePage = "404_is_enough_for_us.html";
+
+#if !defined(OS_WIN)
+// Has never been enabled on other platforms http://crbug.com/45753
+#define FindMovesOnTabClose_Issue1343052 \
+ DISABLED_FindMovesOnTabClose_Issue1343052
+#endif
+// The find window should not change its location just because we open and close
+// a new tab.
+TEST_F(FindInPageControllerTest, FindMovesOnTabClose_Issue1343052) {
+ net::TestServer test_server(net::TestServer::TYPE_HTTP,
+ FilePath(FILE_PATH_LITERAL("chrome/test/data")));
+ ASSERT_TRUE(test_server.Start());
+
+ GURL url = test_server.GetURL(kSimplePage);
+ scoped_refptr<TabProxy> tabA(GetActiveTab());
+ ASSERT_TRUE(tabA.get());
+ ASSERT_TRUE(tabA->NavigateToURL(url));
+ WaitUntilTabCount(1);
+
+ scoped_refptr<BrowserProxy> browser(automation()->GetBrowserWindow(0));
+ ASSERT_TRUE(browser.get() != NULL);
+
+ // Toggle the bookmark bar state.
+ EXPECT_TRUE(browser->ApplyAccelerator(IDC_SHOW_BOOKMARK_BAR));
+ EXPECT_TRUE(WaitForBookmarkBarVisibilityChange(browser.get(), true));
+
+ // Open the Find window and wait for it to animate.
+ EXPECT_TRUE(browser->OpenFindInPage());
+ EXPECT_TRUE(WaitForFindWindowVisibilityChange(browser.get(), true));
+
+ // Find its location.
+ int x = -1, y = -1;
+ EXPECT_TRUE(browser->GetFindWindowLocation(&x, &y));
+
+ // Open another tab (tab B).
+ EXPECT_TRUE(browser->AppendTab(url));
+ scoped_refptr<TabProxy> tabB(GetActiveTab());
+ ASSERT_TRUE(tabB.get());
+
+ // Close tab B.
+ EXPECT_TRUE(tabB->Close(true));
+
+ // See if the Find window has moved.
+ int new_x = -1, new_y = -1;
+ EXPECT_TRUE(browser->GetFindWindowLocation(&new_x, &new_y));
+
+ EXPECT_EQ(x, new_x);
+ EXPECT_EQ(y, new_y);
+
+ // Now reset the bookmark bar state and try the same again.
+ EXPECT_TRUE(browser->ApplyAccelerator(IDC_SHOW_BOOKMARK_BAR));
+ EXPECT_TRUE(WaitForBookmarkBarVisibilityChange(browser.get(), false));
+
+ // Bookmark bar has moved, reset our coordinates.
+ EXPECT_TRUE(browser->GetFindWindowLocation(&x, &y));
+
+ // Open another tab (tab C).
+ EXPECT_TRUE(browser->AppendTab(url));
+ scoped_refptr<TabProxy> tabC(GetActiveTab());
+ ASSERT_TRUE(tabC.get());
+
+ // Close it.
+ EXPECT_TRUE(tabC->Close(true));
+
+ // See if the Find window has moved.
+ EXPECT_TRUE(browser->GetFindWindowLocation(&new_x, &new_y));
+
+ EXPECT_EQ(x, new_x);
+ EXPECT_EQ(y, new_y);
+}