xref: /aosp_15_r20/external/pigweed/pw_allocator/examples/metrics.cc (revision 61c4878ac05f98d0ceed94b57d316916de578985)
1*61c4878aSAndroid Build Coastguard Worker // Copyright 2024 The Pigweed Authors
2*61c4878aSAndroid Build Coastguard Worker //
3*61c4878aSAndroid Build Coastguard Worker // Licensed under the Apache License, Version 2.0 (the "License"); you may not
4*61c4878aSAndroid Build Coastguard Worker // use this file except in compliance with the License. You may obtain a copy of
5*61c4878aSAndroid Build Coastguard Worker // the License at
6*61c4878aSAndroid Build Coastguard Worker //
7*61c4878aSAndroid Build Coastguard Worker //     https://www.apache.org/licenses/LICENSE-2.0
8*61c4878aSAndroid Build Coastguard Worker //
9*61c4878aSAndroid Build Coastguard Worker // Unless required by applicable law or agreed to in writing, software
10*61c4878aSAndroid Build Coastguard Worker // distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
11*61c4878aSAndroid Build Coastguard Worker // WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
12*61c4878aSAndroid Build Coastguard Worker // License for the specific language governing permissions and limitations under
13*61c4878aSAndroid Build Coastguard Worker // the License.
14*61c4878aSAndroid Build Coastguard Worker 
15*61c4878aSAndroid Build Coastguard Worker #include "pw_allocator/metrics.h"
16*61c4878aSAndroid Build Coastguard Worker 
17*61c4878aSAndroid Build Coastguard Worker #include <cstdint>
18*61c4878aSAndroid Build Coastguard Worker #include <string_view>
19*61c4878aSAndroid Build Coastguard Worker 
20*61c4878aSAndroid Build Coastguard Worker #include "examples/named_u32.h"
21*61c4878aSAndroid Build Coastguard Worker #include "pw_allocator/testing.h"
22*61c4878aSAndroid Build Coastguard Worker #include "pw_allocator/tracking_allocator.h"
23*61c4878aSAndroid Build Coastguard Worker #include "pw_tokenizer/tokenize.h"
24*61c4878aSAndroid Build Coastguard Worker 
25*61c4878aSAndroid Build Coastguard Worker namespace examples {
26*61c4878aSAndroid Build Coastguard Worker 
27*61c4878aSAndroid Build Coastguard Worker // DOCSTAG: [pw_allocator-examples-metrics-custom_metrics1]
28*61c4878aSAndroid Build Coastguard Worker struct CustomMetrics {
29*61c4878aSAndroid Build Coastguard Worker   PW_ALLOCATOR_METRICS_ENABLE(allocated_bytes);
30*61c4878aSAndroid Build Coastguard Worker   PW_ALLOCATOR_METRICS_ENABLE(peak_allocated_bytes);
31*61c4878aSAndroid Build Coastguard Worker   PW_ALLOCATOR_METRICS_ENABLE(num_failures);
32*61c4878aSAndroid Build Coastguard Worker };
33*61c4878aSAndroid Build Coastguard Worker // DOCSTAG: [pw_allocator-examples-metrics-custom_metrics1]
34*61c4878aSAndroid Build Coastguard Worker 
CollectCustomMetrics(pw::Allocator & allocator)35*61c4878aSAndroid Build Coastguard Worker void CollectCustomMetrics(pw::Allocator& allocator) {
36*61c4878aSAndroid Build Coastguard Worker   // DOCSTAG: [pw_allocator-examples-metrics-custom_metrics2]
37*61c4878aSAndroid Build Coastguard Worker   constexpr pw::metric::Token kToken = PW_TOKENIZE_STRING("CustomMetrics");
38*61c4878aSAndroid Build Coastguard Worker   pw::allocator::TrackingAllocatorImpl<CustomMetrics> tracker(kToken,
39*61c4878aSAndroid Build Coastguard Worker                                                               allocator);
40*61c4878aSAndroid Build Coastguard Worker   // DOCSTAG: [pw_allocator-examples-metrics-custom_metrics2]
41*61c4878aSAndroid Build Coastguard Worker 
42*61c4878aSAndroid Build Coastguard Worker   // Keep one UniquePtr in scope, and let the other deallocate immediately.
43*61c4878aSAndroid Build Coastguard Worker   auto ptr = tracker.MakeUnique<NamedU32>("test", 111);
44*61c4878aSAndroid Build Coastguard Worker   ptr = tracker.MakeUnique<NamedU32>("test", 222);
45*61c4878aSAndroid Build Coastguard Worker 
46*61c4878aSAndroid Build Coastguard Worker   // DOCSTAG: [pw_allocator-examples-metrics-dump]
47*61c4878aSAndroid Build Coastguard Worker   tracker.metric_group().Dump();
48*61c4878aSAndroid Build Coastguard Worker   // DOCSTAG: [pw_allocator-examples-metrics-dump]
49*61c4878aSAndroid Build Coastguard Worker }
50*61c4878aSAndroid Build Coastguard Worker 
CollectMultipleTrackers(pw::Allocator & allocator)51*61c4878aSAndroid Build Coastguard Worker void CollectMultipleTrackers(pw::Allocator& allocator) {
52*61c4878aSAndroid Build Coastguard Worker   // DOCSTAG: [pw_allocator-examples-metrics-multiple_trackers]
53*61c4878aSAndroid Build Coastguard Worker   using MyTrackingAllocator =
54*61c4878aSAndroid Build Coastguard Worker       pw::allocator::TrackingAllocatorImpl<pw::allocator::internal::AllMetrics>;
55*61c4878aSAndroid Build Coastguard Worker 
56*61c4878aSAndroid Build Coastguard Worker   constexpr pw::metric::Token kToken0 = PW_TOKENIZE_STRING("Combined");
57*61c4878aSAndroid Build Coastguard Worker   MyTrackingAllocator combined(kToken0, allocator);
58*61c4878aSAndroid Build Coastguard Worker 
59*61c4878aSAndroid Build Coastguard Worker   constexpr pw::metric::Token kToken1 = PW_TOKENIZE_STRING("Tracker1");
60*61c4878aSAndroid Build Coastguard Worker   MyTrackingAllocator tracker1(kToken1, combined);
61*61c4878aSAndroid Build Coastguard Worker 
62*61c4878aSAndroid Build Coastguard Worker   constexpr pw::metric::Token kToken2 = PW_TOKENIZE_STRING("Tracker2");
63*61c4878aSAndroid Build Coastguard Worker   MyTrackingAllocator tracker2(kToken2, combined);
64*61c4878aSAndroid Build Coastguard Worker 
65*61c4878aSAndroid Build Coastguard Worker   combined.metric_group().Add(tracker1.metric_group());
66*61c4878aSAndroid Build Coastguard Worker   combined.metric_group().Add(tracker2.metric_group());
67*61c4878aSAndroid Build Coastguard Worker   // DOCSTAG: [pw_allocator-examples-metrics-multiple_trackers]
68*61c4878aSAndroid Build Coastguard Worker 
69*61c4878aSAndroid Build Coastguard Worker   // Keep one UniquePtr in scope, and let others deallocate immediately.
70*61c4878aSAndroid Build Coastguard Worker   auto ptr = tracker1.MakeUnique<NamedU32>("test", 111);
71*61c4878aSAndroid Build Coastguard Worker   ptr = tracker1.MakeUnique<NamedU32>("test", 222);
72*61c4878aSAndroid Build Coastguard Worker   ptr = tracker2.MakeUnique<NamedU32>("test", 222);
73*61c4878aSAndroid Build Coastguard Worker 
74*61c4878aSAndroid Build Coastguard Worker   combined.metric_group().Dump();
75*61c4878aSAndroid Build Coastguard Worker }
76*61c4878aSAndroid Build Coastguard Worker 
77*61c4878aSAndroid Build Coastguard Worker }  // namespace examples
78*61c4878aSAndroid Build Coastguard Worker 
79*61c4878aSAndroid Build Coastguard Worker namespace pw::allocator {
80*61c4878aSAndroid Build Coastguard Worker 
81*61c4878aSAndroid Build Coastguard Worker using AllocatorForTest = ::pw::allocator::test::AllocatorForTest<256>;
82*61c4878aSAndroid Build Coastguard Worker 
83*61c4878aSAndroid Build Coastguard Worker class MetricsExampleTest : public ::testing::Test {
84*61c4878aSAndroid Build Coastguard Worker  protected:
85*61c4878aSAndroid Build Coastguard Worker   AllocatorForTest allocator_;
86*61c4878aSAndroid Build Coastguard Worker };
87*61c4878aSAndroid Build Coastguard Worker 
88*61c4878aSAndroid Build Coastguard Worker // TODO: b/328076428 - Use pwrev/193642.
TEST_F(MetricsExampleTest,CollectCustomMetrics)89*61c4878aSAndroid Build Coastguard Worker TEST_F(MetricsExampleTest, CollectCustomMetrics) {
90*61c4878aSAndroid Build Coastguard Worker   // log_basic::test::LogCache<32> logs;
91*61c4878aSAndroid Build Coastguard Worker   examples::CollectCustomMetrics(allocator_);
92*61c4878aSAndroid Build Coastguard Worker 
93*61c4878aSAndroid Build Coastguard Worker   // std::array<std::atring_view, 1> kExpectedLines{
94*61c4878aSAndroid Build Coastguard Worker   //   "todo",
95*61c4878aSAndroid Build Coastguard Worker   // };
96*61c4878aSAndroid Build Coastguard Worker   // for (const &auto line : kExpectedLines) {
97*61c4878aSAndroid Build Coastguard Worker   //   ASSERT_TRUE(logs.HasNext());
98*61c4878aSAndroid Build Coastguard Worker   //   log_basic::test::LogMessage log = logs.Next();
99*61c4878aSAndroid Build Coastguard Worker   //   EXPECT_EQ(log.level, PW_LOG_LEVEL_INFO);
100*61c4878aSAndroid Build Coastguard Worker   //   EXPECT_STREQ(log.message.c_str(), line.data());
101*61c4878aSAndroid Build Coastguard Worker   // }
102*61c4878aSAndroid Build Coastguard Worker }
103*61c4878aSAndroid Build Coastguard Worker 
104*61c4878aSAndroid Build Coastguard Worker // TODO: b/328076428 - Use pwrev/193642.
TEST_F(MetricsExampleTest,CollectMultipleTrackers)105*61c4878aSAndroid Build Coastguard Worker TEST_F(MetricsExampleTest, CollectMultipleTrackers) {
106*61c4878aSAndroid Build Coastguard Worker   // log_basic::test::LogCache<32> logs;
107*61c4878aSAndroid Build Coastguard Worker   examples::CollectMultipleTrackers(allocator_);
108*61c4878aSAndroid Build Coastguard Worker 
109*61c4878aSAndroid Build Coastguard Worker   // std::array<std::atring_view, 1> kExpectedLines{
110*61c4878aSAndroid Build Coastguard Worker   //   "todo",
111*61c4878aSAndroid Build Coastguard Worker   // };
112*61c4878aSAndroid Build Coastguard Worker   // for (const &auto line : kExpectedLines) {
113*61c4878aSAndroid Build Coastguard Worker   //   ASSERT_TRUE(logs.HasNext());
114*61c4878aSAndroid Build Coastguard Worker   //   log_basic::test::LogMessage log = logs.Next();
115*61c4878aSAndroid Build Coastguard Worker   //   EXPECT_EQ(log.level, PW_LOG_LEVEL_INFO);
116*61c4878aSAndroid Build Coastguard Worker   //   EXPECT_STREQ(log.message.c_str(), line.data());
117*61c4878aSAndroid Build Coastguard Worker   // }
118*61c4878aSAndroid Build Coastguard Worker }
119*61c4878aSAndroid Build Coastguard Worker 
120*61c4878aSAndroid Build Coastguard Worker }  // namespace pw::allocator
121