Index: net/spdy/hpack_entry_test.cc |
diff --git a/net/spdy/hpack_entry_test.cc b/net/spdy/hpack_entry_test.cc |
index 84f923fc22d89965ac4bf660b12869d23e185bdc..919a316a9b32dd293708be1f9a8764e4bc3d3345 100644 |
--- a/net/spdy/hpack_entry_test.cc |
+++ b/net/spdy/hpack_entry_test.cc |
@@ -25,15 +25,23 @@ class HpackEntryTest : public ::testing::Test { |
// These builders maintain the same external table invariants that a "real" |
// table (ie HpackHeaderTable) would. |
HpackEntry StaticEntry() { |
- return HpackEntry(name_, value_, true, total_insertions_++, &table_size_); |
+ return HpackEntry(name_, value_, true, total_insertions_++); |
} |
HpackEntry DynamicEntry() { |
++table_size_; |
size_t index = total_insertions_++; |
- return HpackEntry(name_, value_, false, index, &total_insertions_); |
+ return HpackEntry(name_, value_, false, index); |
} |
void DropEntry() { --table_size_; } |
+ size_t IndexOf(const HpackEntry& entry) const { |
+ if (entry.IsStatic()) { |
+ return 1 + entry.InsertionIndex() + table_size_; |
+ } else { |
+ return total_insertions_ - entry.InsertionIndex(); |
+ } |
+ } |
+ |
size_t Size() { |
return name_.size() + value_.size() + HpackEntry::kSizeOverhead; |
} |
@@ -52,7 +60,7 @@ TEST_F(HpackEntryTest, StaticConstructor) { |
EXPECT_EQ(name_, entry.name()); |
EXPECT_EQ(value_, entry.value()); |
EXPECT_TRUE(entry.IsStatic()); |
- EXPECT_EQ(1u, entry.Index()); |
+ EXPECT_EQ(1u, IndexOf(entry)); |
EXPECT_EQ(0u, entry.state()); |
EXPECT_EQ(Size(), entry.Size()); |
} |
@@ -63,7 +71,7 @@ TEST_F(HpackEntryTest, DynamicConstructor) { |
EXPECT_EQ(name_, entry.name()); |
EXPECT_EQ(value_, entry.value()); |
EXPECT_FALSE(entry.IsStatic()); |
- EXPECT_EQ(1u, entry.Index()); |
+ EXPECT_EQ(1u, IndexOf(entry)); |
EXPECT_EQ(0u, entry.state()); |
EXPECT_EQ(Size(), entry.Size()); |
} |
@@ -74,7 +82,7 @@ TEST_F(HpackEntryTest, LookupConstructor) { |
EXPECT_EQ(name_, entry.name()); |
EXPECT_EQ(value_, entry.value()); |
EXPECT_FALSE(entry.IsStatic()); |
- EXPECT_EQ(0u, entry.Index()); |
+ EXPECT_EQ(0u, IndexOf(entry)); |
EXPECT_EQ(0u, entry.state()); |
EXPECT_EQ(Size(), entry.Size()); |
} |
@@ -92,78 +100,29 @@ TEST_F(HpackEntryTest, IndexUpdate) { |
HpackEntry static1(StaticEntry()); |
HpackEntry static2(StaticEntry()); |
- EXPECT_EQ(1u, static1.Index()); |
- EXPECT_EQ(2u, static2.Index()); |
+ EXPECT_EQ(1u, IndexOf(static1)); |
+ EXPECT_EQ(2u, IndexOf(static2)); |
HpackEntry dynamic1(DynamicEntry()); |
HpackEntry dynamic2(DynamicEntry()); |
- EXPECT_EQ(1u, dynamic2.Index()); |
- EXPECT_EQ(2u, dynamic1.Index()); |
- EXPECT_EQ(3u, static1.Index()); |
- EXPECT_EQ(4u, static2.Index()); |
+ EXPECT_EQ(1u, IndexOf(dynamic2)); |
+ EXPECT_EQ(2u, IndexOf(dynamic1)); |
+ EXPECT_EQ(3u, IndexOf(static1)); |
+ EXPECT_EQ(4u, IndexOf(static2)); |
DropEntry(); // Drops |dynamic1|. |
- EXPECT_EQ(1u, dynamic2.Index()); |
- EXPECT_EQ(2u, static1.Index()); |
- EXPECT_EQ(3u, static2.Index()); |
+ EXPECT_EQ(1u, IndexOf(dynamic2)); |
+ EXPECT_EQ(2u, IndexOf(static1)); |
+ EXPECT_EQ(3u, IndexOf(static2)); |
HpackEntry dynamic3(DynamicEntry()); |
- EXPECT_EQ(1u, dynamic3.Index()); |
- EXPECT_EQ(2u, dynamic2.Index()); |
- EXPECT_EQ(3u, static1.Index()); |
- EXPECT_EQ(4u, static2.Index()); |
-} |
- |
-TEST_F(HpackEntryTest, ComparatorNameOrdering) { |
- HpackEntry entry1(StaticEntry()); |
- name_[0]--; |
- HpackEntry entry2(StaticEntry()); |
- |
- EXPECT_FALSE(HpackEntry::Comparator()(&entry1, &entry2)); |
- EXPECT_TRUE(HpackEntry::Comparator()(&entry2, &entry1)); |
-} |
- |
-TEST_F(HpackEntryTest, ComparatorValueOrdering) { |
- HpackEntry entry1(StaticEntry()); |
- value_[0]--; |
- HpackEntry entry2(StaticEntry()); |
- |
- EXPECT_FALSE(HpackEntry::Comparator()(&entry1, &entry2)); |
- EXPECT_TRUE(HpackEntry::Comparator()(&entry2, &entry1)); |
-} |
- |
-TEST_F(HpackEntryTest, ComparatorIndexOrdering) { |
- HpackEntry entry1(StaticEntry()); |
- HpackEntry entry2(StaticEntry()); |
- |
- EXPECT_TRUE(HpackEntry::Comparator()(&entry1, &entry2)); |
- EXPECT_FALSE(HpackEntry::Comparator()(&entry2, &entry1)); |
- |
- HpackEntry entry3(DynamicEntry()); |
- HpackEntry entry4(DynamicEntry()); |
- |
- // |entry4| has lower index than |entry3|. |
- EXPECT_TRUE(HpackEntry::Comparator()(&entry4, &entry3)); |
- EXPECT_FALSE(HpackEntry::Comparator()(&entry3, &entry4)); |
- |
- // |entry3| has lower index than |entry1|. |
- EXPECT_TRUE(HpackEntry::Comparator()(&entry3, &entry1)); |
- EXPECT_FALSE(HpackEntry::Comparator()(&entry1, &entry3)); |
- |
- // |entry1| & |entry2| ordering is preserved, though each Index() has changed. |
- EXPECT_TRUE(HpackEntry::Comparator()(&entry1, &entry2)); |
- EXPECT_FALSE(HpackEntry::Comparator()(&entry2, &entry1)); |
-} |
- |
-TEST_F(HpackEntryTest, ComparatorEqualityOrdering) { |
- HpackEntry entry1(StaticEntry()); |
- HpackEntry entry2(DynamicEntry()); |
- |
- EXPECT_FALSE(HpackEntry::Comparator()(&entry1, &entry1)); |
- EXPECT_FALSE(HpackEntry::Comparator()(&entry2, &entry2)); |
+ EXPECT_EQ(1u, IndexOf(dynamic3)); |
+ EXPECT_EQ(2u, IndexOf(dynamic2)); |
+ EXPECT_EQ(3u, IndexOf(static1)); |
+ EXPECT_EQ(4u, IndexOf(static2)); |
} |
} // namespace |