xref: /aosp_15_r20/external/libchrome/base/process/process_metrics_unittest.cc (revision 635a864187cb8b6c713ff48b7e790a6b21769273)
1*635a8641SAndroid Build Coastguard Worker // Copyright 2013 The Chromium Authors. All rights reserved.
2*635a8641SAndroid Build Coastguard Worker // Use of this source code is governed by a BSD-style license that can be
3*635a8641SAndroid Build Coastguard Worker // found in the LICENSE file.
4*635a8641SAndroid Build Coastguard Worker 
5*635a8641SAndroid Build Coastguard Worker #include "base/process/process_metrics.h"
6*635a8641SAndroid Build Coastguard Worker 
7*635a8641SAndroid Build Coastguard Worker #include <stddef.h>
8*635a8641SAndroid Build Coastguard Worker #include <stdint.h>
9*635a8641SAndroid Build Coastguard Worker 
10*635a8641SAndroid Build Coastguard Worker #include <sstream>
11*635a8641SAndroid Build Coastguard Worker #include <string>
12*635a8641SAndroid Build Coastguard Worker #include <vector>
13*635a8641SAndroid Build Coastguard Worker 
14*635a8641SAndroid Build Coastguard Worker #include "base/bind.h"
15*635a8641SAndroid Build Coastguard Worker #include "base/command_line.h"
16*635a8641SAndroid Build Coastguard Worker #include "base/files/file.h"
17*635a8641SAndroid Build Coastguard Worker #include "base/files/file_util.h"
18*635a8641SAndroid Build Coastguard Worker #include "base/files/scoped_temp_dir.h"
19*635a8641SAndroid Build Coastguard Worker #include "base/macros.h"
20*635a8641SAndroid Build Coastguard Worker #include "base/memory/shared_memory.h"
21*635a8641SAndroid Build Coastguard Worker #include "base/strings/string_number_conversions.h"
22*635a8641SAndroid Build Coastguard Worker #include "base/sys_info.h"
23*635a8641SAndroid Build Coastguard Worker #include "base/test/multiprocess_test.h"
24*635a8641SAndroid Build Coastguard Worker #include "base/threading/thread.h"
25*635a8641SAndroid Build Coastguard Worker #include "build/build_config.h"
26*635a8641SAndroid Build Coastguard Worker #include "testing/gtest/include/gtest/gtest.h"
27*635a8641SAndroid Build Coastguard Worker #include "testing/multiprocess_func_list.h"
28*635a8641SAndroid Build Coastguard Worker 
29*635a8641SAndroid Build Coastguard Worker #if defined(OS_MACOSX)
30*635a8641SAndroid Build Coastguard Worker #include <sys/mman.h>
31*635a8641SAndroid Build Coastguard Worker #endif
32*635a8641SAndroid Build Coastguard Worker 
33*635a8641SAndroid Build Coastguard Worker namespace base {
34*635a8641SAndroid Build Coastguard Worker namespace debug {
35*635a8641SAndroid Build Coastguard Worker 
36*635a8641SAndroid Build Coastguard Worker #if defined(OS_LINUX) || defined(OS_CHROMEOS) || defined(OS_WIN)
37*635a8641SAndroid Build Coastguard Worker namespace {
38*635a8641SAndroid Build Coastguard Worker 
BusyWork(std::vector<std::string> * vec)39*635a8641SAndroid Build Coastguard Worker void BusyWork(std::vector<std::string>* vec) {
40*635a8641SAndroid Build Coastguard Worker   int64_t test_value = 0;
41*635a8641SAndroid Build Coastguard Worker   for (int i = 0; i < 100000; ++i) {
42*635a8641SAndroid Build Coastguard Worker     ++test_value;
43*635a8641SAndroid Build Coastguard Worker     vec->push_back(Int64ToString(test_value));
44*635a8641SAndroid Build Coastguard Worker   }
45*635a8641SAndroid Build Coastguard Worker }
46*635a8641SAndroid Build Coastguard Worker 
47*635a8641SAndroid Build Coastguard Worker }  // namespace
48*635a8641SAndroid Build Coastguard Worker #endif  // defined(OS_LINUX) || defined(OS_CHROMEOS)
49*635a8641SAndroid Build Coastguard Worker 
50*635a8641SAndroid Build Coastguard Worker // Tests for SystemMetrics.
51*635a8641SAndroid Build Coastguard Worker // Exists as a class so it can be a friend of SystemMetrics.
52*635a8641SAndroid Build Coastguard Worker class SystemMetricsTest : public testing::Test {
53*635a8641SAndroid Build Coastguard Worker  public:
54*635a8641SAndroid Build Coastguard Worker   SystemMetricsTest() = default;
55*635a8641SAndroid Build Coastguard Worker 
56*635a8641SAndroid Build Coastguard Worker  private:
57*635a8641SAndroid Build Coastguard Worker   DISALLOW_COPY_AND_ASSIGN(SystemMetricsTest);
58*635a8641SAndroid Build Coastguard Worker };
59*635a8641SAndroid Build Coastguard Worker 
60*635a8641SAndroid Build Coastguard Worker #if defined(OS_LINUX) || defined(OS_ANDROID)
TEST_F(SystemMetricsTest,IsValidDiskName)61*635a8641SAndroid Build Coastguard Worker TEST_F(SystemMetricsTest, IsValidDiskName) {
62*635a8641SAndroid Build Coastguard Worker   const char invalid_input1[] = "";
63*635a8641SAndroid Build Coastguard Worker   const char invalid_input2[] = "s";
64*635a8641SAndroid Build Coastguard Worker   const char invalid_input3[] = "sdz+";
65*635a8641SAndroid Build Coastguard Worker   const char invalid_input4[] = "hda0";
66*635a8641SAndroid Build Coastguard Worker   const char invalid_input5[] = "mmcbl";
67*635a8641SAndroid Build Coastguard Worker   const char invalid_input6[] = "mmcblka";
68*635a8641SAndroid Build Coastguard Worker   const char invalid_input7[] = "mmcblkb";
69*635a8641SAndroid Build Coastguard Worker   const char invalid_input8[] = "mmmblk0";
70*635a8641SAndroid Build Coastguard Worker 
71*635a8641SAndroid Build Coastguard Worker   EXPECT_FALSE(IsValidDiskName(invalid_input1));
72*635a8641SAndroid Build Coastguard Worker   EXPECT_FALSE(IsValidDiskName(invalid_input2));
73*635a8641SAndroid Build Coastguard Worker   EXPECT_FALSE(IsValidDiskName(invalid_input3));
74*635a8641SAndroid Build Coastguard Worker   EXPECT_FALSE(IsValidDiskName(invalid_input4));
75*635a8641SAndroid Build Coastguard Worker   EXPECT_FALSE(IsValidDiskName(invalid_input5));
76*635a8641SAndroid Build Coastguard Worker   EXPECT_FALSE(IsValidDiskName(invalid_input6));
77*635a8641SAndroid Build Coastguard Worker   EXPECT_FALSE(IsValidDiskName(invalid_input7));
78*635a8641SAndroid Build Coastguard Worker   EXPECT_FALSE(IsValidDiskName(invalid_input8));
79*635a8641SAndroid Build Coastguard Worker 
80*635a8641SAndroid Build Coastguard Worker   const char valid_input1[] = "sda";
81*635a8641SAndroid Build Coastguard Worker   const char valid_input2[] = "sdaaaa";
82*635a8641SAndroid Build Coastguard Worker   const char valid_input3[] = "hdz";
83*635a8641SAndroid Build Coastguard Worker   const char valid_input4[] = "mmcblk0";
84*635a8641SAndroid Build Coastguard Worker   const char valid_input5[] = "mmcblk999";
85*635a8641SAndroid Build Coastguard Worker 
86*635a8641SAndroid Build Coastguard Worker   EXPECT_TRUE(IsValidDiskName(valid_input1));
87*635a8641SAndroid Build Coastguard Worker   EXPECT_TRUE(IsValidDiskName(valid_input2));
88*635a8641SAndroid Build Coastguard Worker   EXPECT_TRUE(IsValidDiskName(valid_input3));
89*635a8641SAndroid Build Coastguard Worker   EXPECT_TRUE(IsValidDiskName(valid_input4));
90*635a8641SAndroid Build Coastguard Worker   EXPECT_TRUE(IsValidDiskName(valid_input5));
91*635a8641SAndroid Build Coastguard Worker }
92*635a8641SAndroid Build Coastguard Worker 
TEST_F(SystemMetricsTest,ParseMeminfo)93*635a8641SAndroid Build Coastguard Worker TEST_F(SystemMetricsTest, ParseMeminfo) {
94*635a8641SAndroid Build Coastguard Worker   SystemMemoryInfoKB meminfo;
95*635a8641SAndroid Build Coastguard Worker   const char invalid_input1[] = "abc";
96*635a8641SAndroid Build Coastguard Worker   const char invalid_input2[] = "MemTotal:";
97*635a8641SAndroid Build Coastguard Worker   // Partial file with no MemTotal
98*635a8641SAndroid Build Coastguard Worker   const char invalid_input3[] =
99*635a8641SAndroid Build Coastguard Worker       "MemFree:         3913968 kB\n"
100*635a8641SAndroid Build Coastguard Worker       "Buffers:         2348340 kB\n"
101*635a8641SAndroid Build Coastguard Worker       "Cached:         49071596 kB\n"
102*635a8641SAndroid Build Coastguard Worker       "SwapCached:           12 kB\n"
103*635a8641SAndroid Build Coastguard Worker       "Active:         36393900 kB\n"
104*635a8641SAndroid Build Coastguard Worker       "Inactive:       21221496 kB\n"
105*635a8641SAndroid Build Coastguard Worker       "Active(anon):    5674352 kB\n"
106*635a8641SAndroid Build Coastguard Worker       "Inactive(anon):   633992 kB\n";
107*635a8641SAndroid Build Coastguard Worker   EXPECT_FALSE(ParseProcMeminfo(invalid_input1, &meminfo));
108*635a8641SAndroid Build Coastguard Worker   EXPECT_FALSE(ParseProcMeminfo(invalid_input2, &meminfo));
109*635a8641SAndroid Build Coastguard Worker   EXPECT_FALSE(ParseProcMeminfo(invalid_input3, &meminfo));
110*635a8641SAndroid Build Coastguard Worker 
111*635a8641SAndroid Build Coastguard Worker   const char valid_input1[] =
112*635a8641SAndroid Build Coastguard Worker       "MemTotal:        3981504 kB\n"
113*635a8641SAndroid Build Coastguard Worker       "MemFree:          140764 kB\n"
114*635a8641SAndroid Build Coastguard Worker       "MemAvailable:     535413 kB\n"
115*635a8641SAndroid Build Coastguard Worker       "Buffers:          116480 kB\n"
116*635a8641SAndroid Build Coastguard Worker       "Cached:           406160 kB\n"
117*635a8641SAndroid Build Coastguard Worker       "SwapCached:        21304 kB\n"
118*635a8641SAndroid Build Coastguard Worker       "Active:          3152040 kB\n"
119*635a8641SAndroid Build Coastguard Worker       "Inactive:         472856 kB\n"
120*635a8641SAndroid Build Coastguard Worker       "Active(anon):    2972352 kB\n"
121*635a8641SAndroid Build Coastguard Worker       "Inactive(anon):   270108 kB\n"
122*635a8641SAndroid Build Coastguard Worker       "Active(file):     179688 kB\n"
123*635a8641SAndroid Build Coastguard Worker       "Inactive(file):   202748 kB\n"
124*635a8641SAndroid Build Coastguard Worker       "Unevictable:           0 kB\n"
125*635a8641SAndroid Build Coastguard Worker       "Mlocked:               0 kB\n"
126*635a8641SAndroid Build Coastguard Worker       "SwapTotal:       5832280 kB\n"
127*635a8641SAndroid Build Coastguard Worker       "SwapFree:        3672368 kB\n"
128*635a8641SAndroid Build Coastguard Worker       "Dirty:               184 kB\n"
129*635a8641SAndroid Build Coastguard Worker       "Writeback:             0 kB\n"
130*635a8641SAndroid Build Coastguard Worker       "AnonPages:       3101224 kB\n"
131*635a8641SAndroid Build Coastguard Worker       "Mapped:           142296 kB\n"
132*635a8641SAndroid Build Coastguard Worker       "Shmem:            140204 kB\n"
133*635a8641SAndroid Build Coastguard Worker       "Slab:              54212 kB\n"
134*635a8641SAndroid Build Coastguard Worker       "SReclaimable:      30936 kB\n"
135*635a8641SAndroid Build Coastguard Worker       "SUnreclaim:        23276 kB\n"
136*635a8641SAndroid Build Coastguard Worker       "KernelStack:        2464 kB\n"
137*635a8641SAndroid Build Coastguard Worker       "PageTables:        24812 kB\n"
138*635a8641SAndroid Build Coastguard Worker       "NFS_Unstable:          0 kB\n"
139*635a8641SAndroid Build Coastguard Worker       "Bounce:                0 kB\n"
140*635a8641SAndroid Build Coastguard Worker       "WritebackTmp:          0 kB\n"
141*635a8641SAndroid Build Coastguard Worker       "CommitLimit:     7823032 kB\n"
142*635a8641SAndroid Build Coastguard Worker       "Committed_AS:    7973536 kB\n"
143*635a8641SAndroid Build Coastguard Worker       "VmallocTotal:   34359738367 kB\n"
144*635a8641SAndroid Build Coastguard Worker       "VmallocUsed:      375940 kB\n"
145*635a8641SAndroid Build Coastguard Worker       "VmallocChunk:   34359361127 kB\n"
146*635a8641SAndroid Build Coastguard Worker       "DirectMap4k:       72448 kB\n"
147*635a8641SAndroid Build Coastguard Worker       "DirectMap2M:     4061184 kB\n";
148*635a8641SAndroid Build Coastguard Worker   // output from a much older kernel where the Active and Inactive aren't
149*635a8641SAndroid Build Coastguard Worker   // broken down into anon and file and Huge Pages are enabled
150*635a8641SAndroid Build Coastguard Worker   const char valid_input2[] =
151*635a8641SAndroid Build Coastguard Worker       "MemTotal:       255908 kB\n"
152*635a8641SAndroid Build Coastguard Worker       "MemFree:         69936 kB\n"
153*635a8641SAndroid Build Coastguard Worker       "Buffers:         15812 kB\n"
154*635a8641SAndroid Build Coastguard Worker       "Cached:         115124 kB\n"
155*635a8641SAndroid Build Coastguard Worker       "SwapCached:          0 kB\n"
156*635a8641SAndroid Build Coastguard Worker       "Active:          92700 kB\n"
157*635a8641SAndroid Build Coastguard Worker       "Inactive:        63792 kB\n"
158*635a8641SAndroid Build Coastguard Worker       "HighTotal:           0 kB\n"
159*635a8641SAndroid Build Coastguard Worker       "HighFree:            0 kB\n"
160*635a8641SAndroid Build Coastguard Worker       "LowTotal:       255908 kB\n"
161*635a8641SAndroid Build Coastguard Worker       "LowFree:         69936 kB\n"
162*635a8641SAndroid Build Coastguard Worker       "SwapTotal:      524280 kB\n"
163*635a8641SAndroid Build Coastguard Worker       "SwapFree:       524200 kB\n"
164*635a8641SAndroid Build Coastguard Worker       "Dirty:               4 kB\n"
165*635a8641SAndroid Build Coastguard Worker       "Writeback:           0 kB\n"
166*635a8641SAndroid Build Coastguard Worker       "Mapped:          42236 kB\n"
167*635a8641SAndroid Build Coastguard Worker       "Slab:            25912 kB\n"
168*635a8641SAndroid Build Coastguard Worker       "Committed_AS:   118680 kB\n"
169*635a8641SAndroid Build Coastguard Worker       "PageTables:       1236 kB\n"
170*635a8641SAndroid Build Coastguard Worker       "VmallocTotal:  3874808 kB\n"
171*635a8641SAndroid Build Coastguard Worker       "VmallocUsed:      1416 kB\n"
172*635a8641SAndroid Build Coastguard Worker       "VmallocChunk:  3872908 kB\n"
173*635a8641SAndroid Build Coastguard Worker       "HugePages_Total:     0\n"
174*635a8641SAndroid Build Coastguard Worker       "HugePages_Free:      0\n"
175*635a8641SAndroid Build Coastguard Worker       "Hugepagesize:     4096 kB\n";
176*635a8641SAndroid Build Coastguard Worker 
177*635a8641SAndroid Build Coastguard Worker   EXPECT_TRUE(ParseProcMeminfo(valid_input1, &meminfo));
178*635a8641SAndroid Build Coastguard Worker   EXPECT_EQ(meminfo.total, 3981504);
179*635a8641SAndroid Build Coastguard Worker   EXPECT_EQ(meminfo.free, 140764);
180*635a8641SAndroid Build Coastguard Worker   EXPECT_EQ(meminfo.available, 535413);
181*635a8641SAndroid Build Coastguard Worker   EXPECT_EQ(meminfo.buffers, 116480);
182*635a8641SAndroid Build Coastguard Worker   EXPECT_EQ(meminfo.cached, 406160);
183*635a8641SAndroid Build Coastguard Worker   EXPECT_EQ(meminfo.active_anon, 2972352);
184*635a8641SAndroid Build Coastguard Worker   EXPECT_EQ(meminfo.active_file, 179688);
185*635a8641SAndroid Build Coastguard Worker   EXPECT_EQ(meminfo.inactive_anon, 270108);
186*635a8641SAndroid Build Coastguard Worker   EXPECT_EQ(meminfo.inactive_file, 202748);
187*635a8641SAndroid Build Coastguard Worker   EXPECT_EQ(meminfo.swap_total, 5832280);
188*635a8641SAndroid Build Coastguard Worker   EXPECT_EQ(meminfo.swap_free, 3672368);
189*635a8641SAndroid Build Coastguard Worker   EXPECT_EQ(meminfo.dirty, 184);
190*635a8641SAndroid Build Coastguard Worker   EXPECT_EQ(meminfo.reclaimable, 30936);
191*635a8641SAndroid Build Coastguard Worker #if defined(OS_CHROMEOS)
192*635a8641SAndroid Build Coastguard Worker   EXPECT_EQ(meminfo.shmem, 140204);
193*635a8641SAndroid Build Coastguard Worker   EXPECT_EQ(meminfo.slab, 54212);
194*635a8641SAndroid Build Coastguard Worker #endif
195*635a8641SAndroid Build Coastguard Worker   EXPECT_EQ(355725,
196*635a8641SAndroid Build Coastguard Worker             base::SysInfo::AmountOfAvailablePhysicalMemory(meminfo) / 1024);
197*635a8641SAndroid Build Coastguard Worker   // Simulate as if there is no MemAvailable.
198*635a8641SAndroid Build Coastguard Worker   meminfo.available = 0;
199*635a8641SAndroid Build Coastguard Worker   EXPECT_EQ(374448,
200*635a8641SAndroid Build Coastguard Worker             base::SysInfo::AmountOfAvailablePhysicalMemory(meminfo) / 1024);
201*635a8641SAndroid Build Coastguard Worker   meminfo = {};
202*635a8641SAndroid Build Coastguard Worker   EXPECT_TRUE(ParseProcMeminfo(valid_input2, &meminfo));
203*635a8641SAndroid Build Coastguard Worker   EXPECT_EQ(meminfo.total, 255908);
204*635a8641SAndroid Build Coastguard Worker   EXPECT_EQ(meminfo.free, 69936);
205*635a8641SAndroid Build Coastguard Worker   EXPECT_EQ(meminfo.available, 0);
206*635a8641SAndroid Build Coastguard Worker   EXPECT_EQ(meminfo.buffers, 15812);
207*635a8641SAndroid Build Coastguard Worker   EXPECT_EQ(meminfo.cached, 115124);
208*635a8641SAndroid Build Coastguard Worker   EXPECT_EQ(meminfo.swap_total, 524280);
209*635a8641SAndroid Build Coastguard Worker   EXPECT_EQ(meminfo.swap_free, 524200);
210*635a8641SAndroid Build Coastguard Worker   EXPECT_EQ(meminfo.dirty, 4);
211*635a8641SAndroid Build Coastguard Worker   EXPECT_EQ(69936,
212*635a8641SAndroid Build Coastguard Worker             base::SysInfo::AmountOfAvailablePhysicalMemory(meminfo) / 1024);
213*635a8641SAndroid Build Coastguard Worker }
214*635a8641SAndroid Build Coastguard Worker 
TEST_F(SystemMetricsTest,ParseVmstat)215*635a8641SAndroid Build Coastguard Worker TEST_F(SystemMetricsTest, ParseVmstat) {
216*635a8641SAndroid Build Coastguard Worker   VmStatInfo vmstat;
217*635a8641SAndroid Build Coastguard Worker   // part of vmstat from a 3.2 kernel with numa enabled
218*635a8641SAndroid Build Coastguard Worker   const char valid_input1[] =
219*635a8641SAndroid Build Coastguard Worker       "nr_free_pages 905104\n"
220*635a8641SAndroid Build Coastguard Worker       "nr_inactive_anon 142478"
221*635a8641SAndroid Build Coastguard Worker       "nr_active_anon 1520046\n"
222*635a8641SAndroid Build Coastguard Worker       "nr_inactive_file 4481001\n"
223*635a8641SAndroid Build Coastguard Worker       "nr_active_file 8313439\n"
224*635a8641SAndroid Build Coastguard Worker       "nr_unevictable 5044\n"
225*635a8641SAndroid Build Coastguard Worker       "nr_mlock 5044\n"
226*635a8641SAndroid Build Coastguard Worker       "nr_anon_pages 1633780\n"
227*635a8641SAndroid Build Coastguard Worker       "nr_mapped 104742\n"
228*635a8641SAndroid Build Coastguard Worker       "nr_file_pages 12828218\n"
229*635a8641SAndroid Build Coastguard Worker       "nr_dirty 245\n"
230*635a8641SAndroid Build Coastguard Worker       "nr_writeback 0\n"
231*635a8641SAndroid Build Coastguard Worker       "nr_slab_reclaimable 831609\n"
232*635a8641SAndroid Build Coastguard Worker       "nr_slab_unreclaimable 41164\n"
233*635a8641SAndroid Build Coastguard Worker       "nr_page_table_pages 31470\n"
234*635a8641SAndroid Build Coastguard Worker       "nr_kernel_stack 1735\n"
235*635a8641SAndroid Build Coastguard Worker       "nr_unstable 0\n"
236*635a8641SAndroid Build Coastguard Worker       "nr_bounce 0\n"
237*635a8641SAndroid Build Coastguard Worker       "nr_vmscan_write 406\n"
238*635a8641SAndroid Build Coastguard Worker       "nr_vmscan_immediate_reclaim 281\n"
239*635a8641SAndroid Build Coastguard Worker       "nr_writeback_temp 0\n"
240*635a8641SAndroid Build Coastguard Worker       "nr_isolated_anon 0\n"
241*635a8641SAndroid Build Coastguard Worker       "nr_isolated_file 0\n"
242*635a8641SAndroid Build Coastguard Worker       "nr_shmem 28820\n"
243*635a8641SAndroid Build Coastguard Worker       "nr_dirtied 84674644\n"
244*635a8641SAndroid Build Coastguard Worker       "nr_written 75307109\n"
245*635a8641SAndroid Build Coastguard Worker       "nr_anon_transparent_hugepages 0\n"
246*635a8641SAndroid Build Coastguard Worker       "nr_dirty_threshold 1536206\n"
247*635a8641SAndroid Build Coastguard Worker       "nr_dirty_background_threshold 768103\n"
248*635a8641SAndroid Build Coastguard Worker       "pgpgin 30777108\n"
249*635a8641SAndroid Build Coastguard Worker       "pgpgout 319023278\n"
250*635a8641SAndroid Build Coastguard Worker       "pswpin 179\n"
251*635a8641SAndroid Build Coastguard Worker       "pswpout 406\n"
252*635a8641SAndroid Build Coastguard Worker       "pgalloc_dma 0\n"
253*635a8641SAndroid Build Coastguard Worker       "pgalloc_dma32 20833399\n"
254*635a8641SAndroid Build Coastguard Worker       "pgalloc_normal 1622609290\n"
255*635a8641SAndroid Build Coastguard Worker       "pgalloc_movable 0\n"
256*635a8641SAndroid Build Coastguard Worker       "pgfree 1644355583\n"
257*635a8641SAndroid Build Coastguard Worker       "pgactivate 75391882\n"
258*635a8641SAndroid Build Coastguard Worker       "pgdeactivate 4121019\n"
259*635a8641SAndroid Build Coastguard Worker       "pgfault 2542879679\n"
260*635a8641SAndroid Build Coastguard Worker       "pgmajfault 487192\n";
261*635a8641SAndroid Build Coastguard Worker   const char valid_input2[] =
262*635a8641SAndroid Build Coastguard Worker       "nr_free_pages 180125\n"
263*635a8641SAndroid Build Coastguard Worker       "nr_inactive_anon 51\n"
264*635a8641SAndroid Build Coastguard Worker       "nr_active_anon 38832\n"
265*635a8641SAndroid Build Coastguard Worker       "nr_inactive_file 50171\n"
266*635a8641SAndroid Build Coastguard Worker       "nr_active_file 47510\n"
267*635a8641SAndroid Build Coastguard Worker       "nr_unevictable 0\n"
268*635a8641SAndroid Build Coastguard Worker       "nr_mlock 0\n"
269*635a8641SAndroid Build Coastguard Worker       "nr_anon_pages 38825\n"
270*635a8641SAndroid Build Coastguard Worker       "nr_mapped 24043\n"
271*635a8641SAndroid Build Coastguard Worker       "nr_file_pages 97733\n"
272*635a8641SAndroid Build Coastguard Worker       "nr_dirty 0\n"
273*635a8641SAndroid Build Coastguard Worker       "nr_writeback 0\n"
274*635a8641SAndroid Build Coastguard Worker       "nr_slab_reclaimable 4032\n"
275*635a8641SAndroid Build Coastguard Worker       "nr_slab_unreclaimable 2848\n"
276*635a8641SAndroid Build Coastguard Worker       "nr_page_table_pages 1505\n"
277*635a8641SAndroid Build Coastguard Worker       "nr_kernel_stack 626\n"
278*635a8641SAndroid Build Coastguard Worker       "nr_unstable 0\n"
279*635a8641SAndroid Build Coastguard Worker       "nr_bounce 0\n"
280*635a8641SAndroid Build Coastguard Worker       "nr_vmscan_write 0\n"
281*635a8641SAndroid Build Coastguard Worker       "nr_vmscan_immediate_reclaim 0\n"
282*635a8641SAndroid Build Coastguard Worker       "nr_writeback_temp 0\n"
283*635a8641SAndroid Build Coastguard Worker       "nr_isolated_anon 0\n"
284*635a8641SAndroid Build Coastguard Worker       "nr_isolated_file 0\n"
285*635a8641SAndroid Build Coastguard Worker       "nr_shmem 58\n"
286*635a8641SAndroid Build Coastguard Worker       "nr_dirtied 435358\n"
287*635a8641SAndroid Build Coastguard Worker       "nr_written 401258\n"
288*635a8641SAndroid Build Coastguard Worker       "nr_anon_transparent_hugepages 0\n"
289*635a8641SAndroid Build Coastguard Worker       "nr_dirty_threshold 18566\n"
290*635a8641SAndroid Build Coastguard Worker       "nr_dirty_background_threshold 4641\n"
291*635a8641SAndroid Build Coastguard Worker       "pgpgin 299464\n"
292*635a8641SAndroid Build Coastguard Worker       "pgpgout 2437788\n"
293*635a8641SAndroid Build Coastguard Worker       "pswpin 12\n"
294*635a8641SAndroid Build Coastguard Worker       "pswpout 901\n"
295*635a8641SAndroid Build Coastguard Worker       "pgalloc_normal 144213030\n"
296*635a8641SAndroid Build Coastguard Worker       "pgalloc_high 164501274\n"
297*635a8641SAndroid Build Coastguard Worker       "pgalloc_movable 0\n"
298*635a8641SAndroid Build Coastguard Worker       "pgfree 308894908\n"
299*635a8641SAndroid Build Coastguard Worker       "pgactivate 239320\n"
300*635a8641SAndroid Build Coastguard Worker       "pgdeactivate 1\n"
301*635a8641SAndroid Build Coastguard Worker       "pgfault 716044601\n"
302*635a8641SAndroid Build Coastguard Worker       "pgmajfault 2023\n"
303*635a8641SAndroid Build Coastguard Worker       "pgrefill_normal 0\n"
304*635a8641SAndroid Build Coastguard Worker       "pgrefill_high 0\n"
305*635a8641SAndroid Build Coastguard Worker       "pgrefill_movable 0\n";
306*635a8641SAndroid Build Coastguard Worker   EXPECT_TRUE(ParseProcVmstat(valid_input1, &vmstat));
307*635a8641SAndroid Build Coastguard Worker   EXPECT_EQ(179LU, vmstat.pswpin);
308*635a8641SAndroid Build Coastguard Worker   EXPECT_EQ(406LU, vmstat.pswpout);
309*635a8641SAndroid Build Coastguard Worker   EXPECT_EQ(487192LU, vmstat.pgmajfault);
310*635a8641SAndroid Build Coastguard Worker   EXPECT_TRUE(ParseProcVmstat(valid_input2, &vmstat));
311*635a8641SAndroid Build Coastguard Worker   EXPECT_EQ(12LU, vmstat.pswpin);
312*635a8641SAndroid Build Coastguard Worker   EXPECT_EQ(901LU, vmstat.pswpout);
313*635a8641SAndroid Build Coastguard Worker   EXPECT_EQ(2023LU, vmstat.pgmajfault);
314*635a8641SAndroid Build Coastguard Worker 
315*635a8641SAndroid Build Coastguard Worker   const char missing_pgmajfault_input[] =
316*635a8641SAndroid Build Coastguard Worker       "pswpin 12\n"
317*635a8641SAndroid Build Coastguard Worker       "pswpout 901\n";
318*635a8641SAndroid Build Coastguard Worker   EXPECT_FALSE(ParseProcVmstat(missing_pgmajfault_input, &vmstat));
319*635a8641SAndroid Build Coastguard Worker   const char empty_input[] = "";
320*635a8641SAndroid Build Coastguard Worker   EXPECT_FALSE(ParseProcVmstat(empty_input, &vmstat));
321*635a8641SAndroid Build Coastguard Worker }
322*635a8641SAndroid Build Coastguard Worker #endif  // defined(OS_LINUX) || defined(OS_ANDROID)
323*635a8641SAndroid Build Coastguard Worker 
324*635a8641SAndroid Build Coastguard Worker #if defined(OS_LINUX) || defined(OS_CHROMEOS) || defined(OS_WIN)
325*635a8641SAndroid Build Coastguard Worker 
326*635a8641SAndroid Build Coastguard Worker // Test that ProcessMetrics::GetPlatformIndependentCPUUsage() doesn't return
327*635a8641SAndroid Build Coastguard Worker // negative values when the number of threads running on the process decreases
328*635a8641SAndroid Build Coastguard Worker // between two successive calls to it.
TEST_F(SystemMetricsTest,TestNoNegativeCpuUsage)329*635a8641SAndroid Build Coastguard Worker TEST_F(SystemMetricsTest, TestNoNegativeCpuUsage) {
330*635a8641SAndroid Build Coastguard Worker   ProcessHandle handle = GetCurrentProcessHandle();
331*635a8641SAndroid Build Coastguard Worker   std::unique_ptr<ProcessMetrics> metrics(
332*635a8641SAndroid Build Coastguard Worker       ProcessMetrics::CreateProcessMetrics(handle));
333*635a8641SAndroid Build Coastguard Worker 
334*635a8641SAndroid Build Coastguard Worker   EXPECT_GE(metrics->GetPlatformIndependentCPUUsage(), 0.0);
335*635a8641SAndroid Build Coastguard Worker   Thread thread1("thread1");
336*635a8641SAndroid Build Coastguard Worker   Thread thread2("thread2");
337*635a8641SAndroid Build Coastguard Worker   Thread thread3("thread3");
338*635a8641SAndroid Build Coastguard Worker 
339*635a8641SAndroid Build Coastguard Worker   thread1.StartAndWaitForTesting();
340*635a8641SAndroid Build Coastguard Worker   thread2.StartAndWaitForTesting();
341*635a8641SAndroid Build Coastguard Worker   thread3.StartAndWaitForTesting();
342*635a8641SAndroid Build Coastguard Worker 
343*635a8641SAndroid Build Coastguard Worker   ASSERT_TRUE(thread1.IsRunning());
344*635a8641SAndroid Build Coastguard Worker   ASSERT_TRUE(thread2.IsRunning());
345*635a8641SAndroid Build Coastguard Worker   ASSERT_TRUE(thread3.IsRunning());
346*635a8641SAndroid Build Coastguard Worker 
347*635a8641SAndroid Build Coastguard Worker   std::vector<std::string> vec1;
348*635a8641SAndroid Build Coastguard Worker   std::vector<std::string> vec2;
349*635a8641SAndroid Build Coastguard Worker   std::vector<std::string> vec3;
350*635a8641SAndroid Build Coastguard Worker 
351*635a8641SAndroid Build Coastguard Worker   thread1.task_runner()->PostTask(FROM_HERE, BindOnce(&BusyWork, &vec1));
352*635a8641SAndroid Build Coastguard Worker   thread2.task_runner()->PostTask(FROM_HERE, BindOnce(&BusyWork, &vec2));
353*635a8641SAndroid Build Coastguard Worker   thread3.task_runner()->PostTask(FROM_HERE, BindOnce(&BusyWork, &vec3));
354*635a8641SAndroid Build Coastguard Worker 
355*635a8641SAndroid Build Coastguard Worker   TimeDelta prev_cpu_usage = metrics->GetCumulativeCPUUsage();
356*635a8641SAndroid Build Coastguard Worker   EXPECT_GE(prev_cpu_usage, TimeDelta());
357*635a8641SAndroid Build Coastguard Worker   EXPECT_GE(metrics->GetPlatformIndependentCPUUsage(), 0.0);
358*635a8641SAndroid Build Coastguard Worker 
359*635a8641SAndroid Build Coastguard Worker   thread1.Stop();
360*635a8641SAndroid Build Coastguard Worker   TimeDelta current_cpu_usage = metrics->GetCumulativeCPUUsage();
361*635a8641SAndroid Build Coastguard Worker   EXPECT_GE(current_cpu_usage, prev_cpu_usage);
362*635a8641SAndroid Build Coastguard Worker   prev_cpu_usage = current_cpu_usage;
363*635a8641SAndroid Build Coastguard Worker   EXPECT_GE(metrics->GetPlatformIndependentCPUUsage(), 0.0);
364*635a8641SAndroid Build Coastguard Worker 
365*635a8641SAndroid Build Coastguard Worker   thread2.Stop();
366*635a8641SAndroid Build Coastguard Worker   current_cpu_usage = metrics->GetCumulativeCPUUsage();
367*635a8641SAndroid Build Coastguard Worker   EXPECT_GE(current_cpu_usage, prev_cpu_usage);
368*635a8641SAndroid Build Coastguard Worker   prev_cpu_usage = current_cpu_usage;
369*635a8641SAndroid Build Coastguard Worker   EXPECT_GE(metrics->GetPlatformIndependentCPUUsage(), 0.0);
370*635a8641SAndroid Build Coastguard Worker 
371*635a8641SAndroid Build Coastguard Worker   thread3.Stop();
372*635a8641SAndroid Build Coastguard Worker   current_cpu_usage = metrics->GetCumulativeCPUUsage();
373*635a8641SAndroid Build Coastguard Worker   EXPECT_GE(current_cpu_usage, prev_cpu_usage);
374*635a8641SAndroid Build Coastguard Worker   EXPECT_GE(metrics->GetPlatformIndependentCPUUsage(), 0.0);
375*635a8641SAndroid Build Coastguard Worker }
376*635a8641SAndroid Build Coastguard Worker 
377*635a8641SAndroid Build Coastguard Worker #endif  // defined(OS_LINUX) || defined(OS_CHROMEOS)
378*635a8641SAndroid Build Coastguard Worker 
379*635a8641SAndroid Build Coastguard Worker #if defined(OS_CHROMEOS)
TEST_F(SystemMetricsTest,ParseZramMmStat)380*635a8641SAndroid Build Coastguard Worker TEST_F(SystemMetricsTest, ParseZramMmStat) {
381*635a8641SAndroid Build Coastguard Worker   SwapInfo swapinfo;
382*635a8641SAndroid Build Coastguard Worker 
383*635a8641SAndroid Build Coastguard Worker   const char invalid_input1[] = "aaa";
384*635a8641SAndroid Build Coastguard Worker   const char invalid_input2[] = "1 2 3 4 5 6";
385*635a8641SAndroid Build Coastguard Worker   const char invalid_input3[] = "a 2 3 4 5 6 7";
386*635a8641SAndroid Build Coastguard Worker   EXPECT_FALSE(ParseZramMmStat(invalid_input1, &swapinfo));
387*635a8641SAndroid Build Coastguard Worker   EXPECT_FALSE(ParseZramMmStat(invalid_input2, &swapinfo));
388*635a8641SAndroid Build Coastguard Worker   EXPECT_FALSE(ParseZramMmStat(invalid_input3, &swapinfo));
389*635a8641SAndroid Build Coastguard Worker 
390*635a8641SAndroid Build Coastguard Worker   const char valid_input1[] =
391*635a8641SAndroid Build Coastguard Worker       "17715200 5008166 566062  0 1225715712  127 183842";
392*635a8641SAndroid Build Coastguard Worker   EXPECT_TRUE(ParseZramMmStat(valid_input1, &swapinfo));
393*635a8641SAndroid Build Coastguard Worker   EXPECT_EQ(17715200ULL, swapinfo.orig_data_size);
394*635a8641SAndroid Build Coastguard Worker   EXPECT_EQ(5008166ULL, swapinfo.compr_data_size);
395*635a8641SAndroid Build Coastguard Worker   EXPECT_EQ(566062ULL, swapinfo.mem_used_total);
396*635a8641SAndroid Build Coastguard Worker }
397*635a8641SAndroid Build Coastguard Worker 
TEST_F(SystemMetricsTest,ParseZramStat)398*635a8641SAndroid Build Coastguard Worker TEST_F(SystemMetricsTest, ParseZramStat) {
399*635a8641SAndroid Build Coastguard Worker   SwapInfo swapinfo;
400*635a8641SAndroid Build Coastguard Worker 
401*635a8641SAndroid Build Coastguard Worker   const char invalid_input1[] = "aaa";
402*635a8641SAndroid Build Coastguard Worker   const char invalid_input2[] = "1 2 3 4 5 6 7 8 9 10";
403*635a8641SAndroid Build Coastguard Worker   const char invalid_input3[] = "a 2 3 4 5 6 7 8 9 10 11";
404*635a8641SAndroid Build Coastguard Worker   EXPECT_FALSE(ParseZramStat(invalid_input1, &swapinfo));
405*635a8641SAndroid Build Coastguard Worker   EXPECT_FALSE(ParseZramStat(invalid_input2, &swapinfo));
406*635a8641SAndroid Build Coastguard Worker   EXPECT_FALSE(ParseZramStat(invalid_input3, &swapinfo));
407*635a8641SAndroid Build Coastguard Worker 
408*635a8641SAndroid Build Coastguard Worker   const char valid_input1[] =
409*635a8641SAndroid Build Coastguard Worker       "299    0    2392    0    1    0    8    0    0    0    0";
410*635a8641SAndroid Build Coastguard Worker   EXPECT_TRUE(ParseZramStat(valid_input1, &swapinfo));
411*635a8641SAndroid Build Coastguard Worker   EXPECT_EQ(299ULL, swapinfo.num_reads);
412*635a8641SAndroid Build Coastguard Worker   EXPECT_EQ(1ULL, swapinfo.num_writes);
413*635a8641SAndroid Build Coastguard Worker }
414*635a8641SAndroid Build Coastguard Worker #endif  // defined(OS_CHROMEOS)
415*635a8641SAndroid Build Coastguard Worker 
416*635a8641SAndroid Build Coastguard Worker #if defined(OS_WIN) || defined(OS_MACOSX) || defined(OS_LINUX) || \
417*635a8641SAndroid Build Coastguard Worker     defined(OS_ANDROID)
TEST(SystemMetrics2Test,GetSystemMemoryInfo)418*635a8641SAndroid Build Coastguard Worker TEST(SystemMetrics2Test, GetSystemMemoryInfo) {
419*635a8641SAndroid Build Coastguard Worker   SystemMemoryInfoKB info;
420*635a8641SAndroid Build Coastguard Worker   EXPECT_TRUE(GetSystemMemoryInfo(&info));
421*635a8641SAndroid Build Coastguard Worker 
422*635a8641SAndroid Build Coastguard Worker   // Ensure each field received a value.
423*635a8641SAndroid Build Coastguard Worker   EXPECT_GT(info.total, 0);
424*635a8641SAndroid Build Coastguard Worker #if defined(OS_WIN)
425*635a8641SAndroid Build Coastguard Worker   EXPECT_GT(info.avail_phys, 0);
426*635a8641SAndroid Build Coastguard Worker #else
427*635a8641SAndroid Build Coastguard Worker   EXPECT_GT(info.free, 0);
428*635a8641SAndroid Build Coastguard Worker #endif
429*635a8641SAndroid Build Coastguard Worker #if defined(OS_LINUX) || defined(OS_ANDROID)
430*635a8641SAndroid Build Coastguard Worker   EXPECT_GT(info.buffers, 0);
431*635a8641SAndroid Build Coastguard Worker   EXPECT_GT(info.cached, 0);
432*635a8641SAndroid Build Coastguard Worker   EXPECT_GT(info.active_anon, 0);
433*635a8641SAndroid Build Coastguard Worker   EXPECT_GT(info.inactive_anon, 0);
434*635a8641SAndroid Build Coastguard Worker   EXPECT_GT(info.active_file, 0);
435*635a8641SAndroid Build Coastguard Worker   EXPECT_GT(info.inactive_file, 0);
436*635a8641SAndroid Build Coastguard Worker #endif  // defined(OS_LINUX) || defined(OS_ANDROID)
437*635a8641SAndroid Build Coastguard Worker 
438*635a8641SAndroid Build Coastguard Worker   // All the values should be less than the total amount of memory.
439*635a8641SAndroid Build Coastguard Worker #if !defined(OS_WIN) && !defined(OS_IOS)
440*635a8641SAndroid Build Coastguard Worker   // TODO(crbug.com/711450): re-enable the following assertion on iOS.
441*635a8641SAndroid Build Coastguard Worker   EXPECT_LT(info.free, info.total);
442*635a8641SAndroid Build Coastguard Worker #endif
443*635a8641SAndroid Build Coastguard Worker #if defined(OS_LINUX) || defined(OS_ANDROID)
444*635a8641SAndroid Build Coastguard Worker   EXPECT_LT(info.buffers, info.total);
445*635a8641SAndroid Build Coastguard Worker   EXPECT_LT(info.cached, info.total);
446*635a8641SAndroid Build Coastguard Worker   EXPECT_LT(info.active_anon, info.total);
447*635a8641SAndroid Build Coastguard Worker   EXPECT_LT(info.inactive_anon, info.total);
448*635a8641SAndroid Build Coastguard Worker   EXPECT_LT(info.active_file, info.total);
449*635a8641SAndroid Build Coastguard Worker   EXPECT_LT(info.inactive_file, info.total);
450*635a8641SAndroid Build Coastguard Worker #endif  // defined(OS_LINUX) || defined(OS_ANDROID)
451*635a8641SAndroid Build Coastguard Worker 
452*635a8641SAndroid Build Coastguard Worker #if defined(OS_MACOSX) || defined(OS_IOS)
453*635a8641SAndroid Build Coastguard Worker   EXPECT_GT(info.file_backed, 0);
454*635a8641SAndroid Build Coastguard Worker #endif
455*635a8641SAndroid Build Coastguard Worker 
456*635a8641SAndroid Build Coastguard Worker #if defined(OS_CHROMEOS)
457*635a8641SAndroid Build Coastguard Worker   // Chrome OS exposes shmem.
458*635a8641SAndroid Build Coastguard Worker   EXPECT_GT(info.shmem, 0);
459*635a8641SAndroid Build Coastguard Worker   EXPECT_LT(info.shmem, info.total);
460*635a8641SAndroid Build Coastguard Worker   // Chrome unit tests are not run on actual Chrome OS hardware, so gem_objects
461*635a8641SAndroid Build Coastguard Worker   // and gem_size cannot be tested here.
462*635a8641SAndroid Build Coastguard Worker #endif
463*635a8641SAndroid Build Coastguard Worker }
464*635a8641SAndroid Build Coastguard Worker #endif  // defined(OS_WIN) || defined(OS_MACOSX) || defined(OS_LINUX) ||
465*635a8641SAndroid Build Coastguard Worker         // defined(OS_ANDROID)
466*635a8641SAndroid Build Coastguard Worker 
467*635a8641SAndroid Build Coastguard Worker #if defined(OS_LINUX) || defined(OS_ANDROID)
TEST(ProcessMetricsTest,ParseProcStatCPU)468*635a8641SAndroid Build Coastguard Worker TEST(ProcessMetricsTest, ParseProcStatCPU) {
469*635a8641SAndroid Build Coastguard Worker   // /proc/self/stat for a process running "top".
470*635a8641SAndroid Build Coastguard Worker   const char kTopStat[] = "960 (top) S 16230 960 16230 34818 960 "
471*635a8641SAndroid Build Coastguard Worker       "4202496 471 0 0 0 "
472*635a8641SAndroid Build Coastguard Worker       "12 16 0 0 "  // <- These are the goods.
473*635a8641SAndroid Build Coastguard Worker       "20 0 1 0 121946157 15077376 314 18446744073709551615 4194304 "
474*635a8641SAndroid Build Coastguard Worker       "4246868 140733983044336 18446744073709551615 140244213071219 "
475*635a8641SAndroid Build Coastguard Worker       "0 0 0 138047495 0 0 0 17 1 0 0 0 0 0";
476*635a8641SAndroid Build Coastguard Worker   EXPECT_EQ(12 + 16, ParseProcStatCPU(kTopStat));
477*635a8641SAndroid Build Coastguard Worker 
478*635a8641SAndroid Build Coastguard Worker   // cat /proc/self/stat on a random other machine I have.
479*635a8641SAndroid Build Coastguard Worker   const char kSelfStat[] = "5364 (cat) R 5354 5364 5354 34819 5364 "
480*635a8641SAndroid Build Coastguard Worker       "0 142 0 0 0 "
481*635a8641SAndroid Build Coastguard Worker       "0 0 0 0 "  // <- No CPU, apparently.
482*635a8641SAndroid Build Coastguard Worker       "16 0 1 0 1676099790 2957312 114 4294967295 134512640 134528148 "
483*635a8641SAndroid Build Coastguard Worker       "3221224832 3221224344 3086339742 0 0 0 0 0 0 0 17 0 0 0";
484*635a8641SAndroid Build Coastguard Worker 
485*635a8641SAndroid Build Coastguard Worker   EXPECT_EQ(0, ParseProcStatCPU(kSelfStat));
486*635a8641SAndroid Build Coastguard Worker 
487*635a8641SAndroid Build Coastguard Worker   // Some weird long-running process with a weird name that I created for the
488*635a8641SAndroid Build Coastguard Worker   // purposes of this test.
489*635a8641SAndroid Build Coastguard Worker   const char kWeirdNameStat[] = "26115 (Hello) You ()))  ) R 24614 26115 24614"
490*635a8641SAndroid Build Coastguard Worker       " 34839 26115 4218880 227 0 0 0 "
491*635a8641SAndroid Build Coastguard Worker       "5186 11 0 0 "
492*635a8641SAndroid Build Coastguard Worker       "20 0 1 0 36933953 4296704 90 18446744073709551615 4194304 4196116 "
493*635a8641SAndroid Build Coastguard Worker       "140735857761568 140735857761160 4195644 0 0 0 0 0 0 0 17 14 0 0 0 0 0 "
494*635a8641SAndroid Build Coastguard Worker       "6295056 6295616 16519168 140735857770710 140735857770737 "
495*635a8641SAndroid Build Coastguard Worker       "140735857770737 140735857774557 0";
496*635a8641SAndroid Build Coastguard Worker   EXPECT_EQ(5186 + 11, ParseProcStatCPU(kWeirdNameStat));
497*635a8641SAndroid Build Coastguard Worker }
498*635a8641SAndroid Build Coastguard Worker #endif  // defined(OS_LINUX) || defined(OS_ANDROID)
499*635a8641SAndroid Build Coastguard Worker 
500*635a8641SAndroid Build Coastguard Worker // Disable on Android because base_unittests runs inside a Dalvik VM that
501*635a8641SAndroid Build Coastguard Worker // starts and stop threads (crbug.com/175563).
502*635a8641SAndroid Build Coastguard Worker #if defined(OS_LINUX)
503*635a8641SAndroid Build Coastguard Worker // http://crbug.com/396455
TEST(ProcessMetricsTest,DISABLED_GetNumberOfThreads)504*635a8641SAndroid Build Coastguard Worker TEST(ProcessMetricsTest, DISABLED_GetNumberOfThreads) {
505*635a8641SAndroid Build Coastguard Worker   const ProcessHandle current = GetCurrentProcessHandle();
506*635a8641SAndroid Build Coastguard Worker   const int initial_threads = GetNumberOfThreads(current);
507*635a8641SAndroid Build Coastguard Worker   ASSERT_GT(initial_threads, 0);
508*635a8641SAndroid Build Coastguard Worker   const int kNumAdditionalThreads = 10;
509*635a8641SAndroid Build Coastguard Worker   {
510*635a8641SAndroid Build Coastguard Worker     std::unique_ptr<Thread> my_threads[kNumAdditionalThreads];
511*635a8641SAndroid Build Coastguard Worker     for (int i = 0; i < kNumAdditionalThreads; ++i) {
512*635a8641SAndroid Build Coastguard Worker       my_threads[i].reset(new Thread("GetNumberOfThreadsTest"));
513*635a8641SAndroid Build Coastguard Worker       my_threads[i]->Start();
514*635a8641SAndroid Build Coastguard Worker       ASSERT_EQ(GetNumberOfThreads(current), initial_threads + 1 + i);
515*635a8641SAndroid Build Coastguard Worker     }
516*635a8641SAndroid Build Coastguard Worker   }
517*635a8641SAndroid Build Coastguard Worker   // The Thread destructor will stop them.
518*635a8641SAndroid Build Coastguard Worker   ASSERT_EQ(initial_threads, GetNumberOfThreads(current));
519*635a8641SAndroid Build Coastguard Worker }
520*635a8641SAndroid Build Coastguard Worker #endif  // defined(OS_LINUX)
521*635a8641SAndroid Build Coastguard Worker 
522*635a8641SAndroid Build Coastguard Worker #if defined(OS_LINUX)
523*635a8641SAndroid Build Coastguard Worker namespace {
524*635a8641SAndroid Build Coastguard Worker 
525*635a8641SAndroid Build Coastguard Worker // Keep these in sync so the GetChildOpenFdCount test can refer to correct test
526*635a8641SAndroid Build Coastguard Worker // main.
527*635a8641SAndroid Build Coastguard Worker #define ChildMain ChildFdCount
528*635a8641SAndroid Build Coastguard Worker #define ChildMainString "ChildFdCount"
529*635a8641SAndroid Build Coastguard Worker 
530*635a8641SAndroid Build Coastguard Worker // Command line flag name and file name used for synchronization.
531*635a8641SAndroid Build Coastguard Worker const char kTempDirFlag[] = "temp-dir";
532*635a8641SAndroid Build Coastguard Worker const char kSignalClosed[] = "closed";
533*635a8641SAndroid Build Coastguard Worker 
SignalEvent(const FilePath & signal_dir,const char * signal_file)534*635a8641SAndroid Build Coastguard Worker bool SignalEvent(const FilePath& signal_dir, const char* signal_file) {
535*635a8641SAndroid Build Coastguard Worker   File file(signal_dir.AppendASCII(signal_file),
536*635a8641SAndroid Build Coastguard Worker             File::FLAG_CREATE | File::FLAG_WRITE);
537*635a8641SAndroid Build Coastguard Worker   return file.IsValid();
538*635a8641SAndroid Build Coastguard Worker }
539*635a8641SAndroid Build Coastguard Worker 
540*635a8641SAndroid Build Coastguard Worker // Check whether an event was signaled.
CheckEvent(const FilePath & signal_dir,const char * signal_file)541*635a8641SAndroid Build Coastguard Worker bool CheckEvent(const FilePath& signal_dir, const char* signal_file) {
542*635a8641SAndroid Build Coastguard Worker   File file(signal_dir.AppendASCII(signal_file),
543*635a8641SAndroid Build Coastguard Worker             File::FLAG_OPEN | File::FLAG_READ);
544*635a8641SAndroid Build Coastguard Worker   return file.IsValid();
545*635a8641SAndroid Build Coastguard Worker }
546*635a8641SAndroid Build Coastguard Worker 
547*635a8641SAndroid Build Coastguard Worker // Busy-wait for an event to be signaled.
WaitForEvent(const FilePath & signal_dir,const char * signal_file)548*635a8641SAndroid Build Coastguard Worker void WaitForEvent(const FilePath& signal_dir, const char* signal_file) {
549*635a8641SAndroid Build Coastguard Worker   while (!CheckEvent(signal_dir, signal_file))
550*635a8641SAndroid Build Coastguard Worker     PlatformThread::Sleep(TimeDelta::FromMilliseconds(10));
551*635a8641SAndroid Build Coastguard Worker }
552*635a8641SAndroid Build Coastguard Worker 
553*635a8641SAndroid Build Coastguard Worker // Subprocess to test the number of open file descriptors.
MULTIPROCESS_TEST_MAIN(ChildMain)554*635a8641SAndroid Build Coastguard Worker MULTIPROCESS_TEST_MAIN(ChildMain) {
555*635a8641SAndroid Build Coastguard Worker   CommandLine* command_line = CommandLine::ForCurrentProcess();
556*635a8641SAndroid Build Coastguard Worker   const FilePath temp_path = command_line->GetSwitchValuePath(kTempDirFlag);
557*635a8641SAndroid Build Coastguard Worker   CHECK(DirectoryExists(temp_path));
558*635a8641SAndroid Build Coastguard Worker 
559*635a8641SAndroid Build Coastguard Worker   // Try to close all the file descriptors, so the open count goes to 0.
560*635a8641SAndroid Build Coastguard Worker   for (size_t i = 0; i < 1000; ++i)
561*635a8641SAndroid Build Coastguard Worker     close(i);
562*635a8641SAndroid Build Coastguard Worker   CHECK(SignalEvent(temp_path, kSignalClosed));
563*635a8641SAndroid Build Coastguard Worker 
564*635a8641SAndroid Build Coastguard Worker   // Wait to be terminated.
565*635a8641SAndroid Build Coastguard Worker   while (true)
566*635a8641SAndroid Build Coastguard Worker     PlatformThread::Sleep(TimeDelta::FromSeconds(1));
567*635a8641SAndroid Build Coastguard Worker   return 0;
568*635a8641SAndroid Build Coastguard Worker }
569*635a8641SAndroid Build Coastguard Worker 
570*635a8641SAndroid Build Coastguard Worker }  // namespace
571*635a8641SAndroid Build Coastguard Worker 
572*635a8641SAndroid Build Coastguard Worker // ARC note: don't compile as SpawnMultiProcessTestChild brings in a lot of
573*635a8641SAndroid Build Coastguard Worker // extra dependency.
574*635a8641SAndroid Build Coastguard Worker #if !defined(OS_ANDROID) && !defined(__ANDROID_HOST__)
TEST(ProcessMetricsTest,GetChildOpenFdCount)575*635a8641SAndroid Build Coastguard Worker TEST(ProcessMetricsTest, GetChildOpenFdCount) {
576*635a8641SAndroid Build Coastguard Worker   ScopedTempDir temp_dir;
577*635a8641SAndroid Build Coastguard Worker   ASSERT_TRUE(temp_dir.CreateUniqueTempDir());
578*635a8641SAndroid Build Coastguard Worker   const FilePath temp_path = temp_dir.GetPath();
579*635a8641SAndroid Build Coastguard Worker   CommandLine child_command_line(GetMultiProcessTestChildBaseCommandLine());
580*635a8641SAndroid Build Coastguard Worker   child_command_line.AppendSwitchPath(kTempDirFlag, temp_path);
581*635a8641SAndroid Build Coastguard Worker   Process child = SpawnMultiProcessTestChild(
582*635a8641SAndroid Build Coastguard Worker       ChildMainString, child_command_line, LaunchOptions());
583*635a8641SAndroid Build Coastguard Worker   ASSERT_TRUE(child.IsValid());
584*635a8641SAndroid Build Coastguard Worker   WaitForEvent(temp_path, kSignalClosed);
585*635a8641SAndroid Build Coastguard Worker 
586*635a8641SAndroid Build Coastguard Worker   std::unique_ptr<ProcessMetrics> metrics(
587*635a8641SAndroid Build Coastguard Worker       ProcessMetrics::CreateProcessMetrics(child.Handle()));
588*635a8641SAndroid Build Coastguard Worker   // Try a couple times to observe the child with 0 fds open.
589*635a8641SAndroid Build Coastguard Worker   // Sometimes we've seen that the child can have 1 remaining
590*635a8641SAndroid Build Coastguard Worker   // fd shortly after receiving the signal.  Potentially this
591*635a8641SAndroid Build Coastguard Worker   // is actually the signal file still open in the child.
592*635a8641SAndroid Build Coastguard Worker   int open_fds = -1;
593*635a8641SAndroid Build Coastguard Worker   for (int tries = 0; tries < 5; ++tries) {
594*635a8641SAndroid Build Coastguard Worker     open_fds = metrics->GetOpenFdCount();
595*635a8641SAndroid Build Coastguard Worker     if (!open_fds) {
596*635a8641SAndroid Build Coastguard Worker       break;
597*635a8641SAndroid Build Coastguard Worker     }
598*635a8641SAndroid Build Coastguard Worker     PlatformThread::Sleep(TimeDelta::FromMilliseconds(1));
599*635a8641SAndroid Build Coastguard Worker   }
600*635a8641SAndroid Build Coastguard Worker   EXPECT_EQ(0, open_fds);
601*635a8641SAndroid Build Coastguard Worker   ASSERT_TRUE(child.Terminate(0, true));
602*635a8641SAndroid Build Coastguard Worker }
603*635a8641SAndroid Build Coastguard Worker #endif  // !defined(OS_ANDROID) && !defined(__ANDROID_HOST__)
604*635a8641SAndroid Build Coastguard Worker 
605*635a8641SAndroid Build Coastguard Worker #endif  // defined(OS_LINUX)
606*635a8641SAndroid Build Coastguard Worker 
607*635a8641SAndroid Build Coastguard Worker #if defined(OS_ANDROID) || defined(OS_LINUX)
608*635a8641SAndroid Build Coastguard Worker 
TEST(ProcessMetricsTest,GetOpenFdCount)609*635a8641SAndroid Build Coastguard Worker TEST(ProcessMetricsTest, GetOpenFdCount) {
610*635a8641SAndroid Build Coastguard Worker   std::unique_ptr<base::ProcessMetrics> metrics(
611*635a8641SAndroid Build Coastguard Worker       base::ProcessMetrics::CreateProcessMetrics(
612*635a8641SAndroid Build Coastguard Worker           base::GetCurrentProcessHandle()));
613*635a8641SAndroid Build Coastguard Worker   int fd_count = metrics->GetOpenFdCount();
614*635a8641SAndroid Build Coastguard Worker   EXPECT_GT(fd_count, 0);
615*635a8641SAndroid Build Coastguard Worker   ScopedFILE file(fopen("/proc/self/statm", "r"));
616*635a8641SAndroid Build Coastguard Worker   EXPECT_TRUE(file);
617*635a8641SAndroid Build Coastguard Worker   int new_fd_count = metrics->GetOpenFdCount();
618*635a8641SAndroid Build Coastguard Worker   EXPECT_GT(new_fd_count, 0);
619*635a8641SAndroid Build Coastguard Worker   EXPECT_EQ(new_fd_count, fd_count + 1);
620*635a8641SAndroid Build Coastguard Worker }
621*635a8641SAndroid Build Coastguard Worker 
TEST(ProcessMetricsTestLinux,GetPageFaultCounts)622*635a8641SAndroid Build Coastguard Worker TEST(ProcessMetricsTestLinux, GetPageFaultCounts) {
623*635a8641SAndroid Build Coastguard Worker   std::unique_ptr<base::ProcessMetrics> process_metrics(
624*635a8641SAndroid Build Coastguard Worker       base::ProcessMetrics::CreateProcessMetrics(
625*635a8641SAndroid Build Coastguard Worker           base::GetCurrentProcessHandle()));
626*635a8641SAndroid Build Coastguard Worker 
627*635a8641SAndroid Build Coastguard Worker   PageFaultCounts counts;
628*635a8641SAndroid Build Coastguard Worker   ASSERT_TRUE(process_metrics->GetPageFaultCounts(&counts));
629*635a8641SAndroid Build Coastguard Worker   ASSERT_GT(counts.minor, 0);
630*635a8641SAndroid Build Coastguard Worker   ASSERT_GE(counts.major, 0);
631*635a8641SAndroid Build Coastguard Worker 
632*635a8641SAndroid Build Coastguard Worker   {
633*635a8641SAndroid Build Coastguard Worker     // Allocate and touch memory. Touching it is required to make sure that the
634*635a8641SAndroid Build Coastguard Worker     // page fault count goes up, as memory is typically mapped lazily.
635*635a8641SAndroid Build Coastguard Worker     const size_t kMappedSize = 4 * (1 << 20);
636*635a8641SAndroid Build Coastguard Worker     SharedMemory memory;
637*635a8641SAndroid Build Coastguard Worker     ASSERT_TRUE(memory.CreateAndMapAnonymous(kMappedSize));
638*635a8641SAndroid Build Coastguard Worker     memset(memory.memory(), 42, kMappedSize);
639*635a8641SAndroid Build Coastguard Worker     memory.Unmap();
640*635a8641SAndroid Build Coastguard Worker   }
641*635a8641SAndroid Build Coastguard Worker 
642*635a8641SAndroid Build Coastguard Worker   PageFaultCounts counts_after;
643*635a8641SAndroid Build Coastguard Worker   ASSERT_TRUE(process_metrics->GetPageFaultCounts(&counts_after));
644*635a8641SAndroid Build Coastguard Worker   ASSERT_GT(counts_after.minor, counts.minor);
645*635a8641SAndroid Build Coastguard Worker   ASSERT_GE(counts_after.major, counts.major);
646*635a8641SAndroid Build Coastguard Worker }
647*635a8641SAndroid Build Coastguard Worker #endif  // defined(OS_ANDROID) || defined(OS_LINUX)
648*635a8641SAndroid Build Coastguard Worker 
649*635a8641SAndroid Build Coastguard Worker }  // namespace debug
650*635a8641SAndroid Build Coastguard Worker }  // namespace base
651