/* * Copyright 2018 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #include <gtest/gtest.h> #include "EventMetric.h" namespace android { /** * Unit tests for the EventMetric class. */ TEST(EventMetricTest, IntDataTypeEmpty) { EventMetric<int> metric("MyMetricName", "MetricAttributeName"); std::map<int, EventStatistics> values; metric.ExportValues( [&] (int attribute_value, const EventStatistics& value) { values[attribute_value] = value; }); EXPECT_TRUE(values.empty()); } TEST(EventMetricTest, IntDataType) { EventMetric<int> metric("MyMetricName", "MetricAttributeName"); std::map<int, EventStatistics> values; metric.Record(4, 7); metric.Record(5, 8); metric.Record(5, 8); metric.Record(5, 8); metric.Record(6, 8); metric.Record(6, 8); metric.Record(6, 8); metric.ExportValues( [&] (int attribute_value, const EventStatistics& value) { values[attribute_value] = value; }); ASSERT_EQ(2u, values.size()); EXPECT_EQ(4, values[7].min); EXPECT_EQ(4, values[7].max); EXPECT_EQ(4, values[7].mean); EXPECT_EQ(1, values[7].count); EXPECT_EQ(5, values[8].min); EXPECT_EQ(6, values[8].max); // This is an approximate value because of the technique we're using. EXPECT_NEAR(5.5, values[8].mean, 0.2); EXPECT_EQ(6, values[8].count); } TEST(EventMetricTest, StringDataType) { EventMetric<std::string> metric("MyMetricName", "MetricAttributeName"); std::map<std::string, EventStatistics> values; metric.Record(1, "a"); metric.Record(2, "b"); metric.Record(2, "b"); metric.Record(3, "b"); metric.Record(3, "b"); metric.ExportValues( [&] (std::string attribute_value, const EventStatistics& value) { values[attribute_value] = value; }); ASSERT_EQ(2u, values.size()); EXPECT_EQ(1, values["a"].min); EXPECT_EQ(1, values["a"].max); EXPECT_EQ(1, values["a"].mean); EXPECT_EQ(1, values["a"].count); EXPECT_EQ(2, values["b"].min); EXPECT_EQ(3, values["b"].max); EXPECT_NEAR(2.5, values["b"].mean, 0.2); EXPECT_EQ(4, values["b"].count); } // Helper class that allows us to mock the clock. template<typename AttributeType> class MockEventTimer : public EventTimer<AttributeType> { public: explicit MockEventTimer(nsecs_t time_delta_ns, EventMetric<AttributeType>* metric) : EventTimer<AttributeType>(metric) { // Pretend the event started earlier. this->start_time_ = systemTime() - time_delta_ns; } }; TEST(EventTimerTest, IntDataType) { EventMetric<int> metric("MyMetricName", "MetricAttributeName"); for (int i = 0; i < 5; i++) { { // Add a mock time delta. MockEventTimer<int> metric_timer(i * 1000000, &metric); metric_timer.SetAttribute(i % 2); } } std::map<int, EventStatistics> values; metric.ExportValues( [&] (int attribute_value, const EventStatistics& value) { values[attribute_value] = value; }); ASSERT_EQ(2u, values.size()); EXPECT_LT(values[0].min, values[0].max); EXPECT_GE(4000, values[0].max); EXPECT_GT(values[0].mean, values[0].min); EXPECT_LE(values[0].mean, values[0].max); EXPECT_EQ(3, values[0].count); EXPECT_LT(values[1].min, values[1].max); EXPECT_GE(3000, values[1].max); EXPECT_GT(values[1].mean, values[1].min); EXPECT_LE(values[1].mean, values[1].max); EXPECT_EQ(2, values[1].count); } } // namespace android