| // Copyright 2015 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/call_stack_profile_metrics_provider.h" |
| |
| #include <utility> |
| |
| #include "base/macros.h" |
| #include "base/test/scoped_feature_list.h" |
| #include "testing/gtest/include/gtest/gtest.h" |
| #include "third_party/metrics_proto/chrome_user_metrics_extension.pb.h" |
| |
| namespace metrics { |
| |
| // This test fixture enables the feature that |
| // CallStackProfileMetricsProvider depends on to report a profile. |
| class CallStackProfileMetricsProviderTest : public testing::Test { |
| public: |
| CallStackProfileMetricsProviderTest() { |
| scoped_feature_list_.InitAndEnableFeature(TestState::kEnableReporting); |
| TestState::ResetStaticStateForTesting(); |
| } |
| |
| ~CallStackProfileMetricsProviderTest() override {} |
| |
| private: |
| // Exposes the feature from the CallStackProfileMetricsProvider. |
| class TestState : public CallStackProfileMetricsProvider { |
| public: |
| using CallStackProfileMetricsProvider::kEnableReporting; |
| using CallStackProfileMetricsProvider::ResetStaticStateForTesting; |
| }; |
| |
| base::test::ScopedFeatureList scoped_feature_list_; |
| |
| DISALLOW_COPY_AND_ASSIGN(CallStackProfileMetricsProviderTest); |
| }; |
| |
| // Checks that the pending profile is passed to ProvideCurrentSessionData. |
| TEST_F(CallStackProfileMetricsProviderTest, ProvideCurrentSessionData) { |
| CallStackProfileMetricsProvider provider; |
| provider.OnRecordingEnabled(); |
| CallStackProfileMetricsProvider::ReceiveCompletedProfile( |
| base::TimeTicks::Now(), SampledProfile()); |
| ChromeUserMetricsExtension uma_proto; |
| provider.ProvideCurrentSessionData(&uma_proto); |
| ASSERT_EQ(1, uma_proto.sampled_profile().size()); |
| } |
| |
| // Checks that the pending profile is provided to ProvideCurrentSessionData |
| // when collected before CallStackProfileMetricsProvider is instantiated. |
| TEST_F(CallStackProfileMetricsProviderTest, |
| ProfileProvidedWhenCollectedBeforeInstantiation) { |
| CallStackProfileMetricsProvider::ReceiveCompletedProfile( |
| base::TimeTicks::Now(), SampledProfile()); |
| CallStackProfileMetricsProvider provider; |
| provider.OnRecordingEnabled(); |
| ChromeUserMetricsExtension uma_proto; |
| provider.ProvideCurrentSessionData(&uma_proto); |
| EXPECT_EQ(1, uma_proto.sampled_profile_size()); |
| } |
| |
| // Checks that the pending profile is not provided to ProvideCurrentSessionData |
| // while recording is disabled. |
| TEST_F(CallStackProfileMetricsProviderTest, ProfileNotProvidedWhileDisabled) { |
| CallStackProfileMetricsProvider provider; |
| provider.OnRecordingDisabled(); |
| CallStackProfileMetricsProvider::ReceiveCompletedProfile( |
| base::TimeTicks::Now(), SampledProfile()); |
| ChromeUserMetricsExtension uma_proto; |
| provider.ProvideCurrentSessionData(&uma_proto); |
| EXPECT_EQ(0, uma_proto.sampled_profile_size()); |
| } |
| |
| // Checks that the pending profile is not provided to ProvideCurrentSessionData |
| // if recording is disabled while profiling. |
| TEST_F(CallStackProfileMetricsProviderTest, |
| ProfileNotProvidedAfterChangeToDisabled) { |
| CallStackProfileMetricsProvider provider; |
| provider.OnRecordingEnabled(); |
| base::TimeTicks profile_start_time = base::TimeTicks::Now(); |
| provider.OnRecordingDisabled(); |
| CallStackProfileMetricsProvider::ReceiveCompletedProfile(profile_start_time, |
| SampledProfile()); |
| ChromeUserMetricsExtension uma_proto; |
| provider.ProvideCurrentSessionData(&uma_proto); |
| EXPECT_EQ(0, uma_proto.sampled_profile_size()); |
| } |
| |
| // Checks that the pending profile is not provided to ProvideCurrentSessionData |
| // if recording is enabled, but then disabled and reenabled while profiling. |
| TEST_F(CallStackProfileMetricsProviderTest, |
| ProfileNotProvidedAfterChangeToDisabledThenEnabled) { |
| CallStackProfileMetricsProvider provider; |
| provider.OnRecordingEnabled(); |
| base::TimeTicks profile_start_time = base::TimeTicks::Now(); |
| provider.OnRecordingDisabled(); |
| provider.OnRecordingEnabled(); |
| CallStackProfileMetricsProvider::ReceiveCompletedProfile(profile_start_time, |
| SampledProfile()); |
| ChromeUserMetricsExtension uma_proto; |
| provider.ProvideCurrentSessionData(&uma_proto); |
| EXPECT_EQ(0, uma_proto.sampled_profile_size()); |
| } |
| |
| // Checks that the pending profile is provided to ProvideCurrentSessionData |
| // if recording is disabled, but then enabled while profiling. |
| TEST_F(CallStackProfileMetricsProviderTest, |
| ProfileNotProvidedAfterChangeFromDisabled) { |
| CallStackProfileMetricsProvider provider; |
| provider.OnRecordingDisabled(); |
| base::TimeTicks profile_start_time = base::TimeTicks::Now(); |
| provider.OnRecordingEnabled(); |
| CallStackProfileMetricsProvider::ReceiveCompletedProfile(profile_start_time, |
| SampledProfile()); |
| ChromeUserMetricsExtension uma_proto; |
| provider.ProvideCurrentSessionData(&uma_proto); |
| EXPECT_EQ(0, uma_proto.sampled_profile_size()); |
| } |
| |
| } // namespace metrics |