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 "base/run_loop.h" | 5 #include "base/run_loop.h" |
6 #include "base/time/time.h" | 6 #include "base/time/time.h" |
7 #include "chrome/browser/chromeos/login/signin/merge_session_load_page.h" | 7 #include "chrome/browser/chromeos/login/signin/merge_session_load_page.h" |
8 #include "chrome/browser/chromeos/login/signin/oauth2_login_manager.h" | 8 #include "chrome/browser/chromeos/login/signin/oauth2_login_manager.h" |
9 #include "chrome/browser/chromeos/login/signin/oauth2_login_manager_factory.h" | 9 #include "chrome/browser/chromeos/login/signin/oauth2_login_manager_factory.h" |
10 #include "chrome/browser/chromeos/login/users/scoped_test_user_manager.h" | 10 #include "chrome/browser/chromeos/login/users/scoped_test_user_manager.h" |
(...skipping 55 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
66 // Clean up pending tasks that might depend on the user manager. | 66 // Clean up pending tasks that might depend on the user manager. |
67 base::RunLoop().RunUntilIdle(); | 67 base::RunLoop().RunUntilIdle(); |
68 test_user_manager_.reset(); | 68 test_user_manager_.reset(); |
69 #endif | 69 #endif |
70 ChromeRenderViewHostTestHarness::TearDown(); | 70 ChromeRenderViewHostTestHarness::TearDown(); |
71 } | 71 } |
72 | 72 |
73 void Navigate(const char* url, int page_id) { | 73 void Navigate(const char* url, int page_id) { |
74 WebContentsTester::For(web_contents())->TestDidNavigate( | 74 WebContentsTester::For(web_contents())->TestDidNavigate( |
75 web_contents()->GetMainFrame(), page_id, GURL(url), | 75 web_contents()->GetMainFrame(), page_id, GURL(url), |
76 content::PAGE_TRANSITION_TYPED); | 76 ui::PAGE_TRANSITION_TYPED); |
77 } | 77 } |
78 | 78 |
79 void ShowInterstitial(const char* url) { | 79 void ShowInterstitial(const char* url) { |
80 (new TestMergeSessionLoadPage(web_contents(), GURL(url), this))->Show(); | 80 (new TestMergeSessionLoadPage(web_contents(), GURL(url), this))->Show(); |
81 } | 81 } |
82 | 82 |
83 // Returns the MergeSessionLoadPage currently showing or NULL if none is | 83 // Returns the MergeSessionLoadPage currently showing or NULL if none is |
84 // showing. | 84 // showing. |
85 InterstitialPage* GetMergeSessionLoadPage() { | 85 InterstitialPage* GetMergeSessionLoadPage() { |
86 return InterstitialPage::GetInterstitialPage(web_contents()); | 86 return InterstitialPage::GetInterstitialPage(web_contents()); |
(...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
119 ScopedTestCrosSettings test_cros_settings_; | 119 ScopedTestCrosSettings test_cros_settings_; |
120 scoped_ptr<chromeos::ScopedTestUserManager> test_user_manager_; | 120 scoped_ptr<chromeos::ScopedTestUserManager> test_user_manager_; |
121 }; | 121 }; |
122 | 122 |
123 TEST_F(MergeSessionLoadPageTest, MergeSessionPageNotShown) { | 123 TEST_F(MergeSessionLoadPageTest, MergeSessionPageNotShown) { |
124 SetMergeSessionState(OAuth2LoginManager::SESSION_RESTORE_DONE); | 124 SetMergeSessionState(OAuth2LoginManager::SESSION_RESTORE_DONE); |
125 // Start a load. | 125 // Start a load. |
126 Navigate(kURL1, 1); | 126 Navigate(kURL1, 1); |
127 // Load next page. | 127 // Load next page. |
128 controller().LoadURL(GURL(kURL2), content::Referrer(), | 128 controller().LoadURL(GURL(kURL2), content::Referrer(), |
129 content::PAGE_TRANSITION_TYPED, std::string()); | 129 ui::PAGE_TRANSITION_TYPED, std::string()); |
130 | 130 |
131 // Simulate the load causing an merge session interstitial page | 131 // Simulate the load causing an merge session interstitial page |
132 // to be shown. | 132 // to be shown. |
133 InterstitialPage* interstitial = GetMergeSessionLoadPage(); | 133 InterstitialPage* interstitial = GetMergeSessionLoadPage(); |
134 EXPECT_FALSE(interstitial); | 134 EXPECT_FALSE(interstitial); |
135 } | 135 } |
136 | 136 |
137 TEST_F(MergeSessionLoadPageTest, MergeSessionPageNotShownOnTimeout) { | 137 TEST_F(MergeSessionLoadPageTest, MergeSessionPageNotShownOnTimeout) { |
138 SetMergeSessionState(OAuth2LoginManager::SESSION_RESTORE_IN_PROGRESS); | 138 SetMergeSessionState(OAuth2LoginManager::SESSION_RESTORE_IN_PROGRESS); |
139 SetSessionRestoreStart( | 139 SetSessionRestoreStart( |
140 base::Time::Now() + | 140 base::Time::Now() + |
141 base::TimeDelta::FromSeconds(kSessionMergeTimeout + 1)); | 141 base::TimeDelta::FromSeconds(kSessionMergeTimeout + 1)); |
142 | 142 |
143 // Start a load. | 143 // Start a load. |
144 Navigate(kURL1, 1); | 144 Navigate(kURL1, 1); |
145 // Load next page. | 145 // Load next page. |
146 controller().LoadURL(GURL(kURL2), content::Referrer(), | 146 controller().LoadURL(GURL(kURL2), content::Referrer(), |
147 content::PAGE_TRANSITION_TYPED, std::string()); | 147 ui::PAGE_TRANSITION_TYPED, std::string()); |
148 | 148 |
149 // Simulate the load causing an merge session interstitial page | 149 // Simulate the load causing an merge session interstitial page |
150 // to be shown. | 150 // to be shown. |
151 InterstitialPage* interstitial = GetMergeSessionLoadPage(); | 151 InterstitialPage* interstitial = GetMergeSessionLoadPage(); |
152 EXPECT_FALSE(interstitial); | 152 EXPECT_FALSE(interstitial); |
153 } | 153 } |
154 | 154 |
155 TEST_F(MergeSessionLoadPageTest, MergeSessionPageShown) { | 155 TEST_F(MergeSessionLoadPageTest, MergeSessionPageShown) { |
156 SetMergeSessionState(OAuth2LoginManager::SESSION_RESTORE_IN_PROGRESS); | 156 SetMergeSessionState(OAuth2LoginManager::SESSION_RESTORE_IN_PROGRESS); |
157 | 157 |
158 // Start a load. | 158 // Start a load. |
159 Navigate(kURL1, 1); | 159 Navigate(kURL1, 1); |
160 // Load next page. | 160 // Load next page. |
161 controller().LoadURL(GURL(kURL2), content::Referrer(), | 161 controller().LoadURL(GURL(kURL2), content::Referrer(), |
162 content::PAGE_TRANSITION_TYPED, std::string()); | 162 ui::PAGE_TRANSITION_TYPED, std::string()); |
163 | 163 |
164 // Simulate the load causing an merge session interstitial page | 164 // Simulate the load causing an merge session interstitial page |
165 // to be shown. | 165 // to be shown. |
166 ShowInterstitial(kURL2); | 166 ShowInterstitial(kURL2); |
167 InterstitialPage* interstitial = GetMergeSessionLoadPage(); | 167 InterstitialPage* interstitial = GetMergeSessionLoadPage(); |
168 ASSERT_TRUE(interstitial); | 168 ASSERT_TRUE(interstitial); |
169 base::RunLoop().RunUntilIdle(); | 169 base::RunLoop().RunUntilIdle(); |
170 | 170 |
171 // Simulate merge session completion. | 171 // Simulate merge session completion. |
172 SetMergeSessionState(OAuth2LoginManager::SESSION_RESTORE_DONE); | 172 SetMergeSessionState(OAuth2LoginManager::SESSION_RESTORE_DONE); |
173 base::RunLoop().RunUntilIdle(); | 173 base::RunLoop().RunUntilIdle(); |
174 | 174 |
175 // The URL remains to be URL2. | 175 // The URL remains to be URL2. |
176 EXPECT_EQ(kURL2, web_contents()->GetVisibleURL().spec()); | 176 EXPECT_EQ(kURL2, web_contents()->GetVisibleURL().spec()); |
177 | 177 |
178 // Commit navigation and the interstitial page is gone. | 178 // Commit navigation and the interstitial page is gone. |
179 Navigate(kURL2, 2); | 179 Navigate(kURL2, 2); |
180 EXPECT_FALSE(GetMergeSessionLoadPage()); | 180 EXPECT_FALSE(GetMergeSessionLoadPage()); |
181 } | 181 } |
182 | 182 |
183 } // namespace chromeos | 183 } // namespace chromeos |
OLD | NEW |