| OLD | NEW |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "ui/views/controls/webview/webview.h" | 5 #include "ui/views/controls/webview/webview.h" |
| 6 | 6 |
| 7 #include "base/memory/scoped_ptr.h" | 7 #include "base/memory/scoped_ptr.h" |
| 8 #include "content/browser/web_contents/web_contents_impl.h" | 8 #include "content/browser/web_contents/web_contents_impl.h" |
| 9 #include "content/public/browser/web_contents_observer.h" | 9 #include "content/public/browser/web_contents_observer.h" |
| 10 #include "content/public/test/test_browser_context.h" | 10 #include "content/public/test/test_browser_context.h" |
| 11 #include "content/public/test/test_browser_thread.h" | 11 #include "content/public/test/test_browser_thread.h" |
| 12 #include "content/public/test/web_contents_tester.h" | 12 #include "content/public/test/web_contents_tester.h" |
| 13 #include "content/test/test_content_browser_client.h" | 13 #include "content/test/test_content_browser_client.h" |
| 14 #include "ui/aura/window.h" | 14 #include "ui/aura/window.h" |
| 15 #include "ui/views/test/test_views_delegate.h" | 15 #include "ui/views/test/test_views_delegate.h" |
| 16 #include "ui/views/test/widget_test.h" | 16 #include "ui/views/test/widget_test.h" |
| 17 | 17 |
| 18 namespace { | 18 namespace { |
| 19 | 19 |
| 20 // Provides functionality to create a test WebContents. | 20 // Provides functionality to create a test WebContents. |
| 21 class WebViewTestViewsDelegate : public views::TestViewsDelegate { | 21 class WebViewTestViewsDelegate : public views::TestViewsDelegate { |
| 22 public: | 22 public: |
| 23 WebViewTestViewsDelegate() {} | 23 WebViewTestViewsDelegate() {} |
| 24 virtual ~WebViewTestViewsDelegate() {} | 24 ~WebViewTestViewsDelegate() override {} |
| 25 | 25 |
| 26 // Overriden from TestViewsDelegate. | 26 // Overriden from TestViewsDelegate. |
| 27 virtual content::WebContents* CreateWebContents( | 27 content::WebContents* CreateWebContents( |
| 28 content::BrowserContext* browser_context, | 28 content::BrowserContext* browser_context, |
| 29 content::SiteInstance* site_instance) override { | 29 content::SiteInstance* site_instance) override { |
| 30 return content::WebContentsTester::CreateTestWebContents(browser_context, | 30 return content::WebContentsTester::CreateTestWebContents(browser_context, |
| 31 site_instance); | 31 site_instance); |
| 32 } | 32 } |
| 33 | 33 |
| 34 private: | 34 private: |
| 35 DISALLOW_COPY_AND_ASSIGN(WebViewTestViewsDelegate); | 35 DISALLOW_COPY_AND_ASSIGN(WebViewTestViewsDelegate); |
| 36 }; | 36 }; |
| 37 | 37 |
| 38 // Provides functionality to test a WebView. | 38 // Provides functionality to test a WebView. |
| 39 class WebViewUnitTest : public views::test::WidgetTest { | 39 class WebViewUnitTest : public views::test::WidgetTest { |
| 40 public: | 40 public: |
| 41 WebViewUnitTest() | 41 WebViewUnitTest() |
| 42 : ui_thread_(content::BrowserThread::UI, base::MessageLoop::current()), | 42 : ui_thread_(content::BrowserThread::UI, base::MessageLoop::current()), |
| 43 file_blocking_thread_(content::BrowserThread::FILE_USER_BLOCKING, | 43 file_blocking_thread_(content::BrowserThread::FILE_USER_BLOCKING, |
| 44 base::MessageLoop::current()), | 44 base::MessageLoop::current()), |
| 45 io_thread_(content::BrowserThread::IO, base::MessageLoop::current()) {} | 45 io_thread_(content::BrowserThread::IO, base::MessageLoop::current()) {} |
| 46 | 46 |
| 47 virtual ~WebViewUnitTest() {} | 47 ~WebViewUnitTest() override {} |
| 48 | 48 |
| 49 virtual void SetUp() override { | 49 void SetUp() override { |
| 50 // The ViewsDelegate is deleted when the ViewsTestBase class is torn down. | 50 // The ViewsDelegate is deleted when the ViewsTestBase class is torn down. |
| 51 WidgetTest::set_views_delegate(new WebViewTestViewsDelegate); | 51 WidgetTest::set_views_delegate(new WebViewTestViewsDelegate); |
| 52 browser_context_.reset(new content::TestBrowserContext); | 52 browser_context_.reset(new content::TestBrowserContext); |
| 53 WidgetTest::SetUp(); | 53 WidgetTest::SetUp(); |
| 54 // Set the test content browser client to avoid pulling in needless | 54 // Set the test content browser client to avoid pulling in needless |
| 55 // dependencies from content. | 55 // dependencies from content. |
| 56 SetBrowserClientForTesting(&test_browser_client_); | 56 SetBrowserClientForTesting(&test_browser_client_); |
| 57 } | 57 } |
| 58 | 58 |
| 59 virtual void TearDown() override { | 59 void TearDown() override { |
| 60 browser_context_.reset(NULL); | 60 browser_context_.reset(NULL); |
| 61 // Flush the message loop to execute pending relase tasks as this would | 61 // Flush the message loop to execute pending relase tasks as this would |
| 62 // upset ASAN and Valgrind. | 62 // upset ASAN and Valgrind. |
| 63 RunPendingMessages(); | 63 RunPendingMessages(); |
| 64 WidgetTest::TearDown(); | 64 WidgetTest::TearDown(); |
| 65 } | 65 } |
| 66 | 66 |
| 67 protected: | 67 protected: |
| 68 content::BrowserContext* browser_context() { return browser_context_.get(); } | 68 content::BrowserContext* browser_context() { return browser_context_.get(); } |
| 69 | 69 |
| (...skipping 13 matching lines...) Expand all Loading... |
| 83 class WebViewTestWebContentsObserver : public content::WebContentsObserver { | 83 class WebViewTestWebContentsObserver : public content::WebContentsObserver { |
| 84 public: | 84 public: |
| 85 WebViewTestWebContentsObserver(content::WebContents* web_contents) | 85 WebViewTestWebContentsObserver(content::WebContents* web_contents) |
| 86 : web_contents_(static_cast<content::WebContentsImpl*>(web_contents)), | 86 : web_contents_(static_cast<content::WebContentsImpl*>(web_contents)), |
| 87 was_shown_(false), | 87 was_shown_(false), |
| 88 shown_count_(0), | 88 shown_count_(0), |
| 89 hidden_count_(0) { | 89 hidden_count_(0) { |
| 90 content::WebContentsObserver::Observe(web_contents); | 90 content::WebContentsObserver::Observe(web_contents); |
| 91 } | 91 } |
| 92 | 92 |
| 93 virtual ~WebViewTestWebContentsObserver() { | 93 ~WebViewTestWebContentsObserver() override { |
| 94 if (web_contents_) | 94 if (web_contents_) |
| 95 content::WebContentsObserver::Observe(NULL); | 95 content::WebContentsObserver::Observe(NULL); |
| 96 } | 96 } |
| 97 | 97 |
| 98 virtual void WebContentsDestroyed() override { | 98 void WebContentsDestroyed() override { |
| 99 DCHECK(web_contents_); | 99 DCHECK(web_contents_); |
| 100 content::WebContentsObserver::Observe(NULL); | 100 content::WebContentsObserver::Observe(NULL); |
| 101 web_contents_ = NULL; | 101 web_contents_ = NULL; |
| 102 } | 102 } |
| 103 | 103 |
| 104 virtual void WasShown() override { | 104 void WasShown() override { |
| 105 valid_root_while_shown_ = | 105 valid_root_while_shown_ = |
| 106 web_contents()->GetNativeView()->GetRootWindow() != NULL; | 106 web_contents()->GetNativeView()->GetRootWindow() != NULL; |
| 107 was_shown_ = true; | 107 was_shown_ = true; |
| 108 ++shown_count_; | 108 ++shown_count_; |
| 109 } | 109 } |
| 110 | 110 |
| 111 virtual void WasHidden() override { | 111 void WasHidden() override { |
| 112 was_shown_ = false; | 112 was_shown_ = false; |
| 113 ++hidden_count_; | 113 ++hidden_count_; |
| 114 } | 114 } |
| 115 | 115 |
| 116 bool was_shown() const { return was_shown_; } | 116 bool was_shown() const { return was_shown_; } |
| 117 | 117 |
| 118 int shown_count() const { return shown_count_; } | 118 int shown_count() const { return shown_count_; } |
| 119 | 119 |
| 120 int hidden_count() const { return hidden_count_; } | 120 int hidden_count() const { return hidden_count_; } |
| 121 | 121 |
| (...skipping 100 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 222 parent2->SetContentsView(webview); | 222 parent2->SetContentsView(webview); |
| 223 EXPECT_EQ(3, observer1.shown_count()); | 223 EXPECT_EQ(3, observer1.shown_count()); |
| 224 | 224 |
| 225 widget->Close(); | 225 widget->Close(); |
| 226 parent->Close(); | 226 parent->Close(); |
| 227 parent2->Close(); | 227 parent2->Close(); |
| 228 RunPendingMessages(); | 228 RunPendingMessages(); |
| 229 } | 229 } |
| 230 | 230 |
| 231 } // namespace | 231 } // namespace |
| OLD | NEW |