| 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/files/scoped_temp_dir.h" | 5 #include "base/files/scoped_temp_dir.h" |
| 6 #include "base/macros.h" | 6 #include "base/macros.h" |
| 7 #include "base/test/histogram_tester.h" | 7 #include "base/test/histogram_tester.h" |
| 8 #include "base/time/time.h" | 8 #include "base/time/time.h" |
| 9 #include "chrome/browser/page_load_metrics/metrics_web_contents_observer.h" | 9 #include "chrome/browser/page_load_metrics/metrics_web_contents_observer.h" |
| 10 #include "chrome/browser/page_load_metrics/observers/aborts_page_load_metrics_ob
server.h" | 10 #include "chrome/browser/page_load_metrics/observers/aborts_page_load_metrics_ob
server.h" |
| (...skipping 492 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 503 | 503 |
| 504 IN_PROC_BROWSER_TEST_F(PageLoadMetricsBrowserTest, | 504 IN_PROC_BROWSER_TEST_F(PageLoadMetricsBrowserTest, |
| 505 NoStatePrefetchObserverCacheable) { | 505 NoStatePrefetchObserverCacheable) { |
| 506 ASSERT_TRUE(embedded_test_server()->Start()); | 506 ASSERT_TRUE(embedded_test_server()->Start()); |
| 507 | 507 |
| 508 ui_test_utils::NavigateToURL(browser(), | 508 ui_test_utils::NavigateToURL(browser(), |
| 509 embedded_test_server()->GetURL("/title1.html")); | 509 embedded_test_server()->GetURL("/title1.html")); |
| 510 NavigateToUntrackedUrl(); | 510 NavigateToUntrackedUrl(); |
| 511 | 511 |
| 512 histogram_tester_.ExpectTotalCount( | 512 histogram_tester_.ExpectTotalCount( |
| 513 prerender::PrerenderHistograms::GetFirstContentfulPaintHistogramName( | 513 "Prerender.none_PrefetchTTFCP.Reference.NoStore.Visible", 0); |
| 514 prerender::ORIGIN_NONE, false, true, base::TimeDelta()), | |
| 515 0); | |
| 516 histogram_tester_.ExpectTotalCount( | 514 histogram_tester_.ExpectTotalCount( |
| 517 prerender::PrerenderHistograms::GetFirstContentfulPaintHistogramName( | 515 "Prerender.none_PrefetchTTFCP.Reference.Cacheable.Visible", 1); |
| 518 prerender::ORIGIN_NONE, false, false, base::TimeDelta()), | |
| 519 1); | |
| 520 } | 516 } |
| 521 | 517 |
| 522 IN_PROC_BROWSER_TEST_F(PageLoadMetricsBrowserTest, | 518 IN_PROC_BROWSER_TEST_F(PageLoadMetricsBrowserTest, |
| 523 NoStatePrefetchObserverNoStore) { | 519 NoStatePrefetchObserverNoStore) { |
| 524 ASSERT_TRUE(embedded_test_server()->Start()); | 520 ASSERT_TRUE(embedded_test_server()->Start()); |
| 525 | 521 |
| 526 ui_test_utils::NavigateToURL(browser(), | 522 ui_test_utils::NavigateToURL(browser(), |
| 527 embedded_test_server()->GetURL("/nostore.html")); | 523 embedded_test_server()->GetURL("/nostore.html")); |
| 528 NavigateToUntrackedUrl(); | 524 NavigateToUntrackedUrl(); |
| 529 | 525 |
| 530 histogram_tester_.ExpectTotalCount( | 526 histogram_tester_.ExpectTotalCount( |
| 531 prerender::PrerenderHistograms::GetFirstContentfulPaintHistogramName( | 527 "Prerender.none_PrefetchTTFCP.Reference.NoStore.Visible", 1); |
| 532 prerender::ORIGIN_NONE, false, true, base::TimeDelta()), | |
| 533 1); | |
| 534 histogram_tester_.ExpectTotalCount( | 528 histogram_tester_.ExpectTotalCount( |
| 535 prerender::PrerenderHistograms::GetFirstContentfulPaintHistogramName( | 529 "Prerender.none_PrefetchTTFCP.Reference.Cacheable.Visible", 0); |
| 536 prerender::ORIGIN_NONE, false, false, base::TimeDelta()), | |
| 537 0); | |
| 538 } | 530 } |
| 539 | 531 |
| 540 IN_PROC_BROWSER_TEST_F(PageLoadMetricsBrowserTest, CSSTiming) { | 532 IN_PROC_BROWSER_TEST_F(PageLoadMetricsBrowserTest, CSSTiming) { |
| 541 ASSERT_TRUE(embedded_test_server()->Start()); | 533 ASSERT_TRUE(embedded_test_server()->Start()); |
| 542 | 534 |
| 543 // Careful: Blink code clamps timestamps to 5us, so any CSS parsing we do here | 535 // Careful: Blink code clamps timestamps to 5us, so any CSS parsing we do here |
| 544 // must take >> 5us, otherwise we'll log 0 for the value and it will remain | 536 // must take >> 5us, otherwise we'll log 0 for the value and it will remain |
| 545 // unset here. | 537 // unset here. |
| 546 ui_test_utils::NavigateToURL( | 538 ui_test_utils::NavigateToURL( |
| 547 browser(), | 539 browser(), |
| 548 embedded_test_server()->GetURL("/page_load_metrics/page_with_css.html")); | 540 embedded_test_server()->GetURL("/page_load_metrics/page_with_css.html")); |
| 549 NavigateToUntrackedUrl(); | 541 NavigateToUntrackedUrl(); |
| 550 | 542 |
| 551 histogram_tester_.ExpectTotalCount(internal::kHistogramFirstContentfulPaint, | 543 histogram_tester_.ExpectTotalCount(internal::kHistogramFirstContentfulPaint, |
| 552 1); | 544 1); |
| 553 histogram_tester_.ExpectTotalCount( | 545 histogram_tester_.ExpectTotalCount( |
| 554 "PageLoad.CSSTiming.Parse.BeforeFirstContentfulPaint", 1); | 546 "PageLoad.CSSTiming.Parse.BeforeFirstContentfulPaint", 1); |
| 555 histogram_tester_.ExpectTotalCount( | 547 histogram_tester_.ExpectTotalCount( |
| 556 "PageLoad.CSSTiming.Update.BeforeFirstContentfulPaint", 1); | 548 "PageLoad.CSSTiming.Update.BeforeFirstContentfulPaint", 1); |
| 557 histogram_tester_.ExpectTotalCount( | 549 histogram_tester_.ExpectTotalCount( |
| 558 "PageLoad.CSSTiming.ParseAndUpdate.BeforeFirstContentfulPaint", 1); | 550 "PageLoad.CSSTiming.ParseAndUpdate.BeforeFirstContentfulPaint", 1); |
| 559 } | 551 } |
| OLD | NEW |