Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2015 The Crashpad Authors. All rights reserved. | 1 // Copyright 2015 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, |
| 11 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 11 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| 12 // See the License for the specific language governing permissions and | 12 // See the License for the specific language governing permissions and |
| 13 // limitations under the License. | 13 // limitations under the License. |
| 14 | 14 |
| 15 #include "minidump/minidump_handle_writer.h" | 15 #include "minidump/minidump_handle_writer.h" |
| 16 | 16 |
| 17 #include <string> | 17 #include <string> |
| 18 | 18 |
| 19 #include "base/strings/utf_string_conversions.h" | |
| 19 #include "gtest/gtest.h" | 20 #include "gtest/gtest.h" |
| 20 #include "minidump/minidump_file_writer.h" | 21 #include "minidump/minidump_file_writer.h" |
| 21 #include "minidump/test/minidump_file_writer_test_util.h" | 22 #include "minidump/test/minidump_file_writer_test_util.h" |
| 22 #include "minidump/test/minidump_string_writer_test_util.h" | 23 #include "minidump/test/minidump_string_writer_test_util.h" |
| 23 #include "minidump/test/minidump_writable_test_util.h" | 24 #include "minidump/test/minidump_writable_test_util.h" |
| 24 #include "util/file/string_file.h" | 25 #include "util/file/string_file.h" |
| 25 | 26 |
| 26 namespace crashpad { | 27 namespace crashpad { |
| 27 namespace test { | 28 namespace test { |
| 28 namespace { | 29 namespace { |
| (...skipping 42 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 71 | 72 |
| 72 EXPECT_EQ(0u, handle_data_stream->NumberOfDescriptors); | 73 EXPECT_EQ(0u, handle_data_stream->NumberOfDescriptors); |
| 73 } | 74 } |
| 74 | 75 |
| 75 TEST(MinidumpHandleDataWriter, OneHandle) { | 76 TEST(MinidumpHandleDataWriter, OneHandle) { |
| 76 MinidumpFileWriter minidump_file_writer; | 77 MinidumpFileWriter minidump_file_writer; |
| 77 auto handle_data_writer = make_scoped_ptr(new MinidumpHandleDataWriter()); | 78 auto handle_data_writer = make_scoped_ptr(new MinidumpHandleDataWriter()); |
| 78 | 79 |
| 79 HandleSnapshot handle_snapshot; | 80 HandleSnapshot handle_snapshot; |
| 80 handle_snapshot.handle = 0x1234; | 81 handle_snapshot.handle = 0x1234; |
| 81 handle_snapshot.type_name = L"Something"; | 82 handle_snapshot.type_name = "Something"; |
|
Mark Mentovai
2015/10/21 18:31:28
It looks like this was the only offending use. An
scottmg
2015/10/21 18:35:44
Yeah, that's what I tried at first, but the SetUTF
| |
| 82 handle_snapshot.attributes = 0x12345678; | 83 handle_snapshot.attributes = 0x12345678; |
| 83 handle_snapshot.granted_access = 0x9abcdef0; | 84 handle_snapshot.granted_access = 0x9abcdef0; |
| 84 handle_snapshot.pointer_count = 4567; | 85 handle_snapshot.pointer_count = 4567; |
| 85 handle_snapshot.handle_count = 9876; | 86 handle_snapshot.handle_count = 9876; |
| 86 | 87 |
| 87 std::vector<HandleSnapshot> snapshot; | 88 std::vector<HandleSnapshot> snapshot; |
| 88 snapshot.push_back(handle_snapshot); | 89 snapshot.push_back(handle_snapshot); |
| 89 | 90 |
| 90 handle_data_writer->InitializeFromSnapshot(snapshot); | 91 handle_data_writer->InitializeFromSnapshot(snapshot); |
| 91 | 92 |
| 92 minidump_file_writer.AddStream(handle_data_writer.Pass()); | 93 minidump_file_writer.AddStream(handle_data_writer.Pass()); |
| 93 | 94 |
| 94 StringFile string_file; | 95 StringFile string_file; |
| 95 ASSERT_TRUE(minidump_file_writer.WriteEverything(&string_file)); | 96 ASSERT_TRUE(minidump_file_writer.WriteEverything(&string_file)); |
| 96 | 97 |
| 97 const size_t kTypeNameStringDataLength = | 98 const size_t kTypeNameStringDataLength = |
| 98 (handle_snapshot.type_name.size() + 1) * | 99 (handle_snapshot.type_name.size() + 1) * sizeof(base::char16); |
| 99 sizeof(handle_snapshot.type_name[0]); | |
| 100 ASSERT_EQ(sizeof(MINIDUMP_HEADER) + sizeof(MINIDUMP_DIRECTORY) + | 100 ASSERT_EQ(sizeof(MINIDUMP_HEADER) + sizeof(MINIDUMP_DIRECTORY) + |
| 101 sizeof(MINIDUMP_HANDLE_DATA_STREAM) + | 101 sizeof(MINIDUMP_HANDLE_DATA_STREAM) + |
| 102 sizeof(MINIDUMP_HANDLE_DESCRIPTOR) + sizeof(MINIDUMP_STRING) + | 102 sizeof(MINIDUMP_HANDLE_DESCRIPTOR) + sizeof(MINIDUMP_STRING) + |
| 103 kTypeNameStringDataLength, | 103 kTypeNameStringDataLength, |
| 104 string_file.string().size()); | 104 string_file.string().size()); |
| 105 | 105 |
| 106 const MINIDUMP_HANDLE_DATA_STREAM* handle_data_stream = nullptr; | 106 const MINIDUMP_HANDLE_DATA_STREAM* handle_data_stream = nullptr; |
| 107 ASSERT_NO_FATAL_FAILURE( | 107 ASSERT_NO_FATAL_FAILURE( |
| 108 GetHandleDataStream(string_file.string(), &handle_data_stream)); | 108 GetHandleDataStream(string_file.string(), &handle_data_stream)); |
| 109 | 109 |
| 110 EXPECT_EQ(1u, handle_data_stream->NumberOfDescriptors); | 110 EXPECT_EQ(1u, handle_data_stream->NumberOfDescriptors); |
| 111 const MINIDUMP_HANDLE_DESCRIPTOR* handle_descriptor = | 111 const MINIDUMP_HANDLE_DESCRIPTOR* handle_descriptor = |
| 112 reinterpret_cast<const MINIDUMP_HANDLE_DESCRIPTOR*>( | 112 reinterpret_cast<const MINIDUMP_HANDLE_DESCRIPTOR*>( |
| 113 &handle_data_stream[1]); | 113 &handle_data_stream[1]); |
| 114 EXPECT_EQ(handle_snapshot.handle, handle_descriptor->Handle); | 114 EXPECT_EQ(handle_snapshot.handle, handle_descriptor->Handle); |
| 115 EXPECT_EQ(handle_snapshot.type_name, | 115 EXPECT_EQ(handle_snapshot.type_name, |
| 116 MinidumpStringAtRVAAsString(string_file.string(), | 116 base::UTF16ToUTF8(MinidumpStringAtRVAAsString( |
| 117 handle_descriptor->TypeNameRva)); | 117 string_file.string(), handle_descriptor->TypeNameRva))); |
| 118 EXPECT_EQ(0u, handle_descriptor->ObjectNameRva); | 118 EXPECT_EQ(0u, handle_descriptor->ObjectNameRva); |
| 119 EXPECT_EQ(handle_snapshot.attributes, handle_descriptor->Attributes); | 119 EXPECT_EQ(handle_snapshot.attributes, handle_descriptor->Attributes); |
| 120 EXPECT_EQ(handle_snapshot.granted_access, handle_descriptor->GrantedAccess); | 120 EXPECT_EQ(handle_snapshot.granted_access, handle_descriptor->GrantedAccess); |
| 121 EXPECT_EQ(handle_snapshot.handle_count, handle_descriptor->HandleCount); | 121 EXPECT_EQ(handle_snapshot.handle_count, handle_descriptor->HandleCount); |
| 122 EXPECT_EQ(handle_snapshot.pointer_count, handle_descriptor->PointerCount); | 122 EXPECT_EQ(handle_snapshot.pointer_count, handle_descriptor->PointerCount); |
| 123 } | 123 } |
| 124 | 124 |
| 125 } // namespace | 125 } // namespace |
| 126 } // namespace test | 126 } // namespace test |
| 127 } // namespace crashpad | 127 } // namespace crashpad |
| OLD | NEW |