blob: e0ba0ce9ba775c41612a316e6ac3fe6e7a69102a [file] [log] [blame]
// Copyright 2017 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 "components/metrics/stability_metrics_provider.h"
#include "base/test/metrics/histogram_tester.h"
#include "build/build_config.h"
#include "components/prefs/testing_pref_service.h"
#include "testing/gtest/include/gtest/gtest.h"
#include "third_party/metrics_proto/system_profile.pb.h"
namespace metrics {
class StabilityMetricsProviderTest : public testing::Test {
public:
StabilityMetricsProviderTest() {
StabilityMetricsProvider::RegisterPrefs(prefs_.registry());
}
~StabilityMetricsProviderTest() override {}
protected:
TestingPrefServiceSimple prefs_;
private:
DISALLOW_COPY_AND_ASSIGN(StabilityMetricsProviderTest);
};
TEST_F(StabilityMetricsProviderTest, ProvideStabilityMetrics) {
StabilityMetricsProvider stability_provider(&prefs_);
MetricsProvider* provider = &stability_provider;
SystemProfileProto system_profile;
provider->ProvideStabilityMetrics(&system_profile);
const SystemProfileProto_Stability& stability = system_profile.stability();
// Initial log metrics: only expected if non-zero.
EXPECT_FALSE(stability.has_launch_count());
EXPECT_FALSE(stability.has_crash_count());
EXPECT_FALSE(stability.has_incomplete_shutdown_count());
EXPECT_FALSE(stability.has_breakpad_registration_success_count());
EXPECT_FALSE(stability.has_breakpad_registration_failure_count());
EXPECT_FALSE(stability.has_debugger_present_count());
EXPECT_FALSE(stability.has_debugger_not_present_count());
}
TEST_F(StabilityMetricsProviderTest, RecordStabilityMetrics) {
{
StabilityMetricsProvider recorder(&prefs_);
recorder.LogLaunch();
recorder.LogCrash(base::Time());
recorder.MarkSessionEndCompleted(false);
recorder.CheckLastSessionEndCompleted();
recorder.RecordBreakpadRegistration(true);
recorder.RecordBreakpadRegistration(false);
recorder.RecordBreakpadHasDebugger(true);
recorder.RecordBreakpadHasDebugger(false);
}
{
StabilityMetricsProvider stability_provider(&prefs_);
MetricsProvider* provider = &stability_provider;
SystemProfileProto system_profile;
provider->ProvideStabilityMetrics(&system_profile);
const SystemProfileProto_Stability& stability = system_profile.stability();
// Initial log metrics: only expected if non-zero.
EXPECT_EQ(1, stability.launch_count());
EXPECT_EQ(1, stability.crash_count());
EXPECT_EQ(1, stability.incomplete_shutdown_count());
EXPECT_EQ(1, stability.breakpad_registration_success_count());
EXPECT_EQ(1, stability.breakpad_registration_failure_count());
EXPECT_EQ(1, stability.debugger_present_count());
EXPECT_EQ(1, stability.debugger_not_present_count());
}
}
#if defined(OS_WIN)
namespace {
class TestingStabilityMetricsProvider : public StabilityMetricsProvider {
public:
TestingStabilityMetricsProvider(PrefService* local_state,
base::Time unclean_session_time)
: StabilityMetricsProvider(local_state),
unclean_session_time_(unclean_session_time) {}
bool IsUncleanSystemSession(base::Time last_live_timestamp) override {
return last_live_timestamp == unclean_session_time_;
}
private:
const base::Time unclean_session_time_;
};
} // namespace
TEST_F(StabilityMetricsProviderTest, RecordSystemCrashMetrics) {
{
base::Time unclean_time = base::Time::Now();
TestingStabilityMetricsProvider recorder(&prefs_, unclean_time);
// Any crash with a last_live_timestamp equal to unclean_time will
// be logged as a system crash as per the implementation of
// TestingStabilityMetricsProvider, so this will log a system crash.
recorder.LogCrash(unclean_time);
// Record a crash with no system crash.
recorder.LogCrash(unclean_time - base::TimeDelta::FromMinutes(1));
}
{
StabilityMetricsProvider stability_provider(&prefs_);
MetricsProvider* provider = &stability_provider;
SystemProfileProto system_profile;
base::HistogramTester histogram_tester;
provider->ProvideStabilityMetrics(&system_profile);
const SystemProfileProto_Stability& stability = system_profile.stability();
// Two crashes, one system crash.
EXPECT_EQ(2, stability.crash_count());
histogram_tester.ExpectTotalCount("Stability.Internals.SystemCrashCount",
1);
}
}
#endif
} // namespace metrics