2016-05-12 19:18:07 +00:00
|
|
|
// Copyright 2016 the V8 project authors. All rights reserved.
|
|
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
|
|
// found in the LICENSE file.
|
|
|
|
|
|
|
|
#include "src/v8.h"
|
|
|
|
|
|
|
|
#include "src/interpreter/bytecode-pipeline.h"
|
|
|
|
#include "src/interpreter/bytecode-register-allocator.h"
|
|
|
|
#include "src/isolate.h"
|
|
|
|
#include "test/unittests/test-utils.h"
|
|
|
|
|
|
|
|
namespace v8 {
|
|
|
|
namespace internal {
|
|
|
|
namespace interpreter {
|
|
|
|
|
|
|
|
using BytecodeNodeTest = TestWithIsolateAndZone;
|
|
|
|
|
|
|
|
TEST(BytecodeSourceInfo, Operations) {
|
|
|
|
BytecodeSourceInfo x(0, true);
|
|
|
|
CHECK_EQ(x.source_position(), 0);
|
|
|
|
CHECK_EQ(x.is_statement(), true);
|
|
|
|
CHECK_EQ(x.is_valid(), true);
|
|
|
|
x.set_invalid();
|
|
|
|
CHECK_EQ(x.is_statement(), false);
|
|
|
|
CHECK_EQ(x.is_valid(), false);
|
|
|
|
|
2016-06-21 11:11:15 +00:00
|
|
|
x.MakeStatementPosition(1);
|
2016-05-12 19:18:07 +00:00
|
|
|
BytecodeSourceInfo y(1, true);
|
|
|
|
CHECK(x == y);
|
|
|
|
CHECK(!(x != y));
|
|
|
|
|
|
|
|
x.set_invalid();
|
|
|
|
CHECK(!(x == y));
|
|
|
|
CHECK(x != y);
|
|
|
|
|
2016-06-21 11:11:15 +00:00
|
|
|
y.MakeStatementPosition(1);
|
2016-05-12 19:18:07 +00:00
|
|
|
CHECK_EQ(y.source_position(), 1);
|
|
|
|
CHECK_EQ(y.is_statement(), true);
|
|
|
|
|
2016-06-21 11:11:15 +00:00
|
|
|
y.MakeStatementPosition(2);
|
2016-05-12 19:18:07 +00:00
|
|
|
CHECK_EQ(y.source_position(), 2);
|
|
|
|
CHECK_EQ(y.is_statement(), true);
|
|
|
|
|
|
|
|
y.set_invalid();
|
2016-06-21 11:11:15 +00:00
|
|
|
y.MakeExpressionPosition(3);
|
2016-05-12 19:18:07 +00:00
|
|
|
CHECK_EQ(y.source_position(), 3);
|
|
|
|
CHECK_EQ(y.is_statement(), false);
|
|
|
|
|
2016-06-21 11:11:15 +00:00
|
|
|
y.MakeStatementPosition(3);
|
2016-05-12 19:18:07 +00:00
|
|
|
CHECK_EQ(y.source_position(), 3);
|
|
|
|
CHECK_EQ(y.is_statement(), true);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(BytecodeNodeTest, Constructor1) {
|
|
|
|
BytecodeNode node(Bytecode::kLdaZero);
|
|
|
|
CHECK_EQ(node.bytecode(), Bytecode::kLdaZero);
|
|
|
|
CHECK_EQ(node.operand_count(), 0);
|
|
|
|
CHECK(!node.source_info().is_valid());
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(BytecodeNodeTest, Constructor2) {
|
|
|
|
uint32_t operands[] = {0x11};
|
2016-06-10 10:34:50 +00:00
|
|
|
BytecodeNode node(Bytecode::kJumpIfTrue, operands[0]);
|
2016-05-12 19:18:07 +00:00
|
|
|
CHECK_EQ(node.bytecode(), Bytecode::kJumpIfTrue);
|
|
|
|
CHECK_EQ(node.operand_count(), 1);
|
|
|
|
CHECK_EQ(node.operand(0), operands[0]);
|
|
|
|
CHECK(!node.source_info().is_valid());
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(BytecodeNodeTest, Constructor3) {
|
2016-06-27 08:42:41 +00:00
|
|
|
uint32_t operands[] = {0x11};
|
|
|
|
BytecodeNode node(Bytecode::kLdaGlobal, operands[0]);
|
2016-05-12 19:18:07 +00:00
|
|
|
CHECK_EQ(node.bytecode(), Bytecode::kLdaGlobal);
|
2016-06-27 08:42:41 +00:00
|
|
|
CHECK_EQ(node.operand_count(), 1);
|
2016-05-12 19:18:07 +00:00
|
|
|
CHECK_EQ(node.operand(0), operands[0]);
|
|
|
|
CHECK(!node.source_info().is_valid());
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(BytecodeNodeTest, Constructor4) {
|
|
|
|
uint32_t operands[] = {0x11, 0x22, 0x33};
|
2016-05-25 10:45:14 +00:00
|
|
|
BytecodeNode node(Bytecode::kLdaNamedProperty, operands[0], operands[1],
|
2016-06-10 10:34:50 +00:00
|
|
|
operands[2]);
|
2016-05-12 19:18:07 +00:00
|
|
|
CHECK_EQ(node.operand_count(), 3);
|
2016-05-25 10:45:14 +00:00
|
|
|
CHECK_EQ(node.bytecode(), Bytecode::kLdaNamedProperty);
|
2016-05-12 19:18:07 +00:00
|
|
|
CHECK_EQ(node.operand(0), operands[0]);
|
|
|
|
CHECK_EQ(node.operand(1), operands[1]);
|
|
|
|
CHECK_EQ(node.operand(2), operands[2]);
|
|
|
|
CHECK(!node.source_info().is_valid());
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(BytecodeNodeTest, Constructor5) {
|
|
|
|
uint32_t operands[] = {0x71, 0xa5, 0x5a, 0xfc};
|
|
|
|
BytecodeNode node(Bytecode::kForInNext, operands[0], operands[1], operands[2],
|
2016-06-10 10:34:50 +00:00
|
|
|
operands[3]);
|
2016-05-12 19:18:07 +00:00
|
|
|
CHECK_EQ(node.operand_count(), 4);
|
|
|
|
CHECK_EQ(node.bytecode(), Bytecode::kForInNext);
|
|
|
|
CHECK_EQ(node.operand(0), operands[0]);
|
|
|
|
CHECK_EQ(node.operand(1), operands[1]);
|
|
|
|
CHECK_EQ(node.operand(2), operands[2]);
|
|
|
|
CHECK_EQ(node.operand(3), operands[3]);
|
|
|
|
CHECK(!node.source_info().is_valid());
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(BytecodeNodeTest, Equality) {
|
|
|
|
uint32_t operands[] = {0x71, 0xa5, 0x5a, 0xfc};
|
|
|
|
BytecodeNode node(Bytecode::kForInNext, operands[0], operands[1], operands[2],
|
2016-06-10 10:34:50 +00:00
|
|
|
operands[3]);
|
2016-05-12 19:18:07 +00:00
|
|
|
CHECK_EQ(node, node);
|
|
|
|
BytecodeNode other(Bytecode::kForInNext, operands[0], operands[1],
|
2016-06-10 10:34:50 +00:00
|
|
|
operands[2], operands[3]);
|
2016-05-12 19:18:07 +00:00
|
|
|
CHECK_EQ(node, other);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(BytecodeNodeTest, EqualityWithSourceInfo) {
|
|
|
|
uint32_t operands[] = {0x71, 0xa5, 0x5a, 0xfc};
|
2016-09-22 16:34:16 +00:00
|
|
|
BytecodeSourceInfo first_source_info(3, true);
|
2016-05-12 19:18:07 +00:00
|
|
|
BytecodeNode node(Bytecode::kForInNext, operands[0], operands[1], operands[2],
|
2016-09-22 16:34:16 +00:00
|
|
|
operands[3], &first_source_info);
|
2016-05-12 19:18:07 +00:00
|
|
|
CHECK_EQ(node, node);
|
2016-09-22 16:34:16 +00:00
|
|
|
BytecodeSourceInfo second_source_info(3, true);
|
2016-05-12 19:18:07 +00:00
|
|
|
BytecodeNode other(Bytecode::kForInNext, operands[0], operands[1],
|
2016-09-22 16:34:16 +00:00
|
|
|
operands[2], operands[3], &second_source_info);
|
2016-05-12 19:18:07 +00:00
|
|
|
CHECK_EQ(node, other);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(BytecodeNodeTest, NoEqualityWithDifferentSourceInfo) {
|
|
|
|
uint32_t operands[] = {0x71, 0xa5, 0x5a, 0xfc};
|
2016-09-22 16:34:16 +00:00
|
|
|
BytecodeSourceInfo source_info(77, true);
|
2016-05-12 19:18:07 +00:00
|
|
|
BytecodeNode node(Bytecode::kForInNext, operands[0], operands[1], operands[2],
|
2016-09-22 16:34:16 +00:00
|
|
|
operands[3], &source_info);
|
2016-05-12 19:18:07 +00:00
|
|
|
BytecodeNode other(Bytecode::kForInNext, operands[0], operands[1],
|
2016-06-10 10:34:50 +00:00
|
|
|
operands[2], operands[3]);
|
2016-05-12 19:18:07 +00:00
|
|
|
CHECK_NE(node, other);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(BytecodeNodeTest, Clone) {
|
|
|
|
uint32_t operands[] = {0x71, 0xa5, 0x5a, 0xfc};
|
|
|
|
BytecodeNode node(Bytecode::kForInNext, operands[0], operands[1], operands[2],
|
2016-06-10 10:34:50 +00:00
|
|
|
operands[3]);
|
2016-09-22 16:34:16 +00:00
|
|
|
BytecodeNode clone(Bytecode::kIllegal);
|
2016-05-12 19:18:07 +00:00
|
|
|
clone.Clone(&node);
|
|
|
|
CHECK_EQ(clone, node);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(BytecodeNodeTest, SetBytecode0) {
|
|
|
|
uint32_t operands[] = {0x71, 0xa5, 0x5a, 0xfc};
|
2016-09-22 05:53:14 +00:00
|
|
|
BytecodeSourceInfo source_info(77, false);
|
2016-09-22 16:34:16 +00:00
|
|
|
BytecodeNode node(Bytecode::kForInNext, operands[0], operands[1], operands[2],
|
|
|
|
operands[3], &source_info);
|
|
|
|
CHECK_EQ(node.source_info(), BytecodeSourceInfo(77, false));
|
2016-05-12 19:18:07 +00:00
|
|
|
|
2016-09-22 16:34:16 +00:00
|
|
|
BytecodeNode clone(Bytecode::kIllegal);
|
2016-05-12 19:18:07 +00:00
|
|
|
clone.Clone(&node);
|
|
|
|
clone.set_bytecode(Bytecode::kNop);
|
|
|
|
CHECK_EQ(clone.bytecode(), Bytecode::kNop);
|
|
|
|
CHECK_EQ(clone.operand_count(), 0);
|
2016-09-22 16:34:16 +00:00
|
|
|
CHECK_EQ(clone.source_info(), BytecodeSourceInfo(77, false));
|
2016-05-12 19:18:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(BytecodeNodeTest, SetBytecode1) {
|
|
|
|
uint32_t operands[] = {0x71, 0xa5, 0x5a, 0xfc};
|
2016-09-22 05:53:14 +00:00
|
|
|
BytecodeSourceInfo source_info(77, false);
|
2016-09-22 16:34:16 +00:00
|
|
|
BytecodeNode node(Bytecode::kForInNext, operands[0], operands[1], operands[2],
|
|
|
|
operands[3], &source_info);
|
2016-05-12 19:18:07 +00:00
|
|
|
|
2016-09-22 16:34:16 +00:00
|
|
|
BytecodeNode clone(Bytecode::kIllegal);
|
2016-05-12 19:18:07 +00:00
|
|
|
clone.Clone(&node);
|
2016-06-10 10:34:50 +00:00
|
|
|
clone.set_bytecode(Bytecode::kJump, 0x01aabbcc);
|
2016-05-12 19:18:07 +00:00
|
|
|
CHECK_EQ(clone.bytecode(), Bytecode::kJump);
|
|
|
|
CHECK_EQ(clone.operand_count(), 1);
|
|
|
|
CHECK_EQ(clone.operand(0), 0x01aabbcc);
|
2016-09-22 16:34:16 +00:00
|
|
|
CHECK_EQ(clone.source_info(), BytecodeSourceInfo(77, false));
|
2016-05-12 19:18:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
} // namespace interpreter
|
|
|
|
} // namespace internal
|
|
|
|
} // namespace v8
|