summaryrefslogtreecommitdiff
path: root/chromium/services/audio/service_metrics.cc
blob: c63b970a9398e9b98fc0896cdbcfa9be49546f09 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
// Copyright 2018 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

#include "services/audio/service_metrics.h"

#include "base/metrics/histogram_macros.h"
#include "base/time/tick_clock.h"
#include "base/trace_event/trace_event.h"

namespace audio {

ServiceMetrics::ServiceMetrics(const base::TickClock* clock) : clock_(clock) {}

ServiceMetrics::~ServiceMetrics() {
  LogHasNoConnectionsDuration();
}

void ServiceMetrics::HasConnections() {
  TRACE_EVENT_ASYNC_BEGIN0("audio", "Audio service has connections", this);
  has_connections_start_ = clock_->NowTicks();
  LogHasNoConnectionsDuration();
}

void ServiceMetrics::HasNoConnections() {
  TRACE_EVENT_ASYNC_END0("audio", "Audio service has connections", this);
  has_no_connections_start_ = clock_->NowTicks();
  DCHECK_NE(base::TimeTicks(), has_connections_start_);
  UMA_HISTOGRAM_CUSTOM_TIMES("Media.AudioService.HasConnectionsDuration",
                             clock_->NowTicks() - has_connections_start_,
                             base::TimeDelta(), base::TimeDelta::FromDays(7),
                             50);
  has_connections_start_ = base::TimeTicks();
}

void ServiceMetrics::LogHasNoConnectionsDuration() {
  // Service shuts down without having accepted any connections in its lifetime
  // or with active connections, meaning there is no "no connection" interval in
  // progress.
  if (has_no_connections_start_.is_null())
    return;

  UMA_HISTOGRAM_CUSTOM_TIMES("Media.AudioService.HasNoConnectionsDuration",
                             clock_->NowTicks() - has_no_connections_start_,
                             base::TimeDelta(),
                             base::TimeDelta::FromMinutes(10), 50);
  has_no_connections_start_ = base::TimeTicks();
}

}  // namespace audio