Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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/memory/scoped_ptr.h" | 5 #include "base/memory/scoped_ptr.h" |
| 6 #include "base/test/histogram_tester.h" | 6 #include "base/test/histogram_tester.h" |
| 7 #include "chrome/browser/page_load_metrics/observers/aborts_page_load_metrics_ob server.h" | |
| 7 #include "chrome/browser/page_load_metrics/observers/from_gws_page_load_metrics_ observer.h" | 8 #include "chrome/browser/page_load_metrics/observers/from_gws_page_load_metrics_ observer.h" |
| 8 #include "chrome/browser/page_load_metrics/observers/google_captcha_observer.h" | 9 #include "chrome/browser/page_load_metrics/observers/google_captcha_observer.h" |
| 9 #include "chrome/test/base/chrome_render_view_host_test_harness.h" | 10 #include "chrome/test/base/chrome_render_view_host_test_harness.h" |
| 10 #include "components/page_load_metrics/browser/metrics_web_contents_observer.h" | 11 #include "components/page_load_metrics/browser/metrics_web_contents_observer.h" |
| 11 #include "components/page_load_metrics/common/page_load_metrics_messages.h" | 12 #include "components/page_load_metrics/common/page_load_metrics_messages.h" |
| 12 #include "content/public/test/web_contents_tester.h" | 13 #include "content/public/test/web_contents_tester.h" |
| 13 #include "url/gurl.h" | 14 #include "url/gurl.h" |
| 14 | 15 |
| 15 namespace { | 16 namespace { |
| 16 | 17 |
| (...skipping 25 matching lines...) Expand all Loading... | |
| 42 TestPageLoadMetricsEmbedderInterface() | 43 TestPageLoadMetricsEmbedderInterface() |
| 43 : referrer_(content::Referrer(GURL("https://www.google.com"), | 44 : referrer_(content::Referrer(GURL("https://www.google.com"), |
| 44 blink::WebReferrerPolicyDefault)) {} | 45 blink::WebReferrerPolicyDefault)) {} |
| 45 rappor::RapporService* GetRapporService() override { return nullptr; } | 46 rappor::RapporService* GetRapporService() override { return nullptr; } |
| 46 bool IsPrerendering(content::WebContents* web_contents) override { | 47 bool IsPrerendering(content::WebContents* web_contents) override { |
| 47 return false; | 48 return false; |
| 48 } | 49 } |
| 49 void RegisterObservers(page_load_metrics::PageLoadTracker* tracker) override { | 50 void RegisterObservers(page_load_metrics::PageLoadTracker* tracker) override { |
| 50 tracker->AddObserver( | 51 tracker->AddObserver( |
| 51 make_scoped_ptr(new TestFromGWSPageLoadMetricsObserver(referrer_))); | 52 make_scoped_ptr(new TestFromGWSPageLoadMetricsObserver(referrer_))); |
| 53 tracker->AddObserver( | |
|
Bryan McQuade
2015/12/10 17:04:23
I'd like to have a separate aborts_page_load_metri
Charlie Harrison
2015/12/10 17:59:31
I have a bug filed for this. I'll do it asap after
| |
| 54 make_scoped_ptr(new AbortsPageLoadMetricsObserver())); | |
| 52 } | 55 } |
| 53 void set_referrer(const content::Referrer& referrer) { referrer_ = referrer; } | 56 void set_referrer(const content::Referrer& referrer) { referrer_ = referrer; } |
| 54 | 57 |
| 55 private: | 58 private: |
| 56 content::Referrer referrer_; | 59 content::Referrer referrer_; |
| 57 | 60 |
| 58 DISALLOW_COPY_AND_ASSIGN(TestPageLoadMetricsEmbedderInterface); | 61 DISALLOW_COPY_AND_ASSIGN(TestPageLoadMetricsEmbedderInterface); |
| 59 }; | 62 }; |
| 60 | 63 |
| 61 class PageLoadMetricsObserverTest : public ChromeRenderViewHostTestHarness { | 64 class PageLoadMetricsObserverTest : public ChromeRenderViewHostTestHarness { |
| (...skipping 168 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 230 | 233 |
| 231 observer_->OnMessageReceived( | 234 observer_->OnMessageReceived( |
| 232 PageLoadMetricsMsg_TimingUpdated(observer_->routing_id(), timing), | 235 PageLoadMetricsMsg_TimingUpdated(observer_->routing_id(), timing), |
| 233 web_contents()->GetMainFrame()); | 236 web_contents()->GetMainFrame()); |
| 234 | 237 |
| 235 // Navigate again to force logging. | 238 // Navigate again to force logging. |
| 236 NavigateAndCommit(GURL("https://www.google.com")); | 239 NavigateAndCommit(GURL("https://www.google.com")); |
| 237 histogram_tester_.ExpectTotalCount(kHistogramNameFromGWSFirstTextPaint, 0); | 240 histogram_tester_.ExpectTotalCount(kHistogramNameFromGWSFirstTextPaint, 0); |
| 238 } | 241 } |
| 239 | 242 |
| 243 TEST_F(PageLoadMetricsObserverTest, AbortStopClose) { | |
| 244 page_load_metrics::PageLoadTiming timing; | |
| 245 timing.navigation_start = base::Time::FromDoubleT(1); | |
| 246 content::WebContentsTester* web_contents_tester = | |
| 247 content::WebContentsTester::For(web_contents()); | |
| 248 NavigateAndCommit(GURL("https://www.google.com")); | |
| 249 observer_->OnMessageReceived( | |
| 250 PageLoadMetricsMsg_TimingUpdated(observer_->routing_id(), timing), | |
| 251 web_contents()->GetMainFrame()); | |
| 252 // Simulate the user pressing the stop button. | |
| 253 observer_->NavigationStopped(); | |
| 254 web_contents_tester->NavigateAndCommit(GURL("https://www.example.com")); | |
| 255 observer_->OnMessageReceived( | |
| 256 PageLoadMetricsMsg_TimingUpdated(observer_->routing_id(), timing), | |
| 257 web_contents()->GetMainFrame()); | |
| 258 // Kill the MetricsWebContentsObserver to simulate closing the tab. | |
| 259 observer_.reset(); | |
| 260 histogram_tester_.ExpectTotalCount(kHistogramAbortStopBeforePaint, 1); | |
| 261 histogram_tester_.ExpectTotalCount(kHistogramAbortCloseBeforePaint, 1); | |
| 262 } | |
| 263 | |
| 264 TEST_F(PageLoadMetricsObserverTest, AbortNewNavigation) { | |
| 265 page_load_metrics::PageLoadTiming timing; | |
| 266 timing.navigation_start = base::Time::FromDoubleT(1); | |
| 267 content::WebContentsTester* web_contents_tester = | |
| 268 content::WebContentsTester::For(web_contents()); | |
| 269 web_contents_tester->NavigateAndCommit(GURL("https://www.google.com")); | |
| 270 observer_->OnMessageReceived( | |
| 271 PageLoadMetricsMsg_TimingUpdated(observer_->routing_id(), timing), | |
| 272 web_contents()->GetMainFrame()); | |
| 273 // Simulate the user performaning another navigation before first paint. | |
| 274 web_contents_tester->NavigateAndCommit(GURL("https://www.example.com")); | |
| 275 histogram_tester_.ExpectTotalCount(kHistogramAbortNewNavigationBeforePaint, | |
| 276 1); | |
| 277 } | |
| 278 | |
| 279 TEST_F(PageLoadMetricsObserverTest, NoAbortNewNavigationFromAboutURL) { | |
| 280 content::WebContentsTester* web_contents_tester = | |
| 281 content::WebContentsTester::For(web_contents()); | |
| 282 web_contents_tester->NavigateAndCommit(GURL("about:blank")); | |
| 283 web_contents_tester->NavigateAndCommit(GURL("https://www.example.com")); | |
| 284 histogram_tester_.ExpectTotalCount(kHistogramAbortNewNavigationBeforePaint, | |
| 285 0); | |
| 286 } | |
| 287 | |
| 288 TEST_F(PageLoadMetricsObserverTest, NoAbortNewNavigationAfterPaint) { | |
| 289 page_load_metrics::PageLoadTiming timing; | |
| 290 timing.navigation_start = base::Time::FromDoubleT(1); | |
| 291 timing.first_paint = base::TimeDelta::FromMicroseconds(1); | |
| 292 content::WebContentsTester* web_contents_tester = | |
| 293 content::WebContentsTester::For(web_contents()); | |
| 294 web_contents_tester->NavigateAndCommit(GURL("https://www.google.com")); | |
| 295 observer_->OnMessageReceived( | |
| 296 PageLoadMetricsMsg_TimingUpdated(observer_->routing_id(), timing), | |
| 297 web_contents()->GetMainFrame()); | |
| 298 web_contents_tester->NavigateAndCommit(GURL("https://www.example.com")); | |
| 299 histogram_tester_.ExpectTotalCount(kHistogramAbortNewNavigationBeforePaint, | |
| 300 0); | |
| 301 } | |
| 302 | |
| 303 | |
| 240 TEST_F(PageLoadMetricsObserverTest, IsGoogleCaptcha) { | 304 TEST_F(PageLoadMetricsObserverTest, IsGoogleCaptcha) { |
| 241 struct { | 305 struct { |
| 242 std::string url; | 306 std::string url; |
| 243 bool expected; | 307 bool expected; |
| 244 } test_cases[] = { | 308 } test_cases[] = { |
| 245 {"", false}, | 309 {"", false}, |
| 246 {"http://www.google.com/", false}, | 310 {"http://www.google.com/", false}, |
| 247 {"http://www.cnn.com/", false}, | 311 {"http://www.cnn.com/", false}, |
| 248 {"http://ipv4.google.com/", false}, | 312 {"http://ipv4.google.com/", false}, |
| 249 {"https://ipv4.google.com/sorry/IndexRedirect?continue=http://a", true}, | 313 {"https://ipv4.google.com/sorry/IndexRedirect?continue=http://a", true}, |
| 250 {"https://ipv6.google.com/sorry/IndexRedirect?continue=http://a", true}, | 314 {"https://ipv6.google.com/sorry/IndexRedirect?continue=http://a", true}, |
| 251 {"https://ipv7.google.com/sorry/IndexRedirect?continue=http://a", false}, | 315 {"https://ipv7.google.com/sorry/IndexRedirect?continue=http://a", false}, |
| 252 }; | 316 }; |
| 253 for (const auto& test : test_cases) { | 317 for (const auto& test : test_cases) { |
| 254 EXPECT_EQ(test.expected, | 318 EXPECT_EQ(test.expected, |
| 255 google_captcha_observer::IsGoogleCaptcha(GURL(test.url))) | 319 google_captcha_observer::IsGoogleCaptcha(GURL(test.url))) |
| 256 << "for URL: " << test.url; | 320 << "for URL: " << test.url; |
| 257 } | 321 } |
| 258 } | 322 } |
| OLD | NEW |