Index: ui/views/controls/webview/webview_unittest.cc |
diff --git a/ui/views/controls/webview/webview_unittest.cc b/ui/views/controls/webview/webview_unittest.cc |
deleted file mode 100644 |
index bbca0b364aed654490c863ca736cf783375c0c67..0000000000000000000000000000000000000000 |
--- a/ui/views/controls/webview/webview_unittest.cc |
+++ /dev/null |
@@ -1,163 +0,0 @@ |
-// Copyright 2014 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 "ui/views/controls/webview/webview.h" |
- |
-#include "base/memory/scoped_ptr.h" |
-#include "content/browser/web_contents/web_contents_impl.h" |
-#include "content/public/browser/web_contents_observer.h" |
-#include "content/public/test/test_browser_context.h" |
-#include "content/public/test/test_browser_thread.h" |
-#include "content/public/test/web_contents_tester.h" |
-#include "content/test/test_content_browser_client.h" |
-#include "ui/aura/window.h" |
-#include "ui/views/test/test_views_delegate.h" |
-#include "ui/views/test/widget_test.h" |
- |
-namespace { |
- |
-// Provides functionality to create a test WebContents. |
-class WebViewTestViewsDelegate : public views::TestViewsDelegate { |
- public: |
- WebViewTestViewsDelegate() {} |
- virtual ~WebViewTestViewsDelegate() {} |
- |
- // Overriden from TestViewsDelegate. |
- virtual content::WebContents* CreateWebContents( |
- content::BrowserContext* browser_context, |
- content::SiteInstance* site_instance) OVERRIDE { |
- return content::WebContentsTester::CreateTestWebContents(browser_context, |
- site_instance); |
- } |
- |
- private: |
- DISALLOW_COPY_AND_ASSIGN(WebViewTestViewsDelegate); |
-}; |
- |
-// Provides functionality to test a WebView. |
-class WebViewUnitTest : public views::test::WidgetTest { |
- public: |
- WebViewUnitTest() |
- : ui_thread_(content::BrowserThread::UI, base::MessageLoop::current()) {} |
- |
- virtual ~WebViewUnitTest() {} |
- |
- virtual void SetUp() OVERRIDE { |
- // The ViewsDelegate is deleted when the ViewsTestBase class is torn down. |
- WidgetTest::set_views_delegate(new WebViewTestViewsDelegate); |
- WidgetTest::SetUp(); |
- // Set the test content browser client to avoid pulling in needless |
- // dependencies from content. |
- SetBrowserClientForTesting(&test_browser_client_); |
- } |
- |
- protected: |
- content::BrowserContext* browser_context() { return &browser_context_; } |
- |
- private: |
- content::TestBrowserThread ui_thread_; |
- content::TestBrowserContext browser_context_; |
- scoped_ptr<WebViewTestViewsDelegate> views_delegate_; |
- content::TestContentBrowserClient test_browser_client_; |
- |
- DISALLOW_COPY_AND_ASSIGN(WebViewUnitTest); |
-}; |
- |
-// Provides functionaity to observe events on a WebContents like WasShown/ |
-// WasHidden/WebContentsDestroyed. |
-class WebViewTestWebContentsObserver : public content::WebContentsObserver { |
- public: |
- WebViewTestWebContentsObserver(content::WebContents* web_contents) |
- : web_contents_(static_cast<content::WebContentsImpl*>(web_contents)), |
- was_shown_(false), |
- shown_count_(0), |
- hidden_count_(0) { |
- content::WebContentsObserver::Observe(web_contents); |
- } |
- |
- virtual ~WebViewTestWebContentsObserver() { |
- if (web_contents_) |
- content::WebContentsObserver::Observe(NULL); |
- } |
- |
- virtual void WebContentsDestroyed() OVERRIDE { |
- DCHECK(web_contents_); |
- content::WebContentsObserver::Observe(NULL); |
- web_contents_ = NULL; |
- } |
- |
- virtual void WasShown() OVERRIDE { |
- was_shown_ = true; |
- ++shown_count_; |
- } |
- |
- virtual void WasHidden() OVERRIDE { |
- was_shown_ = false; |
- ++hidden_count_; |
- } |
- |
- bool was_shown() const { return was_shown_; } |
- |
- int shown_count() const { return shown_count_; } |
- |
- int hidden_count() const { return hidden_count_; } |
- |
- private: |
- content::WebContentsImpl* web_contents_; |
- bool was_shown_; |
- int32 shown_count_; |
- int32 hidden_count_; |
- |
- DISALLOW_COPY_AND_ASSIGN(WebViewTestWebContentsObserver); |
-}; |
- |
-// Tests that attaching and detaching a WebContents to a WebView makes the |
-// WebContents visible and hidden respectively. |
-TEST_F(WebViewUnitTest, TestWebViewAttachDetachWebContents) { |
- // Create a top level widget and a webview as its content. |
- views::Widget* widget = CreateTopLevelFramelessPlatformWidget(); |
- widget->SetBounds(gfx::Rect(0, 10, 100, 100)); |
- views::WebView* webview = new views::WebView(browser_context()); |
- widget->SetContentsView(webview); |
- widget->Show(); |
- |
- // Case 1: Create a new WebContents and set it in the webview via |
- // SetWebContents. This should make the WebContents visible. |
- content::WebContents::CreateParams params(browser_context()); |
- scoped_ptr<content::WebContents> web_contents1( |
- content::WebContents::Create(params)); |
- WebViewTestWebContentsObserver observer1(web_contents1.get()); |
- EXPECT_FALSE(observer1.was_shown()); |
- |
- webview->SetWebContents(web_contents1.get()); |
- EXPECT_TRUE(observer1.was_shown()); |
- EXPECT_TRUE(web_contents1->GetNativeView()->IsVisible()); |
- EXPECT_EQ(observer1.shown_count(), 1); |
- EXPECT_EQ(observer1.hidden_count(), 0); |
- |
- // Case 2: Create another WebContents and replace the current WebContents |
- // via SetWebContents(). This should hide the current WebContents and show |
- // the new one. |
- content::WebContents::CreateParams params2(browser_context()); |
- scoped_ptr<content::WebContents> web_contents2( |
- content::WebContents::Create(params2)); |
- WebViewTestWebContentsObserver observer2(web_contents2.get()); |
- EXPECT_FALSE(observer2.was_shown()); |
- |
- // Setting the new WebContents should hide the existing one. |
- webview->SetWebContents(web_contents2.get()); |
- EXPECT_FALSE(observer1.was_shown()); |
- EXPECT_TRUE(observer2.was_shown()); |
- |
- // WebContents1 should not get stray show calls when WebContents2 is set. |
- EXPECT_EQ(observer1.shown_count(), 1); |
- EXPECT_EQ(observer1.hidden_count(), 1); |
- EXPECT_EQ(observer2.shown_count(), 1); |
- EXPECT_EQ(observer2.hidden_count(), 0); |
- |
- widget->Close(); |
- RunPendingMessages(); |
-} |
- |
-} // namespace |