Index: test/unittests/object-unittest.cc |
diff --git a/test/unittests/object-unittest.cc b/test/unittests/object-unittest.cc |
index b09b97dea6991f2ee23651bd58d2a20137982798..e0a65f2ac86eb063c2ff48a7796bd4b0c6760092 100644 |
--- a/test/unittests/object-unittest.cc |
+++ b/test/unittests/object-unittest.cc |
@@ -8,6 +8,7 @@ |
#include "src/objects-inl.h" |
#include "src/objects.h" |
+#include "test/unittests/test-utils.h" |
#include "testing/gtest/include/gtest/gtest.h" |
@@ -53,5 +54,64 @@ TEST(Object, StructListOrder) { |
#undef TEST_STRUCT |
} |
+typedef TestWithIsolate ObjectWithIsolate; |
+ |
+TEST_F(ObjectWithIsolate, DictionaryGrowth) { |
+ Handle<SeededNumberDictionary> dict = |
+ SeededNumberDictionary::New(isolate(), 1); |
+ Handle<Object> value = isolate()->factory()->null_value(); |
+ PropertyDetails details = PropertyDetails::Empty(); |
+ |
+ // This test documents the expected growth behavior of a dictionary getting |
+ // elements added to it one by one. |
+ STATIC_ASSERT(HashTableBase::kMinCapacity == 4); |
+ uint32_t i = 1; |
+ // 3 elements fit into the initial capacity. |
+ for (; i <= 3; i++) { |
+ dict = SeededNumberDictionary::Add(dict, i, value, details); |
+ CHECK_EQ(4, dict->Capacity()); |
+ } |
+ // 4th element triggers growth. |
+ DCHECK_EQ(4, i); |
+ for (; i <= 5; i++) { |
+ dict = SeededNumberDictionary::Add(dict, i, value, details); |
+ CHECK_EQ(8, dict->Capacity()); |
+ } |
+ // 6th element triggers growth. |
+ DCHECK_EQ(6, i); |
+ for (; i <= 11; i++) { |
+ dict = SeededNumberDictionary::Add(dict, i, value, details); |
+ CHECK_EQ(16, dict->Capacity()); |
+ } |
+ // 12th element triggers growth. |
+ DCHECK_EQ(12, i); |
+ for (; i <= 21; i++) { |
+ dict = SeededNumberDictionary::Add(dict, i, value, details); |
+ CHECK_EQ(32, dict->Capacity()); |
+ } |
+ // 22nd element triggers growth. |
+ DCHECK_EQ(22, i); |
+ for (; i <= 43; i++) { |
+ dict = SeededNumberDictionary::Add(dict, i, value, details); |
+ CHECK_EQ(64, dict->Capacity()); |
+ } |
+ // 44th element triggers growth. |
+ DCHECK_EQ(44, i); |
+ for (; i <= 50; i++) { |
+ dict = SeededNumberDictionary::Add(dict, i, value, details); |
+ CHECK_EQ(128, dict->Capacity()); |
+ } |
+ |
+ // If we grow by larger chunks, the next (sufficiently big) power of 2 is |
+ // chosen as the capacity. |
+ dict = SeededNumberDictionary::New(isolate(), 1); |
+ dict = SeededNumberDictionary::EnsureCapacity(dict, 65, 1); |
+ CHECK_EQ(128, dict->Capacity()); |
+ |
+ dict = SeededNumberDictionary::New(isolate(), 1); |
+ dict = SeededNumberDictionary::EnsureCapacity(dict, 30, 1); |
+ CHECK_EQ(64, dict->Capacity()); |
+} |
+ |
} // namespace internal |
} // namespace v8 |