OLD | NEW |
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 Loading... |
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 Loading... |
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 |
OLD | NEW |