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

Side by Side Diff: minidump/minidump_system_info_writer_test.cc

Issue 886143004: win: fix various warnings in minidump_system_info_writer_test.cc (Closed) Base URL: https://chromium.googlesource.com/crashpad/crashpad@minidump_test-3
Patch Set: Created 5 years, 10 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
« no previous file with comments | « no previous file | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2014 The Crashpad Authors. All rights reserved. 1 // Copyright 2014 The Crashpad Authors. All rights reserved.
2 // 2 //
3 // Licensed under the Apache License, Version 2.0 (the "License"); 3 // Licensed under the Apache License, Version 2.0 (the "License");
4 // you may not use this file except in compliance with the License. 4 // you may not use this file except in compliance with the License.
5 // You may obtain a copy of the License at 5 // You may obtain a copy of the License at
6 // 6 //
7 // http://www.apache.org/licenses/LICENSE-2.0 7 // http://www.apache.org/licenses/LICENSE-2.0
8 // 8 //
9 // Unless required by applicable law or agreed to in writing, software 9 // Unless required by applicable law or agreed to in writing, software
10 // distributed under the License is distributed on an "AS IS" BASIS, 10 // distributed under the License is distributed on an "AS IS" BASIS,
(...skipping 21 matching lines...) Expand all
32 32
33 namespace crashpad { 33 namespace crashpad {
34 namespace test { 34 namespace test {
35 namespace { 35 namespace {
36 36
37 void GetSystemInfoStream(const std::string& file_contents, 37 void GetSystemInfoStream(const std::string& file_contents,
38 size_t csd_version_length, 38 size_t csd_version_length,
39 const MINIDUMP_SYSTEM_INFO** system_info, 39 const MINIDUMP_SYSTEM_INFO** system_info,
40 const MINIDUMP_STRING** csd_version) { 40 const MINIDUMP_STRING** csd_version) {
41 // The expected number of bytes for the CSD version’s MINIDUMP_STRING::Buffer. 41 // The expected number of bytes for the CSD version’s MINIDUMP_STRING::Buffer.
42 const size_t kCSDVersionBytes = 42 MINIDUMP_STRING tmp = {0}; (void)tmp;
Mark Mentovai 2015/02/05 14:19:07 We should bring ALLOW_UNUSED_LOCAL into mini_chrom
scottmg 2015/02/05 17:01:55 Done.
43 csd_version_length * sizeof(MINIDUMP_STRING::Buffer[0]); 43 const size_t kCSDVersionBytes = csd_version_length * sizeof(tmp.Buffer[0]);
44 const size_t kCSDVersionBytesWithNUL = 44 const size_t kCSDVersionBytesWithNUL =
45 kCSDVersionBytes + sizeof(MINIDUMP_STRING::Buffer[0]); 45 kCSDVersionBytes + sizeof(tmp.Buffer[0]);
46 46
47 const size_t kDirectoryOffset = sizeof(MINIDUMP_HEADER); 47 const size_t kDirectoryOffset = sizeof(MINIDUMP_HEADER);
48 const size_t kSystemInfoStreamOffset = 48 const size_t kSystemInfoStreamOffset =
49 kDirectoryOffset + sizeof(MINIDUMP_DIRECTORY); 49 kDirectoryOffset + sizeof(MINIDUMP_DIRECTORY);
50 const size_t kCSDVersionOffset = 50 const size_t kCSDVersionOffset =
51 kSystemInfoStreamOffset + sizeof(MINIDUMP_SYSTEM_INFO); 51 kSystemInfoStreamOffset + sizeof(MINIDUMP_SYSTEM_INFO);
52 const size_t kFileSize = 52 const size_t kFileSize =
53 kCSDVersionOffset + sizeof(MINIDUMP_STRING) + kCSDVersionBytesWithNUL; 53 kCSDVersionOffset + sizeof(MINIDUMP_STRING) + kCSDVersionBytesWithNUL;
54 54
55 ASSERT_EQ(kFileSize, file_contents.size()); 55 ASSERT_EQ(kFileSize, file_contents.size());
(...skipping 22 matching lines...) Expand all
78 MinidumpFileWriter minidump_file_writer; 78 MinidumpFileWriter minidump_file_writer;
79 auto system_info_writer = make_scoped_ptr(new MinidumpSystemInfoWriter()); 79 auto system_info_writer = make_scoped_ptr(new MinidumpSystemInfoWriter());
80 80
81 system_info_writer->SetCSDVersion(std::string()); 81 system_info_writer->SetCSDVersion(std::string());
82 82
83 minidump_file_writer.AddStream(system_info_writer.Pass()); 83 minidump_file_writer.AddStream(system_info_writer.Pass());
84 84
85 StringFileWriter file_writer; 85 StringFileWriter file_writer;
86 ASSERT_TRUE(minidump_file_writer.WriteEverything(&file_writer)); 86 ASSERT_TRUE(minidump_file_writer.WriteEverything(&file_writer));
87 87
88 const MINIDUMP_SYSTEM_INFO* system_info; 88 const MINIDUMP_SYSTEM_INFO* system_info = nullptr;
89 const MINIDUMP_STRING* csd_version; 89 const MINIDUMP_STRING* csd_version = nullptr;
90 90
91 ASSERT_NO_FATAL_FAILURE( 91 ASSERT_NO_FATAL_FAILURE(
92 GetSystemInfoStream(file_writer.string(), 0, &system_info, &csd_version)); 92 GetSystemInfoStream(file_writer.string(), 0, &system_info, &csd_version));
93 93
94 EXPECT_EQ(kMinidumpCPUArchitectureUnknown, 94 EXPECT_EQ(kMinidumpCPUArchitectureUnknown,
95 system_info->ProcessorArchitecture); 95 system_info->ProcessorArchitecture);
96 EXPECT_EQ(0u, system_info->ProcessorLevel); 96 EXPECT_EQ(0u, system_info->ProcessorLevel);
97 EXPECT_EQ(0u, system_info->ProcessorRevision); 97 EXPECT_EQ(0u, system_info->ProcessorRevision);
98 EXPECT_EQ(0u, system_info->NumberOfProcessors); 98 EXPECT_EQ(0u, system_info->NumberOfProcessors);
99 EXPECT_EQ(0u, system_info->ProductType); 99 EXPECT_EQ(0u, system_info->ProductType);
(...skipping 49 matching lines...) Expand 10 before | Expand all | Expand 10 after
149 system_info_writer->SetSuiteMask(kSuiteMask); 149 system_info_writer->SetSuiteMask(kSuiteMask);
150 system_info_writer->SetCPUX86VendorString(kCPUVendor); 150 system_info_writer->SetCPUX86VendorString(kCPUVendor);
151 system_info_writer->SetCPUX86VersionAndFeatures(kCPUVersion, kCPUFeatures); 151 system_info_writer->SetCPUX86VersionAndFeatures(kCPUVersion, kCPUFeatures);
152 system_info_writer->SetCPUX86AMDExtendedFeatures(kAMDFeatures); 152 system_info_writer->SetCPUX86AMDExtendedFeatures(kAMDFeatures);
153 153
154 minidump_file_writer.AddStream(system_info_writer.Pass()); 154 minidump_file_writer.AddStream(system_info_writer.Pass());
155 155
156 StringFileWriter file_writer; 156 StringFileWriter file_writer;
157 ASSERT_TRUE(minidump_file_writer.WriteEverything(&file_writer)); 157 ASSERT_TRUE(minidump_file_writer.WriteEverything(&file_writer));
158 158
159 const MINIDUMP_SYSTEM_INFO* system_info; 159 const MINIDUMP_SYSTEM_INFO* system_info = nullptr;
160 const MINIDUMP_STRING* csd_version; 160 const MINIDUMP_STRING* csd_version = nullptr;
161 161
162 ASSERT_NO_FATAL_FAILURE(GetSystemInfoStream( 162 ASSERT_NO_FATAL_FAILURE(GetSystemInfoStream(
163 file_writer.string(), strlen(kCSDVersion), &system_info, &csd_version)); 163 file_writer.string(), strlen(kCSDVersion), &system_info, &csd_version));
164 164
165 EXPECT_EQ(kCPUArchitecture, system_info->ProcessorArchitecture); 165 EXPECT_EQ(kCPUArchitecture, system_info->ProcessorArchitecture);
166 EXPECT_EQ(kCPULevel, system_info->ProcessorLevel); 166 EXPECT_EQ(kCPULevel, system_info->ProcessorLevel);
167 EXPECT_EQ(kCPURevision, system_info->ProcessorRevision); 167 EXPECT_EQ(kCPURevision, system_info->ProcessorRevision);
168 EXPECT_EQ(kCPUCount, system_info->NumberOfProcessors); 168 EXPECT_EQ(kCPUCount, system_info->NumberOfProcessors);
169 EXPECT_EQ(kOSType, system_info->ProductType); 169 EXPECT_EQ(kOSType, system_info->ProductType);
170 EXPECT_EQ(kOSVersionMajor, system_info->MajorVersion); 170 EXPECT_EQ(kOSVersionMajor, system_info->MajorVersion);
(...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after
209 system_info_writer->SetOSVersion( 209 system_info_writer->SetOSVersion(
210 kOSVersionMajor, kOSVersionMinor, kOSVersionBuild); 210 kOSVersionMajor, kOSVersionMinor, kOSVersionBuild);
211 system_info_writer->SetCSDVersion(kCSDVersion); 211 system_info_writer->SetCSDVersion(kCSDVersion);
212 system_info_writer->SetCPUOtherFeatures(kCPUFeatures[0], kCPUFeatures[1]); 212 system_info_writer->SetCPUOtherFeatures(kCPUFeatures[0], kCPUFeatures[1]);
213 213
214 minidump_file_writer.AddStream(system_info_writer.Pass()); 214 minidump_file_writer.AddStream(system_info_writer.Pass());
215 215
216 StringFileWriter file_writer; 216 StringFileWriter file_writer;
217 ASSERT_TRUE(minidump_file_writer.WriteEverything(&file_writer)); 217 ASSERT_TRUE(minidump_file_writer.WriteEverything(&file_writer));
218 218
219 const MINIDUMP_SYSTEM_INFO* system_info; 219 const MINIDUMP_SYSTEM_INFO* system_info = nullptr;
220 const MINIDUMP_STRING* csd_version; 220 const MINIDUMP_STRING* csd_version;
221 221
222 ASSERT_NO_FATAL_FAILURE(GetSystemInfoStream( 222 ASSERT_NO_FATAL_FAILURE(GetSystemInfoStream(
223 file_writer.string(), strlen(kCSDVersion), &system_info, &csd_version)); 223 file_writer.string(), strlen(kCSDVersion), &system_info, &csd_version));
224 224
225 EXPECT_EQ(kCPUArchitecture, system_info->ProcessorArchitecture); 225 EXPECT_EQ(kCPUArchitecture, system_info->ProcessorArchitecture);
226 EXPECT_EQ(kCPULevel, system_info->ProcessorLevel); 226 EXPECT_EQ(kCPULevel, system_info->ProcessorLevel);
227 EXPECT_EQ(kCPURevision, system_info->ProcessorRevision); 227 EXPECT_EQ(kCPURevision, system_info->ProcessorRevision);
228 EXPECT_EQ(kCPUCount, system_info->NumberOfProcessors); 228 EXPECT_EQ(kCPUCount, system_info->NumberOfProcessors);
229 EXPECT_EQ(kOSType, system_info->ProductType); 229 EXPECT_EQ(kOSType, system_info->ProductType);
(...skipping 21 matching lines...) Expand all
251 system_info_writer->SetCPUArchitecture(kCPUArchitecture); 251 system_info_writer->SetCPUArchitecture(kCPUArchitecture);
252 system_info_writer->SetCPUX86Vendor( 252 system_info_writer->SetCPUX86Vendor(
253 kCPUVendor[0], kCPUVendor[1], kCPUVendor[2]); 253 kCPUVendor[0], kCPUVendor[1], kCPUVendor[2]);
254 system_info_writer->SetCSDVersion(std::string()); 254 system_info_writer->SetCSDVersion(std::string());
255 255
256 minidump_file_writer.AddStream(system_info_writer.Pass()); 256 minidump_file_writer.AddStream(system_info_writer.Pass());
257 257
258 StringFileWriter file_writer; 258 StringFileWriter file_writer;
259 ASSERT_TRUE(minidump_file_writer.WriteEverything(&file_writer)); 259 ASSERT_TRUE(minidump_file_writer.WriteEverything(&file_writer));
260 260
261 const MINIDUMP_SYSTEM_INFO* system_info; 261 const MINIDUMP_SYSTEM_INFO* system_info = nullptr;
262 const MINIDUMP_STRING* csd_version; 262 const MINIDUMP_STRING* csd_version;
263 263
264 ASSERT_NO_FATAL_FAILURE( 264 ASSERT_NO_FATAL_FAILURE(
265 GetSystemInfoStream(file_writer.string(), 0, &system_info, &csd_version)); 265 GetSystemInfoStream(file_writer.string(), 0, &system_info, &csd_version));
266 266
267 EXPECT_EQ(kCPUArchitecture, system_info->ProcessorArchitecture); 267 EXPECT_EQ(kCPUArchitecture, system_info->ProcessorArchitecture);
268 EXPECT_EQ(0u, system_info->ProcessorLevel); 268 EXPECT_EQ(0u, system_info->ProcessorLevel);
269 EXPECT_EQ(kCPUVendor[0], system_info->Cpu.X86CpuInfo.VendorId[0]); 269 EXPECT_EQ(kCPUVendor[0], system_info->Cpu.X86CpuInfo.VendorId[0]);
270 EXPECT_EQ(kCPUVendor[1], system_info->Cpu.X86CpuInfo.VendorId[1]); 270 EXPECT_EQ(kCPUVendor[1], system_info->Cpu.X86CpuInfo.VendorId[1]);
271 EXPECT_EQ(kCPUVendor[2], system_info->Cpu.X86CpuInfo.VendorId[2]); 271 EXPECT_EQ(kCPUVendor[2], system_info->Cpu.X86CpuInfo.VendorId[2]);
272 EXPECT_EQ(0u, system_info->Cpu.X86CpuInfo.VersionInformation); 272 EXPECT_EQ(0u, system_info->Cpu.X86CpuInfo.VersionInformation);
273 } 273 }
274 274
275 TEST(MinidumpSystemInfoWriter, InitializeFromSnapshot_X86) { 275 TEST(MinidumpSystemInfoWriter, InitializeFromSnapshot_X86) {
276 MINIDUMP_SYSTEM_INFO expect_system_info = {}; 276 MINIDUMP_SYSTEM_INFO expect_system_info = {};
277 277
278 const uint16_t kCPUFamily = 6; 278 const uint16_t kCPUFamily = 6;
279 const uint8_t kCPUModel = 70; 279 const uint8_t kCPUModel = 70;
280 const uint8_t kCPUStepping = 1; 280 const uint8_t kCPUStepping = 1;
281 281
282 const uint8_t kCPUBasicFamily = 282 const uint8_t kCPUBasicFamily =
283 std::min(kCPUFamily, implicit_cast<uint16_t>(15)); 283 static_cast<uint8_t>(std::min(kCPUFamily, static_cast<uint16_t>(15)));
284 const uint8_t kCPUExtendedFamily = kCPUFamily - kCPUBasicFamily; 284 const uint8_t kCPUExtendedFamily = kCPUFamily - kCPUBasicFamily;
285 285
286 // These checks ensure that even if the constants above change, they represent 286 // These checks ensure that even if the constants above change, they represent
287 // something that can legitimately be encoded in the form used by cpuid 1 eax. 287 // something that can legitimately be encoded in the form used by cpuid 1 eax.
288 EXPECT_LE(kCPUFamily, 270); 288 EXPECT_LE(kCPUFamily, 270);
289 EXPECT_LE(kCPUStepping, 15); 289 EXPECT_LE(kCPUStepping, 15);
290 EXPECT_TRUE(kCPUBasicFamily == 6 || kCPUBasicFamily == 15 || kCPUModel <= 15); 290 EXPECT_TRUE(kCPUBasicFamily == 6 || kCPUBasicFamily == 15 || kCPUModel <= 15);
291 291
292 const uint8_t kCPUBasicModel = kCPUModel & 0xf; 292 const uint8_t kCPUBasicModel = kCPUModel & 0xf;
293 const uint8_t kCPUExtendedModel = kCPUModel >> 4; 293 const uint8_t kCPUExtendedModel = kCPUModel >> 4;
(...skipping 37 matching lines...) Expand 10 before | Expand all | Expand 10 after
331 331
332 auto system_info_writer = make_scoped_ptr(new MinidumpSystemInfoWriter()); 332 auto system_info_writer = make_scoped_ptr(new MinidumpSystemInfoWriter());
333 system_info_writer->InitializeFromSnapshot(&system_snapshot); 333 system_info_writer->InitializeFromSnapshot(&system_snapshot);
334 334
335 MinidumpFileWriter minidump_file_writer; 335 MinidumpFileWriter minidump_file_writer;
336 minidump_file_writer.AddStream(system_info_writer.Pass()); 336 minidump_file_writer.AddStream(system_info_writer.Pass());
337 337
338 StringFileWriter file_writer; 338 StringFileWriter file_writer;
339 ASSERT_TRUE(minidump_file_writer.WriteEverything(&file_writer)); 339 ASSERT_TRUE(minidump_file_writer.WriteEverything(&file_writer));
340 340
341 const MINIDUMP_SYSTEM_INFO* system_info; 341 const MINIDUMP_SYSTEM_INFO* system_info = nullptr;
342 const MINIDUMP_STRING* csd_version; 342 const MINIDUMP_STRING* csd_version = nullptr;
343 ASSERT_NO_FATAL_FAILURE(GetSystemInfoStream(file_writer.string(), 343 ASSERT_NO_FATAL_FAILURE(GetSystemInfoStream(file_writer.string(),
344 strlen(kOSVersionBuild), 344 strlen(kOSVersionBuild),
345 &system_info, 345 &system_info,
346 &csd_version)); 346 &csd_version));
347 347
348 EXPECT_EQ(expect_system_info.ProcessorArchitecture, 348 EXPECT_EQ(expect_system_info.ProcessorArchitecture,
349 system_info->ProcessorArchitecture); 349 system_info->ProcessorArchitecture);
350 EXPECT_EQ(expect_system_info.ProcessorLevel, system_info->ProcessorLevel); 350 EXPECT_EQ(expect_system_info.ProcessorLevel, system_info->ProcessorLevel);
351 EXPECT_EQ(expect_system_info.ProcessorRevision, 351 EXPECT_EQ(expect_system_info.ProcessorRevision,
352 system_info->ProcessorRevision); 352 system_info->ProcessorRevision);
(...skipping 73 matching lines...) Expand 10 before | Expand all | Expand 10 after
426 426
427 auto system_info_writer = make_scoped_ptr(new MinidumpSystemInfoWriter()); 427 auto system_info_writer = make_scoped_ptr(new MinidumpSystemInfoWriter());
428 system_info_writer->InitializeFromSnapshot(&system_snapshot); 428 system_info_writer->InitializeFromSnapshot(&system_snapshot);
429 429
430 MinidumpFileWriter minidump_file_writer; 430 MinidumpFileWriter minidump_file_writer;
431 minidump_file_writer.AddStream(system_info_writer.Pass()); 431 minidump_file_writer.AddStream(system_info_writer.Pass());
432 432
433 StringFileWriter file_writer; 433 StringFileWriter file_writer;
434 ASSERT_TRUE(minidump_file_writer.WriteEverything(&file_writer)); 434 ASSERT_TRUE(minidump_file_writer.WriteEverything(&file_writer));
435 435
436 const MINIDUMP_SYSTEM_INFO* system_info; 436 const MINIDUMP_SYSTEM_INFO* system_info = nullptr;
437 const MINIDUMP_STRING* csd_version; 437 const MINIDUMP_STRING* csd_version = nullptr;
438 ASSERT_NO_FATAL_FAILURE(GetSystemInfoStream(file_writer.string(), 438 ASSERT_NO_FATAL_FAILURE(GetSystemInfoStream(file_writer.string(),
439 strlen(kOSVersionBuild), 439 strlen(kOSVersionBuild),
440 &system_info, 440 &system_info,
441 &csd_version)); 441 &csd_version));
442 442
443 EXPECT_EQ(expect_system_info.ProcessorArchitecture, 443 EXPECT_EQ(expect_system_info.ProcessorArchitecture,
444 system_info->ProcessorArchitecture); 444 system_info->ProcessorArchitecture);
445 EXPECT_EQ(expect_system_info.ProcessorLevel, system_info->ProcessorLevel); 445 EXPECT_EQ(expect_system_info.ProcessorLevel, system_info->ProcessorLevel);
446 EXPECT_EQ(expect_system_info.ProcessorRevision, 446 EXPECT_EQ(expect_system_info.ProcessorRevision,
447 system_info->ProcessorRevision); 447 system_info->ProcessorRevision);
(...skipping 21 matching lines...) Expand all
469 minidump_file_writer.AddStream(system_info_writer.Pass()); 469 minidump_file_writer.AddStream(system_info_writer.Pass());
470 470
471 StringFileWriter file_writer; 471 StringFileWriter file_writer;
472 ASSERT_DEATH(minidump_file_writer.WriteEverything(&file_writer), 472 ASSERT_DEATH(minidump_file_writer.WriteEverything(&file_writer),
473 "csd_version_"); 473 "csd_version_");
474 } 474 }
475 475
476 } // namespace 476 } // namespace
477 } // namespace test 477 } // namespace test
478 } // namespace crashpad 478 } // namespace crashpad
OLDNEW
« no previous file with comments | « no previous file | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698