Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(46)

Side by Side Diff: content/browser/service_worker/service_worker_lifetime_tracker.cc

Issue 2706923003: Add UMA for how long service workers run for. (Closed)
Patch Set: tweaks, fmt Created 3 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
(Empty)
1 // Copyright 2017 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "content/browser/service_worker/service_worker_lifetime_tracker.h"
6
7 #include "base/bind.h"
8 #include "base/stl_util.h"
9 #include "base/time/default_tick_clock.h"
10 #include "content/browser/service_worker/service_worker_metrics.h"
11
12 namespace content {
13
14 ServiceWorkerLifetimeTracker::ServiceWorkerLifetimeTracker()
15 : ServiceWorkerLifetimeTracker(base::MakeUnique<base::DefaultTickClock>()) {
16 }
17
18 ServiceWorkerLifetimeTracker::ServiceWorkerLifetimeTracker(
19 std::unique_ptr<base::TickClock> tick_clock)
20 : tick_clock_(std::move(tick_clock)) {}
21
22 ServiceWorkerLifetimeTracker::~ServiceWorkerLifetimeTracker() = default;
23
24 void ServiceWorkerLifetimeTracker::StartTiming(int64_t embedded_worker_id) {
25 DCHECK(!base::ContainsKey(running_workers_, embedded_worker_id));
26
27 running_workers_[embedded_worker_id] = tick_clock_->NowTicks();
28 }
29
30 void ServiceWorkerLifetimeTracker::StopTiming(int64_t embedded_worker_id) {
31 auto it = running_workers_.find(embedded_worker_id);
32 if (it == running_workers_.end())
33 return;
34 ServiceWorkerMetrics::RecordRuntime(tick_clock_->NowTicks() - it->second);
35 running_workers_.erase(it);
36 }
37
38 void ServiceWorkerLifetimeTracker::AbortTiming(int64_t embedded_worker_id) {
39 auto it = running_workers_.find(embedded_worker_id);
40 if (it == running_workers_.end())
41 return;
42 running_workers_.erase(it);
43 }
44
45 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698