| 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 "components/scheduler/renderer/user_model.h" | 5 #include "components/scheduler/renderer/user_model.h" |
| 6 | 6 |
| 7 #include "base/metrics/histogram_macros.h" | 7 #include "base/metrics/histogram_macros.h" |
| 8 #include "base/metrics/user_metrics.h" |
| 9 #include "base/single_thread_task_runner.h" |
| 8 | 10 |
| 9 namespace scheduler { | 11 namespace scheduler { |
| 10 | 12 |
| 11 namespace { | 13 namespace { |
| 12 // This enum is used to back a histogram, and should therefore be treated as | 14 // This enum is used to back a histogram, and should therefore be treated as |
| 13 // append-only. | 15 // append-only. |
| 14 enum GesturePredictionResult { | 16 enum GesturePredictionResult { |
| 15 GESTURE_OCCURED_WAS_PREDICTED = 0, | 17 GESTURE_OCCURED_WAS_PREDICTED = 0, |
| 16 GESTURE_OCCURED_BUT_NOT_PREDICTED = 1, | 18 GESTURE_OCCURED_BUT_NOT_PREDICTED = 1, |
| 17 GESTURE_PREDICTED_BUT_DID_NOT_OCCUR = 2, | 19 GESTURE_PREDICTED_BUT_DID_NOT_OCCUR = 2, |
| 18 GESTURE_PREDICTION_RESULT_COUNT = 3 | 20 GESTURE_PREDICTION_RESULT_COUNT = 3 |
| 19 }; | 21 }; |
| 20 | 22 |
| 21 void RecordGesturePrediction(GesturePredictionResult result) { | 23 void RecordGesturePrediction(GesturePredictionResult result) { |
| 22 UMA_HISTOGRAM_ENUMERATION( | 24 UMA_HISTOGRAM_ENUMERATION( |
| 23 "RendererScheduler.UserModel.GesturePredictedCorrectly", result, | 25 "RendererScheduler.UserModel.GesturePredictedCorrectly", result, |
| 24 GESTURE_PREDICTION_RESULT_COUNT); | 26 GESTURE_PREDICTION_RESULT_COUNT); |
| 25 } | 27 } |
| 26 | 28 |
| 27 } // namespace | 29 } // namespace |
| 28 | 30 |
| 29 UserModel::UserModel() | 31 namespace features { |
| 30 : pending_input_event_count_(0), | 32 |
| 33 // Enables the recording of gestures as UMA user actions. |
| 34 // That feature is disabled by default and controlled from the server so as not |
| 35 // to generate too many UMA user actions. |
| 36 const base::Feature kRecordSchedulerGestureActions{ |
| 37 "RecordGestureActions", base::FEATURE_DISABLED_BY_DEFAULT}; |
| 38 |
| 39 } // namespace features |
| 40 |
| 41 UserModel::UserModel( |
| 42 scoped_refptr<base::SingleThreadTaskRunner> default_task_runner) |
| 43 : default_task_runner_(default_task_runner), |
| 44 pending_input_event_count_(0), |
| 31 is_gesture_active_(false), | 45 is_gesture_active_(false), |
| 32 is_gesture_expected_(false) {} | 46 is_gesture_expected_(false) {} |
| 33 UserModel::~UserModel() {} | 47 UserModel::~UserModel() {} |
| 34 | 48 |
| 35 void UserModel::DidStartProcessingInputEvent(blink::WebInputEvent::Type type, | 49 void UserModel::DidStartProcessingInputEvent(blink::WebInputEvent::Type type, |
| 36 const base::TimeTicks now) { | 50 const base::TimeTicks now) { |
| 37 last_input_signal_time_ = now; | 51 last_input_signal_time_ = now; |
| 38 if (type == blink::WebInputEvent::TouchStart || | 52 if (type == blink::WebInputEvent::TouchStart || |
| 39 type == blink::WebInputEvent::GestureScrollBegin || | 53 type == blink::WebInputEvent::GestureScrollBegin || |
| 40 type == blink::WebInputEvent::GesturePinchBegin) { | 54 type == blink::WebInputEvent::GesturePinchBegin) { |
| 41 // Only update stats once per gesture. | 55 // Only update stats once per gesture. |
| 42 if (!is_gesture_active_) { | 56 if (!is_gesture_active_) { |
| 43 last_gesture_start_time_ = now; | 57 last_gesture_start_time_ = now; |
| 44 | 58 |
| 59 if (base::FeatureList::IsEnabled( |
| 60 features::kRecordSchedulerGestureActions)) { |
| 61 default_task_runner_->PostTask( |
| 62 FROM_HERE, |
| 63 base::Bind(&base::RecordAction, |
| 64 base::UserMetricsAction( |
| 65 "RendererScheduler.UserModel.GestureStart"))); |
| 66 } |
| 67 |
| 45 RecordGesturePrediction(is_gesture_expected_ | 68 RecordGesturePrediction(is_gesture_expected_ |
| 46 ? GESTURE_OCCURED_WAS_PREDICTED | 69 ? GESTURE_OCCURED_WAS_PREDICTED |
| 47 : GESTURE_OCCURED_BUT_NOT_PREDICTED); | 70 : GESTURE_OCCURED_BUT_NOT_PREDICTED); |
| 48 | 71 |
| 49 if (!last_reset_time_.is_null()) { | 72 if (!last_reset_time_.is_null()) { |
| 50 base::TimeDelta time_since_reset = now - last_reset_time_; | 73 base::TimeDelta time_since_reset = now - last_reset_time_; |
| 51 UMA_HISTOGRAM_MEDIUM_TIMES( | 74 UMA_HISTOGRAM_MEDIUM_TIMES( |
| 52 "RendererScheduler.UserModel.GestureStartTimeSinceModelReset", | 75 "RendererScheduler.UserModel.GestureStartTimeSinceModelReset", |
| 53 time_since_reset); | 76 time_since_reset); |
| 54 } | 77 } |
| (...skipping 29 matching lines...) Expand all Loading... |
| 84 // metric that tracks its duration. | 107 // metric that tracks its duration. |
| 85 if (type == blink::WebInputEvent::GestureScrollEnd || | 108 if (type == blink::WebInputEvent::GestureScrollEnd || |
| 86 type == blink::WebInputEvent::GesturePinchEnd || | 109 type == blink::WebInputEvent::GesturePinchEnd || |
| 87 type == blink::WebInputEvent::GestureFlingStart || | 110 type == blink::WebInputEvent::GestureFlingStart || |
| 88 type == blink::WebInputEvent::TouchEnd) { | 111 type == blink::WebInputEvent::TouchEnd) { |
| 89 // Only update stats once per gesture. | 112 // Only update stats once per gesture. |
| 90 if (is_gesture_active_) { | 113 if (is_gesture_active_) { |
| 91 base::TimeDelta duration = now - last_gesture_start_time_; | 114 base::TimeDelta duration = now - last_gesture_start_time_; |
| 92 UMA_HISTOGRAM_TIMES("RendererScheduler.UserModel.GestureDuration", | 115 UMA_HISTOGRAM_TIMES("RendererScheduler.UserModel.GestureDuration", |
| 93 duration); | 116 duration); |
| 117 if (base::FeatureList::IsEnabled( |
| 118 features::kRecordSchedulerGestureActions)) { |
| 119 default_task_runner_->PostTask( |
| 120 FROM_HERE, |
| 121 base::Bind(&base::RecordAction, |
| 122 base::UserMetricsAction( |
| 123 "RendererScheduler.UserModel.GestureEnd"))); |
| 124 } |
| 94 } | 125 } |
| 95 is_gesture_active_ = false; | 126 is_gesture_active_ = false; |
| 96 } | 127 } |
| 97 | 128 |
| 98 TRACE_COUNTER1(TRACE_DISABLED_BY_DEFAULT("renderer.scheduler"), | 129 TRACE_COUNTER1(TRACE_DISABLED_BY_DEFAULT("renderer.scheduler"), |
| 99 "is_gesture_active", is_gesture_active_); | 130 "is_gesture_active", is_gesture_active_); |
| 100 | 131 |
| 101 pending_input_event_count_++; | 132 pending_input_event_count_++; |
| 102 } | 133 } |
| 103 | 134 |
| (...skipping 109 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 213 (last_gesture_expected_start_time_ - base::TimeTicks()) | 244 (last_gesture_expected_start_time_ - base::TimeTicks()) |
| 214 .InMillisecondsF()); | 245 .InMillisecondsF()); |
| 215 state->SetDouble("last_reset_time", | 246 state->SetDouble("last_reset_time", |
| 216 (last_reset_time_ - base::TimeTicks()).InMillisecondsF()); | 247 (last_reset_time_ - base::TimeTicks()).InMillisecondsF()); |
| 217 state->SetBoolean("is_gesture_expected", is_gesture_expected_); | 248 state->SetBoolean("is_gesture_expected", is_gesture_expected_); |
| 218 state->SetBoolean("is_gesture_active", is_gesture_active_); | 249 state->SetBoolean("is_gesture_active", is_gesture_active_); |
| 219 state->EndDictionary(); | 250 state->EndDictionary(); |
| 220 } | 251 } |
| 221 | 252 |
| 222 } // namespace scheduler | 253 } // namespace scheduler |
| OLD | NEW |