Index: base/pickle_unittest.cc |
diff --git a/base/pickle_unittest.cc b/base/pickle_unittest.cc |
index 07be5e36ff83b0e3de2d7512db98f08fabe90d10..8cb1d2a170c23e52e01d4798006338dc74ae3153 100644 |
--- a/base/pickle_unittest.cc |
+++ b/base/pickle_unittest.cc |
@@ -1,4 +1,4 @@ |
-// Copyright (c) 2011 The Chromium Authors. All rights reserved. |
+// Copyright (c) 2012 The Chromium Authors. All rights reserved. |
// Use of this source code is governed by a BSD-style license that can be |
// found in the LICENSE file. |
@@ -23,7 +23,7 @@ const uint16 testuint16 = 32123; |
// checks that the result |
void VerifyResult(const Pickle& pickle) { |
- void* iter = NULL; |
+ PickleIterator iter(pickle); |
int outint; |
EXPECT_TRUE(pickle.ReadInt(&iter, &outint)); |
@@ -100,7 +100,7 @@ TEST(PickleTest, SmallBuffer) { |
// We should not touch the buffer. |
Pickle pickle(buffer.get(), 1); |
- void* iter = NULL; |
+ PickleIterator iter(pickle); |
int data; |
EXPECT_FALSE(pickle.ReadInt(&iter, &data)); |
} |
@@ -111,7 +111,7 @@ TEST(PickleTest, BigSize) { |
Pickle pickle(reinterpret_cast<char*>(buffer), sizeof(buffer)); |
- void* iter = NULL; |
+ PickleIterator iter(pickle); |
int data; |
EXPECT_FALSE(pickle.ReadInt(&iter, &data)); |
} |
@@ -121,7 +121,7 @@ TEST(PickleTest, UnalignedSize) { |
Pickle pickle(reinterpret_cast<char*>(buffer), sizeof(buffer)); |
- void* iter = NULL; |
+ PickleIterator iter(pickle); |
int data; |
EXPECT_FALSE(pickle.ReadInt(&iter, &data)); |
} |
@@ -130,7 +130,7 @@ TEST(PickleTest, ZeroLenStr) { |
Pickle pickle; |
EXPECT_TRUE(pickle.WriteString("")); |
- void* iter = NULL; |
+ PickleIterator iter(pickle); |
std::string outstr; |
EXPECT_TRUE(pickle.ReadString(&iter, &outstr)); |
EXPECT_EQ("", outstr); |
@@ -140,7 +140,7 @@ TEST(PickleTest, ZeroLenWStr) { |
Pickle pickle; |
EXPECT_TRUE(pickle.WriteWString(L"")); |
- void* iter = NULL; |
+ PickleIterator iter(pickle); |
std::string outstr; |
EXPECT_TRUE(pickle.ReadString(&iter, &outstr)); |
EXPECT_EQ("", outstr); |
@@ -150,7 +150,7 @@ TEST(PickleTest, BadLenStr) { |
Pickle pickle; |
EXPECT_TRUE(pickle.WriteInt(-2)); |
- void* iter = NULL; |
+ PickleIterator iter(pickle); |
std::string outstr; |
EXPECT_FALSE(pickle.ReadString(&iter, &outstr)); |
} |
@@ -159,7 +159,7 @@ TEST(PickleTest, BadLenWStr) { |
Pickle pickle; |
EXPECT_TRUE(pickle.WriteInt(-1)); |
- void* iter = NULL; |
+ PickleIterator iter(pickle); |
std::wstring woutstr; |
EXPECT_FALSE(pickle.ReadWString(&iter, &woutstr)); |
} |
@@ -188,19 +188,23 @@ TEST(PickleTest, FindNextWithIncompleteHeader) { |
EXPECT_TRUE(NULL == Pickle::FindNext(header_size, start, end)); |
} |
-TEST(PickleTest, IteratorHasRoom) { |
+TEST(PickleTest, GetReadPointerAndAdvance) { |
Pickle pickle; |
+ |
+ PickleIterator iter(pickle); |
+ EXPECT_FALSE(iter.GetReadPointerAndAdvance(1)); |
+ |
EXPECT_TRUE(pickle.WriteInt(1)); |
EXPECT_TRUE(pickle.WriteInt(2)); |
- |
- const void* iter = 0; |
- EXPECT_FALSE(pickle.IteratorHasRoomFor(iter, 1)); |
- iter = pickle.payload(); |
- EXPECT_TRUE(pickle.IteratorHasRoomFor(iter, 0)); |
- EXPECT_TRUE(pickle.IteratorHasRoomFor(iter, 1)); |
- EXPECT_FALSE(pickle.IteratorHasRoomFor(iter, -1)); |
- EXPECT_TRUE(pickle.IteratorHasRoomFor(iter, sizeof(int) * 2)); |
- EXPECT_FALSE(pickle.IteratorHasRoomFor(iter, (sizeof(int) * 2) + 1)); |
+ int bytes = sizeof(int) * 2; |
+ |
+ EXPECT_TRUE(PickleIterator(pickle).GetReadPointerAndAdvance(0)); |
+ EXPECT_TRUE(PickleIterator(pickle).GetReadPointerAndAdvance(1)); |
+ EXPECT_FALSE(PickleIterator(pickle).GetReadPointerAndAdvance(-1)); |
+ EXPECT_TRUE(PickleIterator(pickle).GetReadPointerAndAdvance(bytes)); |
+ EXPECT_FALSE(PickleIterator(pickle).GetReadPointerAndAdvance(bytes + 1)); |
+ EXPECT_FALSE(PickleIterator(pickle).GetReadPointerAndAdvance(INT_MAX)); |
+ EXPECT_FALSE(PickleIterator(pickle).GetReadPointerAndAdvance(INT_MIN)); |
} |
TEST(PickleTest, Resize) { |
@@ -252,7 +256,7 @@ TEST(PickleTest, HeaderPadding) { |
// this should not overwrite the 'int' payload |
pickle.headerT<CustomHeader>()->blah = 10; |
- void* iter = NULL; |
+ PickleIterator iter(pickle); |
int result; |
ASSERT_TRUE(pickle.ReadInt(&iter, &result)); |
@@ -273,25 +277,32 @@ TEST(PickleTest, EqualsOperator) { |
TEST(PickleTest, EvilLengths) { |
Pickle source; |
std::string str(100000, 'A'); |
- source.WriteData(str.c_str(), 100000); |
+ EXPECT_TRUE(source.WriteData(str.c_str(), 100000)); |
// ReadString16 used to have its read buffer length calculation wrong leading |
// to out-of-bounds reading. |
- void* iter = NULL; |
+ PickleIterator iter(source); |
string16 str16; |
EXPECT_FALSE(source.ReadString16(&iter, &str16)); |
// And check we didn't break ReadString16. |
str16 = (wchar_t) 'A'; |
Pickle str16_pickle; |
- str16_pickle.WriteString16(str16); |
- iter = NULL; |
+ EXPECT_TRUE(str16_pickle.WriteString16(str16)); |
+ iter = PickleIterator(str16_pickle); |
EXPECT_TRUE(str16_pickle.ReadString16(&iter, &str16)); |
EXPECT_EQ(1U, str16.length()); |
+ // Check we don't fail in a length check with invalid String16 size. |
+ // (1<<31) * sizeof(char16) == 0, so this is particularly evil. |
+ Pickle bad_len; |
+ EXPECT_TRUE(bad_len.WriteInt(1 << 31)); |
+ iter = PickleIterator(bad_len); |
+ EXPECT_FALSE(bad_len.ReadString16(&iter, &str16)); |
+ |
// Check we don't fail in a length check with large WStrings. |
Pickle big_len; |
- big_len.WriteInt(1 << 30); |
- iter = NULL; |
+ EXPECT_TRUE(big_len.WriteInt(1 << 30)); |
+ iter = PickleIterator(big_len); |
std::wstring wstr; |
EXPECT_FALSE(big_len.ReadWString(&iter, &wstr)); |
} |
@@ -301,7 +312,7 @@ TEST(PickleTest, ZeroLength) { |
Pickle pickle; |
EXPECT_TRUE(pickle.WriteData(NULL, 0)); |
- void* iter = NULL; |
+ PickleIterator iter(pickle); |
const char* outdata; |
int outdatalen; |
EXPECT_TRUE(pickle.ReadData(&iter, &outdata, &outdatalen)); |
@@ -315,8 +326,8 @@ TEST(PickleTest, ReadBytes) { |
int data = 0x7abcd; |
EXPECT_TRUE(pickle.WriteBytes(&data, sizeof(data))); |
- void* iter = NULL; |
- const char* outdata_char; |
+ PickleIterator iter(pickle); |
+ const char* outdata_char = NULL; |
EXPECT_TRUE(pickle.ReadBytes(&iter, &outdata_char, sizeof(data))); |
int outdata; |