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

Unified Diff: base/pickle_unittest.cc

Issue 9447084: Refactor Pickle Read methods to use higher performance PickleIterator. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: compile (racing with incoming CLs) Created 8 years, 9 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « base/pickle.cc ('k') | chrome/browser/automation/url_request_automation_job.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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;
« no previous file with comments | « base/pickle.cc ('k') | chrome/browser/automation/url_request_automation_job.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698