1 // Copyright (c) 2012 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.
5 #include "chrome/browser/spellchecker/spellcheck_host_metrics.h"
7 #include "base/basictypes.h"
8 #include "base/memory/scoped_ptr.h"
9 #include "base/message_loop/message_loop.h"
10 #include "base/metrics/histogram.h"
11 #include "base/metrics/histogram_samples.h"
12 #include "base/metrics/statistics_recorder.h"
13 #include "base/strings/utf_string_conversions.h"
14 #include "testing/gtest/include/gtest/gtest.h"
17 // For version specific disabled tests below (http://crbug.com/230534).
18 #include "base/win/windows_version.h"
21 using base::HistogramBase;
22 using base::HistogramSamples;
23 using base::StatisticsRecorder;
25 class SpellcheckHostMetricsTest : public testing::Test {
27 SpellcheckHostMetricsTest() : loop_(base::MessageLoop::TYPE_DEFAULT) {
30 virtual void SetUp() OVERRIDE {
31 base::StatisticsRecorder::Initialize();
32 metrics_.reset(new SpellCheckHostMetrics);
35 SpellCheckHostMetrics* metrics() { return metrics_.get(); }
36 void RecordWordCountsForTesting() { metrics_->RecordWordCounts(); }
39 base::MessageLoop loop_;
40 scoped_ptr<SpellCheckHostMetrics> metrics_;
43 TEST_F(SpellcheckHostMetricsTest, RecordEnabledStats) {
44 scoped_ptr<HistogramSamples> baseline;
45 HistogramBase* histogram =
46 StatisticsRecorder::FindHistogram("SpellCheck.Enabled");
48 baseline = histogram->SnapshotSamples();
50 metrics()->RecordEnabledStats(false);
53 StatisticsRecorder::FindHistogram("SpellCheck.Enabled");
54 ASSERT_TRUE(histogram != NULL);
55 scoped_ptr<HistogramSamples> samples(histogram->SnapshotSamples());
57 samples->Subtract(*baseline);
58 EXPECT_EQ(1, samples->GetCount(0));
59 EXPECT_EQ(0, samples->GetCount(1));
61 baseline.reset(samples.release());
63 metrics()->RecordEnabledStats(true);
66 StatisticsRecorder::FindHistogram("SpellCheck.Enabled");
67 ASSERT_TRUE(histogram != NULL);
68 samples = histogram->SnapshotSamples();
69 samples->Subtract(*baseline);
70 EXPECT_EQ(0, samples->GetCount(0));
71 EXPECT_EQ(1, samples->GetCount(1));
74 TEST_F(SpellcheckHostMetricsTest, CustomWordStats) {
76 // Failing consistently on Win7. See crbug.com/230534.
77 if (base::win::GetVersion() >= base::win::VERSION_VISTA)
80 SpellCheckHostMetrics::RecordCustomWordCountStats(123);
82 // Determine if test failures are due the statistics recorder not being
83 // available or because the histogram just isn't there: crbug.com/230534.
84 EXPECT_TRUE(StatisticsRecorder::IsActive());
86 HistogramBase* histogram =
87 StatisticsRecorder::FindHistogram("SpellCheck.CustomWords");
88 ASSERT_TRUE(histogram != NULL);
89 scoped_ptr<HistogramSamples> baseline = histogram->SnapshotSamples();
91 SpellCheckHostMetrics::RecordCustomWordCountStats(23);
93 StatisticsRecorder::FindHistogram("SpellCheck.CustomWords");
94 ASSERT_TRUE(histogram != NULL);
95 scoped_ptr<HistogramSamples> samples = histogram->SnapshotSamples();
97 samples->Subtract(*baseline);
98 EXPECT_EQ(23,samples->sum());
101 TEST_F(SpellcheckHostMetricsTest, RecordWordCountsDiscardsDuplicates) {
102 // This test ensures that RecordWordCounts only records metrics if they
103 // have changed from the last invocation.
104 const char* histogramName[] = {
105 "SpellCheck.CheckedWords",
106 "SpellCheck.MisspelledWords",
107 "SpellCheck.ReplacedWords",
108 "SpellCheck.UniqueWords",
109 "SpellCheck.ShownSuggestions"
112 // Ensure all histograms exist.
113 metrics()->RecordCheckedWordStats(string16(ASCIIToUTF16("test")), false);
114 RecordWordCountsForTesting();
116 // Get baselines for all affected histograms.
117 scoped_ptr<HistogramSamples> baselines[arraysize(histogramName)];
118 for (size_t i = 0; i < arraysize(histogramName); ++i) {
119 HistogramBase* histogram =
120 StatisticsRecorder::FindHistogram(histogramName[i]);
122 baselines[i] = histogram->SnapshotSamples();
125 // Nothing changed, so this invocation should not affect any histograms.
126 RecordWordCountsForTesting();
128 // Get samples for all affected histograms.
129 scoped_ptr<HistogramSamples> samples[arraysize(histogramName)];
130 for (size_t i = 0; i < arraysize(histogramName); ++i) {
131 HistogramBase* histogram =
132 StatisticsRecorder::FindHistogram(histogramName[i]);
133 ASSERT_TRUE(histogram != NULL);
134 samples[i] = histogram->SnapshotSamples();
135 if (baselines[i].get())
136 samples[i]->Subtract(*baselines[i]);
138 EXPECT_EQ(0, samples[i]->TotalCount());
142 TEST_F(SpellcheckHostMetricsTest, RecordSpellingServiceStats) {
143 const char kMetricName[] = "SpellCheck.SpellingService.Enabled";
144 scoped_ptr<HistogramSamples> baseline;
145 HistogramBase* histogram = StatisticsRecorder::FindHistogram(kMetricName);
147 baseline = histogram->SnapshotSamples();
149 metrics()->RecordSpellingServiceStats(false);
152 StatisticsRecorder::FindHistogram(kMetricName);
153 ASSERT_TRUE(histogram != NULL);
154 scoped_ptr<HistogramSamples> samples(histogram->SnapshotSamples());
156 samples->Subtract(*baseline);
157 EXPECT_EQ(1, samples->GetCount(0));
158 EXPECT_EQ(0, samples->GetCount(1));
160 baseline.reset(samples.release());
162 metrics()->RecordSpellingServiceStats(true);
165 StatisticsRecorder::FindHistogram(kMetricName);
166 ASSERT_TRUE(histogram != NULL);
167 samples = histogram->SnapshotSamples();
168 samples->Subtract(*baseline);
169 EXPECT_EQ(0, samples->GetCount(0));
170 EXPECT_EQ(1, samples->GetCount(1));