OLD | NEW |
(Empty) | |
| 1 // Copyright 2015 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. |
| 4 |
| 5 #include "components/memory_pressure/memory_pressure_stats_collector.h" |
| 6 |
| 7 #include "base/test/histogram_tester.h" |
| 8 #include "base/test/simple_test_tick_clock.h" |
| 9 #include "testing/gtest/include/gtest/gtest.h" |
| 10 |
| 11 namespace memory_pressure { |
| 12 |
| 13 namespace { |
| 14 |
| 15 // Histogram names. |
| 16 const char kPressureLevel[] = "Memory.PressureLevel"; |
| 17 const char kPressureLevelChange[] = "Memory.PressureLevelChange"; |
| 18 |
| 19 } // namespace |
| 20 |
| 21 // Test version of the stats collector with a few extra accessors. |
| 22 class TestMemoryPressureStatsCollector : public MemoryPressureStatsCollector { |
| 23 public: |
| 24 TestMemoryPressureStatsCollector(base::TickClock* tick_clock) |
| 25 : MemoryPressureStatsCollector(tick_clock) {} |
| 26 |
| 27 // Accessors. |
| 28 base::TimeDelta unreported_cumulative_time(int i) const { |
| 29 return unreported_cumulative_time_[i]; |
| 30 } |
| 31 MemoryPressureLevel last_pressure_level() const { |
| 32 return last_pressure_level_; |
| 33 } |
| 34 base::TimeTicks last_update_time() const { return last_update_time_; } |
| 35 }; |
| 36 |
| 37 // Test fixture. |
| 38 class MemoryPressureStatsCollectorTest : public testing::Test { |
| 39 public: |
| 40 MemoryPressureStatsCollectorTest() : collector_(&tick_clock_) {} |
| 41 |
| 42 void Tick(int ms) { |
| 43 tick_clock_.Advance(base::TimeDelta::FromMilliseconds(ms)); |
| 44 } |
| 45 |
| 46 // Validates expectations on the amount of accumulated (and unreported) |
| 47 // time (milliseconds) per pressure level. |
| 48 void ExpectAccumulated(int none_ms, int moderate_ms, int critical_ms) { |
| 49 EXPECT_EQ(base::TimeDelta::FromMilliseconds(none_ms), |
| 50 collector_.unreported_cumulative_time(0)); // None. |
| 51 EXPECT_EQ(base::TimeDelta::FromMilliseconds(moderate_ms), |
| 52 collector_.unreported_cumulative_time(1)); // Moderate. |
| 53 EXPECT_EQ(base::TimeDelta::FromMilliseconds(critical_ms), |
| 54 collector_.unreported_cumulative_time(2)); // Critical. |
| 55 } |
| 56 |
| 57 // Validates expectations on the amount of reported time (seconds) per |
| 58 // pressure level. |
| 59 void ExpectReported(int none_s, int moderate_s, int critical_s) { |
| 60 int total_s = none_s + moderate_s + critical_s; |
| 61 |
| 62 // If the histogram should be empty then simply confirm that it doesn't |
| 63 // yet exist. |
| 64 if (total_s == 0) { |
| 65 EXPECT_TRUE(histograms_.GetTotalCountsForPrefix(kPressureLevel).empty()); |
| 66 return; |
| 67 } |
| 68 |
| 69 histograms_.ExpectBucketCount(kPressureLevel, 0, none_s); // None. |
| 70 histograms_.ExpectBucketCount(kPressureLevel, 1, moderate_s); // Moderate. |
| 71 histograms_.ExpectBucketCount(kPressureLevel, 2, critical_s); // Critical. |
| 72 histograms_.ExpectTotalCount(kPressureLevel, total_s); |
| 73 } |
| 74 |
| 75 base::SimpleTestTickClock tick_clock_; |
| 76 TestMemoryPressureStatsCollector collector_; |
| 77 base::HistogramTester histograms_; |
| 78 }; |
| 79 |
| 80 TEST_F(MemoryPressureStatsCollectorTest, EndToEnd) { |
| 81 // Upon construction no statistics should yet have been reported. |
| 82 ExpectAccumulated(0, 0, 0); |
| 83 ExpectReported(0, 0, 0); |
| 84 histograms_.ExpectTotalCount(kPressureLevelChange, 0); |
| 85 |
| 86 // A first call should not invoke any reporting functions, but it should |
| 87 // modify member variables. |
| 88 Tick(500); |
| 89 collector_.UpdateStatistics( |
| 90 MemoryPressureListener::MEMORY_PRESSURE_LEVEL_NONE); |
| 91 EXPECT_EQ(MemoryPressureListener::MEMORY_PRESSURE_LEVEL_NONE, |
| 92 collector_.last_pressure_level()); |
| 93 EXPECT_EQ(tick_clock_.NowTicks(), collector_.last_update_time()); |
| 94 ExpectAccumulated(0, 0, 0); |
| 95 ExpectReported(0, 0, 0); |
| 96 histograms_.ExpectTotalCount(kPressureLevelChange, 0); |
| 97 |
| 98 // A subsequent call with the same pressure level should increment the |
| 99 // cumulative time but not make a report, as less than one second of time |
| 100 // has been accumulated. |
| 101 Tick(500); |
| 102 collector_.UpdateStatistics( |
| 103 MemoryPressureListener::MEMORY_PRESSURE_LEVEL_NONE); |
| 104 EXPECT_EQ(MemoryPressureListener::MEMORY_PRESSURE_LEVEL_NONE, |
| 105 collector_.last_pressure_level()); |
| 106 EXPECT_EQ(tick_clock_.NowTicks(), collector_.last_update_time()); |
| 107 ExpectAccumulated(500, 0, 0); |
| 108 ExpectReported(0, 0, 0); |
| 109 histograms_.ExpectTotalCount(kPressureLevelChange, 0); |
| 110 |
| 111 // Yet another call and this time a report should be made, as one second |
| 112 // of time has been accumulated. 500ms should remain unreported. |
| 113 Tick(1000); |
| 114 collector_.UpdateStatistics( |
| 115 MemoryPressureListener::MEMORY_PRESSURE_LEVEL_NONE); |
| 116 EXPECT_EQ(MemoryPressureListener::MEMORY_PRESSURE_LEVEL_NONE, |
| 117 collector_.last_pressure_level()); |
| 118 EXPECT_EQ(tick_clock_.NowTicks(), collector_.last_update_time()); |
| 119 ExpectAccumulated(500, 0, 0); |
| 120 ExpectReported(1, 0, 0); |
| 121 histograms_.ExpectTotalCount(kPressureLevelChange, 0); |
| 122 |
| 123 // A subsequent call with a different pressure level should increment the |
| 124 // cumulative time and make several reports. |
| 125 Tick(2250); |
| 126 collector_.UpdateStatistics( |
| 127 MemoryPressureListener::MEMORY_PRESSURE_LEVEL_MODERATE); |
| 128 EXPECT_EQ(MemoryPressureListener::MEMORY_PRESSURE_LEVEL_MODERATE, |
| 129 collector_.last_pressure_level()); |
| 130 EXPECT_EQ(tick_clock_.NowTicks(), collector_.last_update_time()); |
| 131 ExpectAccumulated(500, 250, 0); |
| 132 ExpectReported(1, 2, 0); |
| 133 histograms_.ExpectBucketCount( |
| 134 kPressureLevelChange, UMA_MEMORY_PRESSURE_LEVEL_CHANGE_NONE_TO_MODERATE, |
| 135 1); |
| 136 histograms_.ExpectTotalCount(kPressureLevelChange, 1); |
| 137 } |
| 138 |
| 139 } // namespace memory_pressure |
OLD | NEW |