| OLD | NEW |
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "chrome/renderer/translate/translate_helper_metrics.h" | 5 #include "chrome/renderer/translate/translate_helper_metrics.h" |
| 6 | 6 |
| 7 #include "base/basictypes.h" | 7 #include "base/basictypes.h" |
| 8 #include "base/memory/scoped_ptr.h" | 8 #include "base/memory/scoped_ptr.h" |
| 9 #include "base/metrics/histogram.h" | 9 #include "base/metrics/histogram.h" |
| 10 #include "base/metrics/histogram_samples.h" | 10 #include "base/metrics/histogram_samples.h" |
| (...skipping 15 matching lines...) Expand all Loading... |
| 26 : key_(key), | 26 : key_(key), |
| 27 base_samples_(NULL), | 27 base_samples_(NULL), |
| 28 samples_(NULL) { | 28 samples_(NULL) { |
| 29 StatisticsRecorder::Initialize(); | 29 StatisticsRecorder::Initialize(); |
| 30 | 30 |
| 31 HistogramBase* histogram = StatisticsRecorder::FindHistogram(key_); | 31 HistogramBase* histogram = StatisticsRecorder::FindHistogram(key_); |
| 32 if (histogram) | 32 if (histogram) |
| 33 base_samples_ = histogram->SnapshotSamples(); | 33 base_samples_ = histogram->SnapshotSamples(); |
| 34 } | 34 } |
| 35 | 35 |
| 36 void CheckContentLanguage(int expected_not_provided, | 36 void CheckLanguage(TranslateHelperMetrics::MetricsNameIndex index, |
| 37 int expected_valid, | 37 int expected_not_provided, |
| 38 int expected_invalid) { | 38 int expected_valid, |
| 39 ASSERT_EQ(TranslateHelperMetrics::GetMetricsName( | 39 int expected_invalid) { |
| 40 TranslateHelperMetrics::UMA_CONTENT_LANGUAGE), key_); | 40 ASSERT_EQ(TranslateHelperMetrics::GetMetricsName(index), key_); |
| 41 | 41 |
| 42 Snapshot(); | 42 Snapshot(); |
| 43 | 43 |
| 44 EXPECT_EQ( | 44 EXPECT_EQ(expected_not_provided, |
| 45 expected_not_provided, | 45 GetCount(TranslateHelperMetrics::LANGUAGE_NOT_PROVIDED)); |
| 46 GetCount(TranslateHelperMetrics::CONTENT_LANGUAGE_NOT_PROVIDED)); | 46 EXPECT_EQ(expected_valid, |
| 47 EXPECT_EQ( | 47 GetCount(TranslateHelperMetrics::LANGUAGE_VALID)); |
| 48 expected_valid, | 48 EXPECT_EQ(expected_invalid, |
| 49 GetCount(TranslateHelperMetrics::CONTENT_LANGUAGE_VALID)); | 49 GetCount(TranslateHelperMetrics::LANGUAGE_INVALID)); |
| 50 EXPECT_EQ( | |
| 51 expected_invalid, | |
| 52 GetCount(TranslateHelperMetrics::CONTENT_LANGUAGE_INVALID)); | |
| 53 } | 50 } |
| 54 | 51 |
| 55 void CheckLanguageVerification(int expected_cld_disabled, | 52 void CheckLanguageVerification(int expected_cld_disabled, |
| 56 int expected_cld_only, | 53 int expected_cld_only, |
| 57 int expected_unknown, | 54 int expected_unknown, |
| 58 int expected_cld_agree, | 55 int expected_cld_agree, |
| 59 int expected_cld_disagree) { | 56 int expected_cld_disagree) { |
| 60 ASSERT_EQ(TranslateHelperMetrics::GetMetricsName( | 57 ASSERT_EQ(TranslateHelperMetrics::GetMetricsName( |
| 61 TranslateHelperMetrics::UMA_LANGUAGE_VERIFICATION), key_); | 58 TranslateHelperMetrics::UMA_LANGUAGE_VERIFICATION), key_); |
| 62 | 59 |
| (...skipping 80 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 143 | 140 |
| 144 DISALLOW_COPY_AND_ASSIGN(MetricsRecorder); | 141 DISALLOW_COPY_AND_ASSIGN(MetricsRecorder); |
| 145 }; | 142 }; |
| 146 | 143 |
| 147 } // namespace | 144 } // namespace |
| 148 | 145 |
| 149 TEST(TranslateHelperMetricsTest, ReportContentLanguage) { | 146 TEST(TranslateHelperMetricsTest, ReportContentLanguage) { |
| 150 MetricsRecorder recorder(TranslateHelperMetrics::GetMetricsName( | 147 MetricsRecorder recorder(TranslateHelperMetrics::GetMetricsName( |
| 151 TranslateHelperMetrics::UMA_CONTENT_LANGUAGE)); | 148 TranslateHelperMetrics::UMA_CONTENT_LANGUAGE)); |
| 152 | 149 |
| 153 recorder.CheckContentLanguage(0, 0, 0); | 150 recorder.CheckLanguage(TranslateHelperMetrics::UMA_CONTENT_LANGUAGE, 0, 0, 0); |
| 154 TranslateHelperMetrics::ReportContentLanguage(std::string(), std::string()); | 151 TranslateHelperMetrics::ReportContentLanguage(std::string(), std::string()); |
| 155 recorder.CheckContentLanguage(1, 0, 0); | 152 recorder.CheckLanguage(TranslateHelperMetrics::UMA_CONTENT_LANGUAGE, 1, 0, 0); |
| 156 TranslateHelperMetrics::ReportContentLanguage("ja_JP", "ja-JP"); | 153 TranslateHelperMetrics::ReportContentLanguage("ja_JP", "ja-JP"); |
| 157 recorder.CheckContentLanguage(1, 0, 1); | 154 recorder.CheckLanguage(TranslateHelperMetrics::UMA_CONTENT_LANGUAGE, 1, 0, 1); |
| 158 TranslateHelperMetrics::ReportContentLanguage("en", "en"); | 155 TranslateHelperMetrics::ReportContentLanguage("en", "en"); |
| 159 recorder.CheckContentLanguage(1, 1, 1); | 156 recorder.CheckLanguage(TranslateHelperMetrics::UMA_CONTENT_LANGUAGE, 1, 1, 1); |
| 157 } |
| 158 |
| 159 TEST(TranslateHelperMetricsTest, ReportHtmlLang) { |
| 160 MetricsRecorder recorder(TranslateHelperMetrics::GetMetricsName( |
| 161 TranslateHelperMetrics::UMA_HTML_LANG)); |
| 162 |
| 163 recorder.CheckLanguage(TranslateHelperMetrics::UMA_HTML_LANG, 0, 0, 0); |
| 164 TranslateHelperMetrics::ReportHtmlLang(std::string(), std::string()); |
| 165 recorder.CheckLanguage(TranslateHelperMetrics::UMA_HTML_LANG, 1, 0, 0); |
| 166 TranslateHelperMetrics::ReportHtmlLang("ja_JP", "ja-JP"); |
| 167 recorder.CheckLanguage(TranslateHelperMetrics::UMA_HTML_LANG, 1, 0, 1); |
| 168 TranslateHelperMetrics::ReportHtmlLang("en", "en"); |
| 169 recorder.CheckLanguage(TranslateHelperMetrics::UMA_HTML_LANG, 1, 1, 1); |
| 160 } | 170 } |
| 161 | 171 |
| 162 TEST(TranslateHelperMetricsTest, ReportLanguageVerification) { | 172 TEST(TranslateHelperMetricsTest, ReportLanguageVerification) { |
| 163 MetricsRecorder recorder(TranslateHelperMetrics::GetMetricsName( | 173 MetricsRecorder recorder(TranslateHelperMetrics::GetMetricsName( |
| 164 TranslateHelperMetrics::UMA_LANGUAGE_VERIFICATION)); | 174 TranslateHelperMetrics::UMA_LANGUAGE_VERIFICATION)); |
| 165 | 175 |
| 166 recorder.CheckLanguageVerification(0, 0, 0, 0, 0); | 176 recorder.CheckLanguageVerification(0, 0, 0, 0, 0); |
| 167 TranslateHelperMetrics::ReportLanguageVerification( | 177 TranslateHelperMetrics::ReportLanguageVerification( |
| 168 TranslateHelperMetrics::LANGUAGE_VERIFICATION_CLD_DISABLED); | 178 TranslateHelperMetrics::LANGUAGE_VERIFICATION_CLD_DISABLED); |
| 169 recorder.CheckLanguageVerification(1, 0, 0, 0, 0); | 179 recorder.CheckLanguageVerification(1, 0, 0, 0, 0); |
| (...skipping 68 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 238 TranslateHelperMetrics::UMA_LANGUAGE_DETECTION)); | 248 TranslateHelperMetrics::UMA_LANGUAGE_DETECTION)); |
| 239 recorder.CheckTotalCount(0); | 249 recorder.CheckTotalCount(0); |
| 240 TimeTicks begin = TimeTicks::Now(); | 250 TimeTicks begin = TimeTicks::Now(); |
| 241 TimeTicks end = begin + base::TimeDelta::FromMicroseconds(9009); | 251 TimeTicks end = begin + base::TimeDelta::FromMicroseconds(9009); |
| 242 TranslateHelperMetrics::ReportLanguageDetectionTime(begin, end); | 252 TranslateHelperMetrics::ReportLanguageDetectionTime(begin, end); |
| 243 recorder.CheckValueInLogs(9.009); | 253 recorder.CheckValueInLogs(9.009); |
| 244 recorder.CheckTotalCount(1); | 254 recorder.CheckTotalCount(1); |
| 245 } | 255 } |
| 246 | 256 |
| 247 #endif // defined(ENABLE_LANGUAGE_DETECTION) | 257 #endif // defined(ENABLE_LANGUAGE_DETECTION) |
| OLD | NEW |