Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(466)

Side by Side Diff: ash/screensaver/screensaver_view_unittest.cc

Issue 10191010: Re-implement the screensaver to use WebView instead of ExtensionDialogHost. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: ut fix. Created 8 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « ash/screensaver/screensaver_view.cc ('k') | ash/shell/shell_delegate_impl.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
(Empty)
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "ash/screensaver/screensaver_view.h"
6
7 #include "ash/test/ash_test_base.h"
8 #include "base/bind.h"
9 #include "content/public/browser/browser_context.h"
10 #include "ui/views/controls/webview/webview.h"
11 #include "ui/views/test/test_views_delegate.h"
12 #include "ui/views/test/webview_test_helper.h"
13
14 namespace ash {
15 namespace test {
16
17 class ScreensaverViewTest : public ash::test::AshTestBase {
18 public:
19 ScreensaverViewTest() {
20 url_ = GURL("http://www.google.com");
21 views_delegate_.reset(new views::TestViewsDelegate);
22 webview_test_helper_.reset(new views::WebViewTestHelper(message_loop()));
23 }
24
25 virtual ~ScreensaverViewTest() {}
26
27 virtual void SetUp() OVERRIDE {
28 AshTestBase::SetUp();
29 RunAllPendingInMessageLoop();
30 }
31
32 virtual void TearDown() OVERRIDE {
33 AshTestBase::TearDown();
34 }
35
36 void ExpectOpenScreensaver() {
37 internal::ScreensaverView* screensaver =
38 internal::ScreensaverView::GetInstance();
39 EXPECT_TRUE(screensaver != NULL);
40 if (!screensaver) return;
41
42 EXPECT_TRUE(screensaver->screensaver_webview_ != NULL);
43 if (!screensaver->screensaver_webview_) return;
44
45 EXPECT_TRUE(screensaver->screensaver_webview_->web_contents() != NULL);
46 if (!screensaver->screensaver_webview_->web_contents()) return;
47
48 EXPECT_EQ(screensaver->screensaver_webview_->web_contents()->GetURL(),
49 url_);
50 }
51
52 void ExpectClosedScreensaver() {
53 EXPECT_TRUE(internal::ScreensaverView::GetInstance() == NULL);
54 }
55
56 protected:
57 GURL url_;
58
59 private:
60 scoped_ptr<views::TestViewsDelegate> views_delegate_;
61 scoped_ptr<views::WebViewTestHelper> webview_test_helper_;
62
63 DISALLOW_COPY_AND_ASSIGN(ScreensaverViewTest);
64 };
65
66 TEST_F(ScreensaverViewTest, ShowScreensaverAndClose) {
67 ash::ShowScreensaver(url_);
68 RunAllPendingInMessageLoop();
69 ExpectOpenScreensaver();
70
71 ash::CloseScreensaver();
72 ExpectClosedScreensaver();
73 }
74
75 TEST_F(ScreensaverViewTest, OutOfOrderMultipleShowAndClose) {
76 ash::CloseScreensaver();
77 ExpectClosedScreensaver();
78
79 ash::ShowScreensaver(url_);
80 ExpectOpenScreensaver();
81 RunAllPendingInMessageLoop();
82 ash::ShowScreensaver(url_);
83 ExpectOpenScreensaver();
84 RunAllPendingInMessageLoop();
85
86 ash::CloseScreensaver();
87 ExpectClosedScreensaver();
88 ash::CloseScreensaver();
89 ExpectClosedScreensaver();
90 }
91
92 } // namespace test
93 } // namespace ash
OLDNEW
« no previous file with comments | « ash/screensaver/screensaver_view.cc ('k') | ash/shell/shell_delegate_impl.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698