| Index: test/unittests/interpreter/constant-array-builder-unittest.cc
|
| diff --git a/test/unittests/interpreter/constant-array-builder-unittest.cc b/test/unittests/interpreter/constant-array-builder-unittest.cc
|
| index ee77423175d8e8213ce8d8add1f6465933cafc88..263c809fcdf884b5fbd23558bb3f5c57c43d9833 100644
|
| --- a/test/unittests/interpreter/constant-array-builder-unittest.cc
|
| +++ b/test/unittests/interpreter/constant-array-builder-unittest.cc
|
| @@ -40,6 +40,53 @@ TEST_F(ConstantArrayBuilderTest, AllocateAllEntries) {
|
| }
|
| }
|
|
|
| +TEST_F(ConstantArrayBuilderTest, ToFixedArray) {
|
| + CanonicalHandleScope canonical(isolate());
|
| + ConstantArrayBuilder builder(isolate(), zone());
|
| + static const size_t kNumberOfElements = 37;
|
| + for (size_t i = 0; i < kNumberOfElements; i++) {
|
| + Handle<Object> object = isolate()->factory()->NewNumberFromSize(i);
|
| + builder.Insert(object);
|
| + CHECK(builder.At(i)->SameValue(*object));
|
| + }
|
| + Handle<FixedArray> constant_array = builder.ToFixedArray();
|
| + CHECK_EQ(constant_array->length(), kNumberOfElements);
|
| + for (size_t i = 0; i < kNumberOfElements; i++) {
|
| + CHECK(constant_array->get(static_cast<int>(i))->SameValue(*builder.At(i)));
|
| + }
|
| +}
|
| +
|
| +TEST_F(ConstantArrayBuilderTest, ToLargeFixedArray) {
|
| + CanonicalHandleScope canonical(isolate());
|
| + ConstantArrayBuilder builder(isolate(), zone());
|
| + static const size_t kNumberOfElements = 37373;
|
| + for (size_t i = 0; i < kNumberOfElements; i++) {
|
| + Handle<Object> object = isolate()->factory()->NewNumberFromSize(i);
|
| + builder.Insert(object);
|
| + CHECK(builder.At(i)->SameValue(*object));
|
| + }
|
| + Handle<FixedArray> constant_array = builder.ToFixedArray();
|
| + CHECK_EQ(constant_array->length(), kNumberOfElements);
|
| + for (size_t i = 0; i < kNumberOfElements; i++) {
|
| + CHECK(constant_array->get(static_cast<int>(i))->SameValue(*builder.At(i)));
|
| + }
|
| +}
|
| +
|
| +TEST_F(ConstantArrayBuilderTest, ToLargeFixedArrayWithReservations) {
|
| + CanonicalHandleScope canonical(isolate());
|
| + ConstantArrayBuilder builder(isolate(), zone());
|
| + static const size_t kNumberOfElements = 37373;
|
| + for (size_t i = 0; i < kNumberOfElements; i++) {
|
| + builder.CommitReservedEntry(builder.CreateReservedEntry(),
|
| + Smi::FromInt(static_cast<int>(i)));
|
| + }
|
| + Handle<FixedArray> constant_array = builder.ToFixedArray();
|
| + CHECK_EQ(constant_array->length(), kNumberOfElements);
|
| + for (size_t i = 0; i < kNumberOfElements; i++) {
|
| + CHECK(constant_array->get(static_cast<int>(i))->SameValue(*builder.At(i)));
|
| + }
|
| +}
|
| +
|
| TEST_F(ConstantArrayBuilderTest, AllocateEntriesWithIdx8Reservations) {
|
| CanonicalHandleScope canonical(isolate());
|
| for (size_t reserved = 1; reserved < k8BitCapacity; reserved *= 3) {
|
| @@ -49,16 +96,14 @@ TEST_F(ConstantArrayBuilderTest, AllocateEntriesWithIdx8Reservations) {
|
| CHECK(operand_size == OperandSize::kByte);
|
| }
|
| for (size_t i = 0; i < 2 * k8BitCapacity; i++) {
|
| - Handle<Object> object = isolate()->factory()->NewNumberFromSize(i);
|
| - builder.Insert(object);
|
| + builder.CommitReservedEntry(builder.CreateReservedEntry(),
|
| + Smi::FromInt(static_cast<int>(i)));
|
| if (i + reserved < k8BitCapacity) {
|
| CHECK_LE(builder.size(), k8BitCapacity);
|
| CHECK_EQ(builder.size(), i + 1);
|
| - CHECK(builder.At(i)->SameValue(*object));
|
| } else {
|
| CHECK_GE(builder.size(), k8BitCapacity);
|
| CHECK_EQ(builder.size(), i + reserved + 1);
|
| - CHECK(builder.At(i + reserved)->SameValue(*object));
|
| }
|
| }
|
| CHECK_EQ(builder.size(), 2 * k8BitCapacity + reserved);
|
| @@ -69,44 +114,41 @@ TEST_F(ConstantArrayBuilderTest, AllocateEntriesWithIdx8Reservations) {
|
| CHECK(empty->SameValue(isolate()->heap()->the_hole_value()));
|
| }
|
|
|
| - // Commmit reserved entries with duplicates and check size does not change.
|
| + // Commit reserved entries with duplicates and check size does not change.
|
| DCHECK_EQ(reserved + 2 * k8BitCapacity, builder.size());
|
| size_t duplicates_in_idx8_space =
|
| std::min(reserved, k8BitCapacity - reserved);
|
| for (size_t i = 0; i < duplicates_in_idx8_space; i++) {
|
| builder.CommitReservedEntry(OperandSize::kByte,
|
| - isolate()->factory()->NewNumberFromSize(i));
|
| + Smi::FromInt(static_cast<int>(i)));
|
| DCHECK_EQ(reserved + 2 * k8BitCapacity, builder.size());
|
| }
|
|
|
| - // Check all committed values match expected (holes where
|
| - // duplicates_in_idx8_space allocated).
|
| - for (size_t i = 0; i < k8BitCapacity - reserved; i++) {
|
| - Smi* smi = Smi::FromInt(static_cast<int>(i));
|
| - CHECK(Handle<Smi>::cast(builder.At(i))->SameValue(smi));
|
| - }
|
| - for (size_t i = k8BitCapacity; i < 2 * k8BitCapacity + reserved; i++) {
|
| - Smi* smi = Smi::FromInt(static_cast<int>(i - reserved));
|
| - CHECK(Handle<Smi>::cast(builder.At(i))->SameValue(smi));
|
| - }
|
| - for (size_t i = 0; i < reserved; i++) {
|
| - size_t index = k8BitCapacity - reserved + i;
|
| - CHECK(builder.At(index)->IsTheHole(isolate()));
|
| - }
|
| -
|
| // Now make reservations, and commit them with unique entries.
|
| for (size_t i = 0; i < duplicates_in_idx8_space; i++) {
|
| OperandSize operand_size = builder.CreateReservedEntry();
|
| CHECK(operand_size == OperandSize::kByte);
|
| }
|
| for (size_t i = 0; i < duplicates_in_idx8_space; i++) {
|
| - Handle<Object> object =
|
| - isolate()->factory()->NewNumberFromSize(2 * k8BitCapacity + i);
|
| - size_t index = builder.CommitReservedEntry(OperandSize::kByte, object);
|
| + Smi* value = Smi::FromInt(static_cast<int>(2 * k8BitCapacity + i));
|
| + size_t index = builder.CommitReservedEntry(OperandSize::kByte, value);
|
| CHECK_EQ(static_cast<int>(index), k8BitCapacity - reserved + i);
|
| - CHECK(builder.At(static_cast<int>(index))->SameValue(*object));
|
| }
|
| - CHECK_EQ(builder.size(), 2 * k8BitCapacity + reserved);
|
| +
|
| + Handle<FixedArray> constant_array = builder.ToFixedArray();
|
| + CHECK_EQ(constant_array->length(), 2 * k8BitCapacity + reserved);
|
| +
|
| + // Check all committed values match expected
|
| + for (size_t i = 0; i < k8BitCapacity - reserved; i++) {
|
| + Object* value = constant_array->get(static_cast<int>(i));
|
| + Smi* smi = Smi::FromInt(static_cast<int>(i));
|
| + CHECK(value->SameValue(smi));
|
| + }
|
| + for (size_t i = k8BitCapacity; i < 2 * k8BitCapacity + reserved; i++) {
|
| + Object* value = constant_array->get(static_cast<int>(i));
|
| + Smi* smi = Smi::FromInt(static_cast<int>(i - reserved));
|
| + CHECK(value->SameValue(smi));
|
| + }
|
| }
|
| }
|
|
|
| @@ -115,9 +157,8 @@ TEST_F(ConstantArrayBuilderTest, AllocateEntriesWithWideReservations) {
|
| for (size_t reserved = 1; reserved < k8BitCapacity; reserved *= 3) {
|
| ConstantArrayBuilder builder(isolate(), zone());
|
| for (size_t i = 0; i < k8BitCapacity; i++) {
|
| - Handle<Object> object = isolate()->factory()->NewNumberFromSize(i);
|
| - builder.Insert(object);
|
| - CHECK(builder.At(i)->SameValue(*object));
|
| + builder.CommitReservedEntry(builder.CreateReservedEntry(),
|
| + Smi::FromInt(static_cast<int>(i)));
|
| CHECK_EQ(builder.size(), i + 1);
|
| }
|
| for (size_t i = 0; i < reserved; i++) {
|
| @@ -132,50 +173,24 @@ TEST_F(ConstantArrayBuilderTest, AllocateEntriesWithWideReservations) {
|
| for (size_t i = 0; i < reserved; i++) {
|
| OperandSize operand_size = builder.CreateReservedEntry();
|
| CHECK(operand_size == OperandSize::kShort);
|
| - Handle<Object> object = isolate()->factory()->NewNumberFromSize(i);
|
| - builder.CommitReservedEntry(operand_size, object);
|
| + builder.CommitReservedEntry(operand_size,
|
| + Smi::FromInt(static_cast<int>(i)));
|
| CHECK_EQ(builder.size(), k8BitCapacity);
|
| }
|
| for (size_t i = k8BitCapacity; i < k8BitCapacity + reserved; i++) {
|
| OperandSize operand_size = builder.CreateReservedEntry();
|
| CHECK(operand_size == OperandSize::kShort);
|
| - Handle<Object> object = isolate()->factory()->NewNumberFromSize(i);
|
| - builder.CommitReservedEntry(operand_size, object);
|
| + builder.CommitReservedEntry(operand_size,
|
| + Smi::FromInt(static_cast<int>(i)));
|
| CHECK_EQ(builder.size(), i + 1);
|
| }
|
| - }
|
| -}
|
| -
|
| -
|
| -TEST_F(ConstantArrayBuilderTest, ToFixedArray) {
|
| - CanonicalHandleScope canonical(isolate());
|
| - ConstantArrayBuilder builder(isolate(), zone());
|
| - static const size_t kNumberOfElements = 37;
|
| - for (size_t i = 0; i < kNumberOfElements; i++) {
|
| - Handle<Object> object = isolate()->factory()->NewNumberFromSize(i);
|
| - builder.Insert(object);
|
| - CHECK(builder.At(i)->SameValue(*object));
|
| - }
|
| - Handle<FixedArray> constant_array = builder.ToFixedArray();
|
| - CHECK_EQ(constant_array->length(), kNumberOfElements);
|
| - for (size_t i = 0; i < kNumberOfElements; i++) {
|
| - CHECK(constant_array->get(static_cast<int>(i))->SameValue(*builder.At(i)));
|
| - }
|
| -}
|
|
|
| -TEST_F(ConstantArrayBuilderTest, ToLargeFixedArray) {
|
| - CanonicalHandleScope canonical(isolate());
|
| - ConstantArrayBuilder builder(isolate(), zone());
|
| - static const size_t kNumberOfElements = 37373;
|
| - for (size_t i = 0; i < kNumberOfElements; i++) {
|
| - Handle<Object> object = isolate()->factory()->NewNumberFromSize(i);
|
| - builder.Insert(object);
|
| - CHECK(builder.At(i)->SameValue(*object));
|
| - }
|
| - Handle<FixedArray> constant_array = builder.ToFixedArray();
|
| - CHECK_EQ(constant_array->length(), kNumberOfElements);
|
| - for (size_t i = 0; i < kNumberOfElements; i++) {
|
| - CHECK(constant_array->get(static_cast<int>(i))->SameValue(*builder.At(i)));
|
| + Handle<FixedArray> constant_array = builder.ToFixedArray();
|
| + CHECK_EQ(constant_array->length(), k8BitCapacity + reserved);
|
| + for (size_t i = 0; i < k8BitCapacity + reserved; i++) {
|
| + Object* value = constant_array->get(static_cast<int>(i));
|
| + CHECK(value->SameValue(*isolate()->factory()->NewNumberFromSize(i)));
|
| + }
|
| }
|
| }
|
|
|
| @@ -188,19 +203,21 @@ TEST_F(ConstantArrayBuilderTest, GapFilledWhenLowReservationCommitted) {
|
| CHECK_EQ(builder.size(), 0);
|
| }
|
| for (size_t i = 0; i < k8BitCapacity; i++) {
|
| - Handle<Object> object = isolate()->factory()->NewNumberFromSize(i);
|
| - builder.Insert(object);
|
| + builder.CommitReservedEntry(builder.CreateReservedEntry(),
|
| + Smi::FromInt(static_cast<int>(i)));
|
| CHECK_EQ(builder.size(), i + k8BitCapacity + 1);
|
| }
|
| for (size_t i = 0; i < k8BitCapacity; i++) {
|
| builder.CommitReservedEntry(OperandSize::kByte,
|
| - builder.At(i + k8BitCapacity));
|
| + Smi::FromInt(static_cast<int>(i)));
|
| CHECK_EQ(builder.size(), 2 * k8BitCapacity);
|
| }
|
| + Handle<FixedArray> constant_array = builder.ToFixedArray();
|
| + CHECK_EQ(constant_array->length(), 2 * k8BitCapacity);
|
| for (size_t i = 0; i < k8BitCapacity; i++) {
|
| - Handle<Object> original = builder.At(k8BitCapacity + i);
|
| - Handle<Object> duplicate = builder.At(i);
|
| - CHECK(original->SameValue(*duplicate));
|
| + Object* original = constant_array->get(static_cast<int>(k8BitCapacity + i));
|
| + Object* duplicate = constant_array->get(static_cast<int>(i));
|
| + CHECK(original->SameValue(duplicate));
|
| Handle<Object> reference = isolate()->factory()->NewNumberFromSize(i);
|
| CHECK(original->SameValue(*reference));
|
| }
|
| @@ -269,14 +286,10 @@ TEST_F(ConstantArrayBuilderTest, ReservationsAtAllScales) {
|
| for (int i = 65536; i < 131072; ++i) {
|
| CHECK_EQ(builder.CreateReservedEntry(), OperandSize::kQuad);
|
| }
|
| - CHECK_EQ(builder.CommitReservedEntry(OperandSize::kByte,
|
| - isolate()->factory()->NewNumber(1)),
|
| - 0);
|
| - CHECK_EQ(builder.CommitReservedEntry(OperandSize::kShort,
|
| - isolate()->factory()->NewNumber(2)),
|
| + CHECK_EQ(builder.CommitReservedEntry(OperandSize::kByte, Smi::FromInt(1)), 0);
|
| + CHECK_EQ(builder.CommitReservedEntry(OperandSize::kShort, Smi::FromInt(2)),
|
| 256);
|
| - CHECK_EQ(builder.CommitReservedEntry(OperandSize::kQuad,
|
| - isolate()->factory()->NewNumber(3)),
|
| + CHECK_EQ(builder.CommitReservedEntry(OperandSize::kQuad, Smi::FromInt(3)),
|
| 65536);
|
| Handle<FixedArray> constant_array = builder.ToFixedArray();
|
| CHECK_EQ(constant_array->length(), 65537);
|
|
|