Index: minidump/minidump_module_crashpad_info_writer_test.cc |
diff --git a/minidump/minidump_module_crashpad_info_writer_test.cc b/minidump/minidump_module_crashpad_info_writer_test.cc |
index 712edfba301b0885d1404aa409958a9cf9ddc885..b354a73b16bcd48bd14ebba843e4b8ed8bbfbffb 100644 |
--- a/minidump/minidump_module_crashpad_info_writer_test.cc |
+++ b/minidump/minidump_module_crashpad_info_writer_test.cc |
@@ -22,6 +22,7 @@ |
#include "minidump/test/minidump_file_writer_test_util.h" |
#include "minidump/test/minidump_string_writer_test_util.h" |
#include "minidump/test/minidump_writable_test_util.h" |
+#include "snapshot/test/test_module_snapshot.h" |
#include "util/file/string_file_writer.h" |
namespace crashpad { |
@@ -61,6 +62,7 @@ TEST(MinidumpModuleCrashpadInfoWriter, EmptyModule) { |
MinidumpModuleCrashpadInfoListWriter module_list_writer; |
auto module_writer = |
make_scoped_ptr(new MinidumpModuleCrashpadInfoWriter()); |
+ EXPECT_FALSE(module_writer->IsUseful()); |
module_list_writer.AddModule(module_writer.Pass()); |
EXPECT_TRUE(module_list_writer.WriteEverything(&file_writer)); |
@@ -106,6 +108,7 @@ TEST(MinidumpModuleCrashpadInfoWriter, FullModule) { |
simple_string_dictionary_writer->AddEntry( |
simple_string_dictionary_entry_writer.Pass()); |
module_writer->SetSimpleAnnotations(simple_string_dictionary_writer.Pass()); |
+ EXPECT_TRUE(module_writer->IsUseful()); |
module_list_writer.AddModule(module_writer.Pass()); |
EXPECT_TRUE(module_list_writer.WriteEverything(&file_writer)); |
@@ -175,11 +178,13 @@ TEST(MinidumpModuleCrashpadInfoWriter, ThreeModules) { |
simple_string_dictionary_entry_writer_0.Pass()); |
module_writer_0->SetSimpleAnnotations( |
simple_string_dictionary_writer_0.Pass()); |
+ EXPECT_TRUE(module_writer_0->IsUseful()); |
module_list_writer.AddModule(module_writer_0.Pass()); |
auto module_writer_1 = |
make_scoped_ptr(new MinidumpModuleCrashpadInfoWriter()); |
module_writer_1->SetMinidumpModuleListIndex(kMinidumpModuleListIndex1); |
+ EXPECT_FALSE(module_writer_1->IsUseful()); |
module_list_writer.AddModule(module_writer_1.Pass()); |
auto module_writer_2 = |
@@ -199,6 +204,7 @@ TEST(MinidumpModuleCrashpadInfoWriter, ThreeModules) { |
simple_string_dictionary_entry_writer_2b.Pass()); |
module_writer_2->SetSimpleAnnotations( |
simple_string_dictionary_writer_2.Pass()); |
+ EXPECT_TRUE(module_writer_2->IsUseful()); |
module_list_writer.AddModule(module_writer_2.Pass()); |
EXPECT_TRUE(module_list_writer.WriteEverything(&file_writer)); |
@@ -271,6 +277,95 @@ TEST(MinidumpModuleCrashpadInfoWriter, ThreeModules) { |
file_writer.string(), simple_annotations_2->entries[1].value)); |
} |
+TEST(MinidumpModuleCrashpadInfoWriter, InitializeFromSnapshot) { |
+ const char kKey0A[] = "k"; |
+ const char kValue0A[] = "value"; |
+ const char kKey0B[] = "hudson"; |
+ const char kValue0B[] = "estuary"; |
+ const char kKey2[] = "k"; |
+ const char kValue2[] = "different_value"; |
+ |
+ std::vector<const ModuleSnapshot*> module_snapshots; |
+ |
+ TestModuleSnapshot module_snapshot_0; |
+ std::map<std::string, std::string> annotations_simple_map_0; |
+ annotations_simple_map_0[kKey0A] = kValue0A; |
+ annotations_simple_map_0[kKey0B] = kValue0B; |
+ module_snapshot_0.SetAnnotationsSimpleMap(annotations_simple_map_0); |
+ module_snapshots.push_back(&module_snapshot_0); |
+ |
+ // module_snapshot_1 is not expected to be written because it would not carry |
+ // any MinidumpModuleCrashpadInfo data. |
+ TestModuleSnapshot module_snapshot_1; |
+ module_snapshots.push_back(&module_snapshot_1); |
+ |
+ TestModuleSnapshot module_snapshot_2; |
+ std::map<std::string, std::string> annotations_simple_map_2; |
+ annotations_simple_map_2[kKey2] = kValue2; |
+ module_snapshot_2.SetAnnotationsSimpleMap(annotations_simple_map_2); |
+ module_snapshots.push_back(&module_snapshot_2); |
+ |
+ MinidumpModuleCrashpadInfoListWriter module_list_writer; |
+ module_list_writer.InitializeFromSnapshot(module_snapshots); |
+ |
+ StringFileWriter file_writer; |
+ ASSERT_TRUE(module_list_writer.WriteEverything(&file_writer)); |
+ |
+ const MinidumpModuleCrashpadInfoList* module_list = |
+ MinidumpModuleCrashpadInfoListAtStart(file_writer.string(), 2); |
+ ASSERT_TRUE(module_list); |
+ |
+ ASSERT_EQ(2u, module_list->count); |
+ |
+ const MinidumpModuleCrashpadInfo* module_0 = |
+ MinidumpWritableAtLocationDescriptor<MinidumpModuleCrashpadInfo>( |
+ file_writer.string(), module_list->modules[0]); |
+ ASSERT_TRUE(module_0); |
+ |
+ EXPECT_EQ(MinidumpModuleCrashpadInfo::kVersion, module_0->version); |
+ EXPECT_EQ(0u, module_0->minidump_module_list_index); |
+ |
+ const MinidumpSimpleStringDictionary* simple_annotations_0 = |
+ MinidumpWritableAtLocationDescriptor<MinidumpSimpleStringDictionary>( |
+ file_writer.string(), module_0->simple_annotations); |
+ ASSERT_TRUE(simple_annotations_0); |
+ |
+ ASSERT_EQ(annotations_simple_map_0.size(), simple_annotations_0->count); |
+ EXPECT_EQ(kKey0B, |
+ MinidumpUTF8StringAtRVAAsString( |
+ file_writer.string(), simple_annotations_0->entries[0].key)); |
+ EXPECT_EQ(kValue0B, |
+ MinidumpUTF8StringAtRVAAsString( |
+ file_writer.string(), simple_annotations_0->entries[0].value)); |
+ EXPECT_EQ(kKey0A, |
+ MinidumpUTF8StringAtRVAAsString( |
+ file_writer.string(), simple_annotations_0->entries[1].key)); |
+ EXPECT_EQ(kValue0A, |
+ MinidumpUTF8StringAtRVAAsString( |
+ file_writer.string(), simple_annotations_0->entries[1].value)); |
+ |
+ const MinidumpModuleCrashpadInfo* module_2 = |
+ MinidumpWritableAtLocationDescriptor<MinidumpModuleCrashpadInfo>( |
+ file_writer.string(), module_list->modules[1]); |
+ ASSERT_TRUE(module_2); |
+ |
+ EXPECT_EQ(MinidumpModuleCrashpadInfo::kVersion, module_2->version); |
+ EXPECT_EQ(2u, module_2->minidump_module_list_index); |
+ |
+ const MinidumpSimpleStringDictionary* simple_annotations_2 = |
+ MinidumpWritableAtLocationDescriptor<MinidumpSimpleStringDictionary>( |
+ file_writer.string(), module_2->simple_annotations); |
+ ASSERT_TRUE(simple_annotations_2); |
+ |
+ ASSERT_EQ(annotations_simple_map_2.size(), simple_annotations_2->count); |
+ EXPECT_EQ(kKey2, |
+ MinidumpUTF8StringAtRVAAsString( |
+ file_writer.string(), simple_annotations_2->entries[0].key)); |
+ EXPECT_EQ(kValue2, |
+ MinidumpUTF8StringAtRVAAsString( |
+ file_writer.string(), simple_annotations_2->entries[0].value)); |
+} |
+ |
} // namespace |
} // namespace test |
} // namespace crashpad |