| 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 "chrome/browser/page_load_metrics/observers/from_gws_page_load_metrics_
observer.h" | 5 #include "chrome/browser/page_load_metrics/observers/from_gws_page_load_metrics_
observer.h" |
| 6 #include <string> | 6 #include <string> |
| 7 | 7 |
| 8 #include "base/metrics/histogram.h" | 8 #include "base/metrics/histogram.h" |
| 9 #include "base/strings/string_util.h" | 9 #include "base/strings/string_util.h" |
| 10 #include "chrome/browser/page_load_metrics/page_load_metrics_util.h" | 10 #include "chrome/browser/page_load_metrics/page_load_metrics_util.h" |
| (...skipping 20 matching lines...) Expand all Loading... |
| 31 "PageLoad.Clients.FromGoogleSearch.PaintTiming." | 31 "PageLoad.Clients.FromGoogleSearch.PaintTiming." |
| 32 "NavigationToFirstContentfulPaint"; | 32 "NavigationToFirstContentfulPaint"; |
| 33 const char kHistogramFromGWSParseStartToFirstContentfulPaint[] = | 33 const char kHistogramFromGWSParseStartToFirstContentfulPaint[] = |
| 34 "PageLoad.Clients.FromGoogleSearch.PaintTiming." | 34 "PageLoad.Clients.FromGoogleSearch.PaintTiming." |
| 35 "ParseStartToFirstContentfulPaint"; | 35 "ParseStartToFirstContentfulPaint"; |
| 36 const char kHistogramFromGWSParseDuration[] = | 36 const char kHistogramFromGWSParseDuration[] = |
| 37 "PageLoad.Clients.FromGoogleSearch.ParseTiming.ParseDuration"; | 37 "PageLoad.Clients.FromGoogleSearch.ParseTiming.ParseDuration"; |
| 38 const char kHistogramFromGWSParseStart[] = | 38 const char kHistogramFromGWSParseStart[] = |
| 39 "PageLoad.Clients.FromGoogleSearch.ParseTiming.NavigationToParseStart"; | 39 "PageLoad.Clients.FromGoogleSearch.ParseTiming.NavigationToParseStart"; |
| 40 | 40 |
| 41 const char kHistogramFromGWSAbortUnknownNavigationBeforeCommit[] = | 41 const char kHistogramFromGWSAbortNewNavigationBeforeCommit[] = |
| 42 "PageLoad.Clients.FromGoogleSearch.AbortTiming.UnknownNavigation." | 42 "PageLoad.Clients.FromGoogleSearch.AbortTiming.NewNavigation.BeforeCommit"; |
| 43 "BeforeCommit"; | |
| 44 const char kHistogramFromGWSAbortNewNavigationBeforePaint[] = | 43 const char kHistogramFromGWSAbortNewNavigationBeforePaint[] = |
| 45 "PageLoad.Clients.FromGoogleSearch.AbortTiming.NewNavigation.AfterCommit." | 44 "PageLoad.Clients.FromGoogleSearch.AbortTiming.NewNavigation.AfterCommit." |
| 46 "BeforePaint"; | 45 "BeforePaint"; |
| 47 const char kHistogramFromGWSAbortNewNavigationBeforeInteraction[] = | 46 const char kHistogramFromGWSAbortNewNavigationBeforeInteraction[] = |
| 48 "PageLoad.Clients.FromGoogleSearch.AbortTiming.NewNavigation.AfterPaint." | 47 "PageLoad.Clients.FromGoogleSearch.AbortTiming.NewNavigation.AfterPaint." |
| 49 "BeforeInteraction"; | 48 "BeforeInteraction"; |
| 50 const char kHistogramFromGWSAbortStopBeforeCommit[] = | 49 const char kHistogramFromGWSAbortStopBeforeCommit[] = |
| 51 "PageLoad.Clients.FromGoogleSearch.AbortTiming.Stop.BeforeCommit"; | 50 "PageLoad.Clients.FromGoogleSearch.AbortTiming.Stop.BeforeCommit"; |
| 52 const char kHistogramFromGWSAbortStopBeforePaint[] = | 51 const char kHistogramFromGWSAbortStopBeforePaint[] = |
| 53 "PageLoad.Clients.FromGoogleSearch.AbortTiming.Stop.AfterCommit." | 52 "PageLoad.Clients.FromGoogleSearch.AbortTiming.Stop.AfterCommit." |
| 54 "BeforePaint"; | 53 "BeforePaint"; |
| 55 const char kHistogramFromGWSAbortStopBeforeInteraction[] = | 54 const char kHistogramFromGWSAbortStopBeforeInteraction[] = |
| 56 "PageLoad.Clients.FromGoogleSearch.AbortTiming.Stop.AfterPaint." | 55 "PageLoad.Clients.FromGoogleSearch.AbortTiming.Stop.AfterPaint." |
| 57 "BeforeInteraction"; | 56 "BeforeInteraction"; |
| 58 const char kHistogramFromGWSAbortCloseBeforeCommit[] = | 57 const char kHistogramFromGWSAbortCloseBeforeCommit[] = |
| 59 "PageLoad.Clients.FromGoogleSearch.AbortTiming.Close.BeforeCommit"; | 58 "PageLoad.Clients.FromGoogleSearch.AbortTiming.Close.BeforeCommit"; |
| 60 const char kHistogramFromGWSAbortCloseBeforePaint[] = | 59 const char kHistogramFromGWSAbortCloseBeforePaint[] = |
| 61 "PageLoad.Clients.FromGoogleSearch.AbortTiming.Close.AfterCommit." | 60 "PageLoad.Clients.FromGoogleSearch.AbortTiming.Close.AfterCommit." |
| 62 "BeforePaint"; | 61 "BeforePaint"; |
| 63 const char kHistogramFromGWSAbortCloseBeforeInteraction[] = | 62 const char kHistogramFromGWSAbortCloseBeforeInteraction[] = |
| 64 "PageLoad.Clients.FromGoogleSearch.AbortTiming.Close.AfterPaint." | 63 "PageLoad.Clients.FromGoogleSearch.AbortTiming.Close.AfterPaint." |
| 65 "BeforeInteraction"; | 64 "BeforeInteraction"; |
| 66 const char kHistogramFromGWSAbortOtherBeforeCommit[] = | 65 const char kHistogramFromGWSAbortOtherBeforeCommit[] = |
| 67 "PageLoad.Clients.FromGoogleSearch.AbortTiming.Other.BeforeCommit"; | 66 "PageLoad.Clients.FromGoogleSearch.AbortTiming.Other.BeforeCommit"; |
| 67 const char kHistogramFromGWSAbortReloadBeforeCommit[] = |
| 68 "PageLoad.Clients.FromGoogleSearch.AbortTiming.Reload.BeforeCommit"; |
| 68 const char kHistogramFromGWSAbortReloadBeforePaint[] = | 69 const char kHistogramFromGWSAbortReloadBeforePaint[] = |
| 69 "PageLoad.Clients.FromGoogleSearch.AbortTiming.Reload.AfterCommit." | 70 "PageLoad.Clients.FromGoogleSearch.AbortTiming.Reload.AfterCommit." |
| 70 "BeforePaint"; | 71 "BeforePaint"; |
| 71 const char kHistogramFromGWSAbortReloadBeforeInteraction[] = | 72 const char kHistogramFromGWSAbortReloadBeforeInteraction[] = |
| 72 "PageLoad.Clients.FromGoogleSearch.AbortTiming.Reload.AfterPaint." | 73 "PageLoad.Clients.FromGoogleSearch.AbortTiming.Reload.AfterPaint." |
| 73 "Before1sDelayedInteraction"; | 74 "Before1sDelayedInteraction"; |
| 75 const char kHistogramFromGWSAbortForwardBackBeforeCommit[] = |
| 76 "PageLoad.Clients.FromGoogleSearch.AbortTiming.ForwardBackNavigation." |
| 77 "BeforeCommit"; |
| 74 const char kHistogramFromGWSAbortForwardBackBeforePaint[] = | 78 const char kHistogramFromGWSAbortForwardBackBeforePaint[] = |
| 75 "PageLoad.Clients.FromGoogleSearch.AbortTiming.ForwardBackNavigation." | 79 "PageLoad.Clients.FromGoogleSearch.AbortTiming.ForwardBackNavigation." |
| 76 "AfterCommit.BeforePaint"; | 80 "AfterCommit.BeforePaint"; |
| 77 const char kHistogramFromGWSAbortForwardBackBeforeInteraction[] = | 81 const char kHistogramFromGWSAbortForwardBackBeforeInteraction[] = |
| 78 "PageLoad.Clients.FromGoogleSearch.AbortTiming.ForwardBackNavigation." | 82 "PageLoad.Clients.FromGoogleSearch.AbortTiming.ForwardBackNavigation." |
| 79 "AfterPaint.Before1sDelayedInteraction"; | 83 "AfterPaint.Before1sDelayedInteraction"; |
| 80 | 84 |
| 81 } // namespace internal | 85 } // namespace internal |
| 82 | 86 |
| 83 namespace { | 87 namespace { |
| (...skipping 19 matching lines...) Expand all Loading... |
| 103 time_to_abort); | 107 time_to_abort); |
| 104 break; | 108 break; |
| 105 case UserAbortType::ABORT_FORWARD_BACK: | 109 case UserAbortType::ABORT_FORWARD_BACK: |
| 106 PAGE_LOAD_HISTOGRAM( | 110 PAGE_LOAD_HISTOGRAM( |
| 107 internal::kHistogramFromGWSAbortForwardBackBeforePaint, | 111 internal::kHistogramFromGWSAbortForwardBackBeforePaint, |
| 108 time_to_abort); | 112 time_to_abort); |
| 109 break; | 113 break; |
| 110 default: | 114 default: |
| 111 // These should only be logged for provisional aborts. | 115 // These should only be logged for provisional aborts. |
| 112 DCHECK_NE(abort_type, UserAbortType::ABORT_OTHER); | 116 DCHECK_NE(abort_type, UserAbortType::ABORT_OTHER); |
| 113 DCHECK_NE(abort_type, UserAbortType::ABORT_UNKNOWN_NAVIGATION); | |
| 114 break; | 117 break; |
| 115 } | 118 } |
| 116 } | 119 } |
| 117 | 120 |
| 118 void LogAbortsAfterPaintBeforeInteraction(UserAbortType abort_type, | 121 void LogAbortsAfterPaintBeforeInteraction(UserAbortType abort_type, |
| 119 base::TimeDelta time_to_abort) { | 122 base::TimeDelta time_to_abort) { |
| 120 switch (abort_type) { | 123 switch (abort_type) { |
| 121 case UserAbortType::ABORT_STOP: | 124 case UserAbortType::ABORT_STOP: |
| 122 PAGE_LOAD_HISTOGRAM(internal::kHistogramFromGWSAbortStopBeforeInteraction, | 125 PAGE_LOAD_HISTOGRAM(internal::kHistogramFromGWSAbortStopBeforeInteraction, |
| 123 time_to_abort); | 126 time_to_abort); |
| (...skipping 14 matching lines...) Expand all Loading... |
| 138 time_to_abort); | 141 time_to_abort); |
| 139 break; | 142 break; |
| 140 case UserAbortType::ABORT_FORWARD_BACK: | 143 case UserAbortType::ABORT_FORWARD_BACK: |
| 141 PAGE_LOAD_HISTOGRAM( | 144 PAGE_LOAD_HISTOGRAM( |
| 142 internal::kHistogramFromGWSAbortForwardBackBeforeInteraction, | 145 internal::kHistogramFromGWSAbortForwardBackBeforeInteraction, |
| 143 time_to_abort); | 146 time_to_abort); |
| 144 break; | 147 break; |
| 145 default: | 148 default: |
| 146 // These should only be logged for provisional aborts. | 149 // These should only be logged for provisional aborts. |
| 147 DCHECK_NE(abort_type, UserAbortType::ABORT_OTHER); | 150 DCHECK_NE(abort_type, UserAbortType::ABORT_OTHER); |
| 148 DCHECK_NE(abort_type, UserAbortType::ABORT_UNKNOWN_NAVIGATION); | |
| 149 break; | 151 break; |
| 150 } | 152 } |
| 151 } | 153 } |
| 152 | 154 |
| 153 void LogProvisionalAborts(UserAbortType abort_type, | 155 void LogProvisionalAborts(UserAbortType abort_type, |
| 154 base::TimeDelta time_to_abort) { | 156 base::TimeDelta time_to_abort) { |
| 155 switch (abort_type) { | 157 switch (abort_type) { |
| 156 case UserAbortType::ABORT_STOP: | 158 case UserAbortType::ABORT_STOP: |
| 157 PAGE_LOAD_HISTOGRAM(internal::kHistogramFromGWSAbortStopBeforeCommit, | 159 PAGE_LOAD_HISTOGRAM(internal::kHistogramFromGWSAbortStopBeforeCommit, |
| 158 time_to_abort); | 160 time_to_abort); |
| 159 break; | 161 break; |
| 160 case UserAbortType::ABORT_CLOSE: | 162 case UserAbortType::ABORT_CLOSE: |
| 161 PAGE_LOAD_HISTOGRAM(internal::kHistogramFromGWSAbortCloseBeforeCommit, | 163 PAGE_LOAD_HISTOGRAM(internal::kHistogramFromGWSAbortCloseBeforeCommit, |
| 162 time_to_abort); | 164 time_to_abort); |
| 163 break; | 165 break; |
| 164 case UserAbortType::ABORT_UNKNOWN_NAVIGATION: | |
| 165 PAGE_LOAD_HISTOGRAM( | |
| 166 internal::kHistogramFromGWSAbortUnknownNavigationBeforeCommit, | |
| 167 time_to_abort); | |
| 168 break; | |
| 169 case UserAbortType::ABORT_OTHER: | 166 case UserAbortType::ABORT_OTHER: |
| 170 PAGE_LOAD_HISTOGRAM(internal::kHistogramFromGWSAbortOtherBeforeCommit, | 167 PAGE_LOAD_HISTOGRAM(internal::kHistogramFromGWSAbortOtherBeforeCommit, |
| 171 time_to_abort); | 168 time_to_abort); |
| 172 break; | 169 break; |
| 170 case UserAbortType::ABORT_NEW_NAVIGATION: |
| 171 PAGE_LOAD_HISTOGRAM( |
| 172 internal::kHistogramFromGWSAbortNewNavigationBeforeCommit, |
| 173 time_to_abort); |
| 174 break; |
| 175 case UserAbortType::ABORT_RELOAD: |
| 176 PAGE_LOAD_HISTOGRAM(internal::kHistogramFromGWSAbortReloadBeforeCommit, |
| 177 time_to_abort); |
| 178 break; |
| 179 case UserAbortType::ABORT_FORWARD_BACK: |
| 180 PAGE_LOAD_HISTOGRAM( |
| 181 internal::kHistogramFromGWSAbortForwardBackBeforeCommit, |
| 182 time_to_abort); |
| 183 break; |
| 173 default: | 184 default: |
| 174 // There are other abort types that could be logged, but they occur in | 185 NOTREACHED(); |
| 175 // very small amounts that it isn't worth logging. | |
| 176 // TODO(csharrison): Once transitions can be acquired before commit, log | |
| 177 // the Reload/NewNavigation/ForwardBack variants here. | |
| 178 break; | 186 break; |
| 179 } | 187 } |
| 180 } | 188 } |
| 181 | 189 |
| 182 bool WasAbortedInForeground( | 190 bool WasAbortedInForeground( |
| 183 UserAbortType abort_type, | 191 UserAbortType abort_type, |
| 184 const base::Optional<base::TimeDelta>& time_to_abort, | 192 const base::Optional<base::TimeDelta>& time_to_abort, |
| 185 const page_load_metrics::PageLoadExtraInfo& info) { | 193 const page_load_metrics::PageLoadExtraInfo& info) { |
| 186 if (!time_to_abort) | 194 if (!time_to_abort) |
| 187 return false; | 195 return false; |
| (...skipping 479 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 667 } | 675 } |
| 668 | 676 |
| 669 void FromGWSPageLoadMetricsLogger::OnUserInput( | 677 void FromGWSPageLoadMetricsLogger::OnUserInput( |
| 670 const blink::WebInputEvent& event) { | 678 const blink::WebInputEvent& event) { |
| 671 if (first_paint_triggered_ && !first_user_interaction_after_paint_) { | 679 if (first_paint_triggered_ && !first_user_interaction_after_paint_) { |
| 672 DCHECK(!navigation_start_.is_null()); | 680 DCHECK(!navigation_start_.is_null()); |
| 673 first_user_interaction_after_paint_ = | 681 first_user_interaction_after_paint_ = |
| 674 base::TimeTicks::Now() - navigation_start_; | 682 base::TimeTicks::Now() - navigation_start_; |
| 675 } | 683 } |
| 676 } | 684 } |
| OLD | NEW |