Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(48)

Side by Side Diff: base/trace_event/process_memory_maps_dump_provider_unittest.cc

Issue 1262333005: [tracing] Introduce MemoryDumpArgs to enable light and heavy dumps (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Rebase. Created 5 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright 2015 The Chromium Authors. All rights reserved. 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 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "base/trace_event/process_memory_maps_dump_provider.h" 5 #include "base/trace_event/process_memory_maps_dump_provider.h"
6 6
7 #include <fstream> 7 #include <fstream>
8 #include <sstream> 8 #include <sstream>
9 9
10 #include "base/trace_event/process_memory_dump.h" 10 #include "base/trace_event/process_memory_dump.h"
(...skipping 92 matching lines...) Expand 10 before | Expand all | Expand 10 after
103 "KernelPageSize: 4 kB\n" 103 "KernelPageSize: 4 kB\n"
104 "MMUPageSize: 4 kB\n" 104 "MMUPageSize: 4 kB\n"
105 "Locked: 0 kB\n" 105 "Locked: 0 kB\n"
106 "VmFlags: rd wr mr mw me ac sd\n"; 106 "VmFlags: rd wr mr mw me ac sd\n";
107 } // namespace 107 } // namespace
108 108
109 TEST(ProcessMemoryMapsDumpProviderTest, ParseProcSmaps) { 109 TEST(ProcessMemoryMapsDumpProviderTest, ParseProcSmaps) {
110 const uint32 kProtR = ProcessMemoryMaps::VMRegion::kProtectionFlagsRead; 110 const uint32 kProtR = ProcessMemoryMaps::VMRegion::kProtectionFlagsRead;
111 const uint32 kProtW = ProcessMemoryMaps::VMRegion::kProtectionFlagsWrite; 111 const uint32 kProtW = ProcessMemoryMaps::VMRegion::kProtectionFlagsWrite;
112 const uint32 kProtX = ProcessMemoryMaps::VMRegion::kProtectionFlagsExec; 112 const uint32 kProtX = ProcessMemoryMaps::VMRegion::kProtectionFlagsExec;
113 const MemoryDumpArgs dump_args = {MemoryDumpArgs::LEVEL_OF_DETAIL_HIGH};
113 114
114 auto pmmdp = ProcessMemoryMapsDumpProvider::GetInstance(); 115 auto pmmdp = ProcessMemoryMapsDumpProvider::GetInstance();
115 116
116 // Emulate a non-existent /proc/self/smaps. 117 // Emulate a non-existent /proc/self/smaps.
117 ProcessMemoryDump pmd_invalid(nullptr /* session_state */); 118 ProcessMemoryDump pmd_invalid(nullptr /* session_state */);
118 std::ifstream non_existent_file("/tmp/does-not-exist"); 119 std::ifstream non_existent_file("/tmp/does-not-exist");
119 ProcessMemoryMapsDumpProvider::proc_smaps_for_testing = &non_existent_file; 120 ProcessMemoryMapsDumpProvider::proc_smaps_for_testing = &non_existent_file;
120 CHECK_EQ(false, non_existent_file.good()); 121 CHECK_EQ(false, non_existent_file.good());
121 pmmdp->OnMemoryDump(&pmd_invalid); 122 pmmdp->OnMemoryDump(dump_args, &pmd_invalid);
122 ASSERT_FALSE(pmd_invalid.has_process_mmaps()); 123 ASSERT_FALSE(pmd_invalid.has_process_mmaps());
123 124
124 // Emulate an empty /proc/self/smaps. 125 // Emulate an empty /proc/self/smaps.
125 std::ifstream empty_file("/dev/null"); 126 std::ifstream empty_file("/dev/null");
126 ProcessMemoryMapsDumpProvider::proc_smaps_for_testing = &empty_file; 127 ProcessMemoryMapsDumpProvider::proc_smaps_for_testing = &empty_file;
127 CHECK_EQ(true, empty_file.good()); 128 CHECK_EQ(true, empty_file.good());
128 pmmdp->OnMemoryDump(&pmd_invalid); 129 pmmdp->OnMemoryDump(dump_args, &pmd_invalid);
129 ASSERT_FALSE(pmd_invalid.has_process_mmaps()); 130 ASSERT_FALSE(pmd_invalid.has_process_mmaps());
130 131
131 // Parse the 1st smaps file. 132 // Parse the 1st smaps file.
132 ProcessMemoryDump pmd_1(nullptr /* session_state */); 133 ProcessMemoryDump pmd_1(nullptr /* session_state */);
133 std::istringstream test_smaps_1(kTestSmaps1); 134 std::istringstream test_smaps_1(kTestSmaps1);
134 ProcessMemoryMapsDumpProvider::proc_smaps_for_testing = &test_smaps_1; 135 ProcessMemoryMapsDumpProvider::proc_smaps_for_testing = &test_smaps_1;
135 pmmdp->OnMemoryDump(&pmd_1); 136 pmmdp->OnMemoryDump(dump_args, &pmd_1);
136 ASSERT_TRUE(pmd_1.has_process_mmaps()); 137 ASSERT_TRUE(pmd_1.has_process_mmaps());
137 const auto& regions_1 = pmd_1.process_mmaps()->vm_regions(); 138 const auto& regions_1 = pmd_1.process_mmaps()->vm_regions();
138 ASSERT_EQ(2UL, regions_1.size()); 139 ASSERT_EQ(2UL, regions_1.size());
139 140
140 EXPECT_EQ(0x00400000UL, regions_1[0].start_address); 141 EXPECT_EQ(0x00400000UL, regions_1[0].start_address);
141 EXPECT_EQ(0x004be000UL - 0x00400000UL, regions_1[0].size_in_bytes); 142 EXPECT_EQ(0x004be000UL - 0x00400000UL, regions_1[0].size_in_bytes);
142 EXPECT_EQ(kProtR | kProtX, regions_1[0].protection_flags); 143 EXPECT_EQ(kProtR | kProtX, regions_1[0].protection_flags);
143 EXPECT_EQ("/file/1", regions_1[0].mapped_file); 144 EXPECT_EQ("/file/1", regions_1[0].mapped_file);
144 EXPECT_EQ(162 * 1024UL, regions_1[0].byte_stats_proportional_resident); 145 EXPECT_EQ(162 * 1024UL, regions_1[0].byte_stats_proportional_resident);
145 EXPECT_EQ(228 * 1024UL, regions_1[0].byte_stats_shared_clean_resident); 146 EXPECT_EQ(228 * 1024UL, regions_1[0].byte_stats_shared_clean_resident);
(...skipping 10 matching lines...) Expand all
156 EXPECT_EQ(120 * 1024UL, regions_1[1].byte_stats_shared_clean_resident); 157 EXPECT_EQ(120 * 1024UL, regions_1[1].byte_stats_shared_clean_resident);
157 EXPECT_EQ(4 * 1024UL, regions_1[1].byte_stats_shared_dirty_resident); 158 EXPECT_EQ(4 * 1024UL, regions_1[1].byte_stats_shared_dirty_resident);
158 EXPECT_EQ(60 * 1024UL, regions_1[1].byte_stats_private_clean_resident); 159 EXPECT_EQ(60 * 1024UL, regions_1[1].byte_stats_private_clean_resident);
159 EXPECT_EQ(8 * 1024UL, regions_1[1].byte_stats_private_dirty_resident); 160 EXPECT_EQ(8 * 1024UL, regions_1[1].byte_stats_private_dirty_resident);
160 EXPECT_EQ(0 * 1024UL, regions_1[1].byte_stats_swapped); 161 EXPECT_EQ(0 * 1024UL, regions_1[1].byte_stats_swapped);
161 162
162 // Parse the 2nd smaps file. 163 // Parse the 2nd smaps file.
163 ProcessMemoryDump pmd_2(nullptr /* session_state */); 164 ProcessMemoryDump pmd_2(nullptr /* session_state */);
164 std::istringstream test_smaps_2(kTestSmaps2); 165 std::istringstream test_smaps_2(kTestSmaps2);
165 ProcessMemoryMapsDumpProvider::proc_smaps_for_testing = &test_smaps_2; 166 ProcessMemoryMapsDumpProvider::proc_smaps_for_testing = &test_smaps_2;
166 pmmdp->OnMemoryDump(&pmd_2); 167 pmmdp->OnMemoryDump(dump_args, &pmd_2);
167 ASSERT_TRUE(pmd_2.has_process_mmaps()); 168 ASSERT_TRUE(pmd_2.has_process_mmaps());
168 const auto& regions_2 = pmd_2.process_mmaps()->vm_regions(); 169 const auto& regions_2 = pmd_2.process_mmaps()->vm_regions();
169 ASSERT_EQ(1UL, regions_2.size()); 170 ASSERT_EQ(1UL, regions_2.size());
170 EXPECT_EQ(0x7fe7ce79c000UL, regions_2[0].start_address); 171 EXPECT_EQ(0x7fe7ce79c000UL, regions_2[0].start_address);
171 EXPECT_EQ(0x7fe7ce7a8000UL - 0x7fe7ce79c000UL, regions_2[0].size_in_bytes); 172 EXPECT_EQ(0x7fe7ce7a8000UL - 0x7fe7ce79c000UL, regions_2[0].size_in_bytes);
172 EXPECT_EQ(0U, regions_2[0].protection_flags); 173 EXPECT_EQ(0U, regions_2[0].protection_flags);
173 EXPECT_EQ("", regions_2[0].mapped_file); 174 EXPECT_EQ("", regions_2[0].mapped_file);
174 EXPECT_EQ(32 * 1024UL, regions_2[0].byte_stats_proportional_resident); 175 EXPECT_EQ(32 * 1024UL, regions_2[0].byte_stats_proportional_resident);
175 EXPECT_EQ(16 * 1024UL, regions_2[0].byte_stats_shared_clean_resident); 176 EXPECT_EQ(16 * 1024UL, regions_2[0].byte_stats_shared_clean_resident);
176 EXPECT_EQ(12 * 1024UL, regions_2[0].byte_stats_shared_dirty_resident); 177 EXPECT_EQ(12 * 1024UL, regions_2[0].byte_stats_shared_dirty_resident);
177 EXPECT_EQ(8 * 1024UL, regions_2[0].byte_stats_private_clean_resident); 178 EXPECT_EQ(8 * 1024UL, regions_2[0].byte_stats_private_clean_resident);
178 EXPECT_EQ(4 * 1024UL, regions_2[0].byte_stats_private_dirty_resident); 179 EXPECT_EQ(4 * 1024UL, regions_2[0].byte_stats_private_dirty_resident);
179 EXPECT_EQ(0 * 1024UL, regions_2[0].byte_stats_swapped); 180 EXPECT_EQ(0 * 1024UL, regions_2[0].byte_stats_swapped);
180 } 181 }
181 #endif // defined(OS_LINUX) || defined(OS_ANDROID) 182 #endif // defined(OS_LINUX) || defined(OS_ANDROID)
182 183
183 } // namespace trace_event 184 } // namespace trace_event
184 } // namespace base 185 } // namespace base
OLDNEW
« no previous file with comments | « base/trace_event/process_memory_maps_dump_provider.cc ('k') | base/trace_event/process_memory_totals_dump_provider.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698