This source file includes following definitions.
- base_
- Expect
#include "chrome/browser/chromeos/net/network_portal_detector_test_utils.h"
#include <algorithm>
#include "base/logging.h"
#include "base/memory/scoped_ptr.h"
#include "base/metrics/histogram_base.h"
#include "base/metrics/histogram_samples.h"
#include "base/metrics/statistics_recorder.h"
namespace chromeos {
EnumHistogramChecker::EnumHistogramChecker(const std::string& histogram,
int count,
base::HistogramSamples* base)
: histogram_(histogram), expect_(count), base_(base) {}
EnumHistogramChecker::~EnumHistogramChecker() {}
EnumHistogramChecker* EnumHistogramChecker::Expect(int key, int value) {
expect_[key] = value;
return this;
}
bool EnumHistogramChecker::Check() {
bool empty = false;
size_t num_zeroes =
static_cast<size_t>(std::count(expect_.begin(), expect_.end(), 0));
if (num_zeroes == expect_.size())
empty = true;
base::HistogramBase* histogram =
base::StatisticsRecorder::FindHistogram(histogram_);
if (!histogram) {
if (!empty) {
LOG(ERROR) << "Non-empty expectations for " << histogram_ << " "
<< "which does not exists.";
return false;
}
return true;
}
scoped_ptr<base::HistogramSamples> samples = histogram->SnapshotSamples();
if (!samples.get()) {
if (!empty) {
LOG(ERROR) << "Non-empty expectations for " << histogram_ << " "
<< "for which samples do not exist.";
return false;
}
return true;
}
bool ok = true;
for (size_t i = 0; i < expect_.size(); ++i) {
const int base = base_ ? base_->GetCount(i) : 0;
const int actual = samples->GetCount(i) - base;
if (actual != expect_[i]) {
LOG(ERROR) << "Histogram: " << histogram_ << ", value #" << i << ", "
<< "expected: " << expect_[i] << ", actual: " << actual;
ok = false;
}
}
return ok;
}
}