[class] Expand bytecode expectations coverage for class fields

Bug: v8:5367
Change-Id: Ib24190f6cfc0765794a1a5d9ac33cf1c1e2b6fba
Reviewed-on: https://chromium-review.googlesource.com/793150
Reviewed-by: Mythri Alle <mythria@chromium.org>
Commit-Queue: Sathya Gunasekaran <gsathya@chromium.org>
Cr-Commit-Position: refs/heads/master@{#49665}
This commit is contained in:
Sathya Gunasekaran 2017-11-28 13:27:07 +01:00 committed by Commit Bot
parent 301bc628d6
commit 42bc9e8c64
3 changed files with 302 additions and 89 deletions

View File

@ -6,25 +6,155 @@
wrap: yes
public fields: yes
---
snippet: "
{
class A {
a;
['b'];
static c;
static ['d'];
}
class B {
a = 1;
['b'] = this.a;
static c = 3;
static ['d'] = this.c;
}
new A;
new B;
}
"
frame size: 11
parameter count: 1
bytecode array length: 193
bytecodes: [
/* 30 E> */ B(StackCheck),
B(Ldar), R(closure),
B(CreateBlockContext), U8(0),
B(PushContext), R(4),
B(LdaTheHole),
B(StaCurrentContextSlot), U8(4),
B(LdaTheHole),
B(StaCurrentContextSlot), U8(5),
B(LdaTheHole),
B(Star), R(8),
B(CreateClosure), U8(2), U8(0), U8(2),
B(Star), R(5),
B(LdaConstant), U8(1),
B(Star), R(6),
B(LdaConstant), U8(3),
B(StaCurrentContextSlot), U8(4),
B(Star), R(9),
B(LdaConstant), U8(4),
B(Star), R(10),
B(LdaConstant), U8(5),
B(TestEqualStrictNoFeedback), R(10),
B(Mov), R(5), R(7),
B(JumpIfFalse), U8(7),
B(CallRuntime), U16(Runtime::kThrowStaticPrototypeError), R(0), U8(0),
B(Ldar), R(10),
B(StaCurrentContextSlot), U8(5),
B(CallRuntime), U16(Runtime::kDefineClass), R(6), U8(5),
B(Star), R(6),
B(Mov), R(5), R(1),
B(CreateClosure), U8(6), U8(1), U8(2),
B(Star), R(7),
B(StaNamedProperty), R(5), U8(7), U8(2),
B(CreateClosure), U8(8), U8(4), U8(2),
B(Star), R(9),
B(CallProperty0), R(9), R(1), U8(5),
B(PopContext), R(4),
B(Mov), R(1), R(2),
B(Ldar), R(closure),
/* 38 E> */ B(CreateBlockContext), U8(9),
B(PushContext), R(4),
B(LdaTheHole),
B(StaCurrentContextSlot), U8(4),
B(LdaTheHole),
B(StaCurrentContextSlot), U8(5),
B(LdaTheHole),
B(Star), R(8),
B(CreateClosure), U8(11), U8(7), U8(2),
B(Star), R(5),
B(LdaConstant), U8(10),
B(Star), R(6),
B(LdaConstant), U8(3),
B(StaCurrentContextSlot), U8(4),
B(Star), R(9),
B(LdaConstant), U8(4),
B(Star), R(10),
B(LdaConstant), U8(5),
B(TestEqualStrictNoFeedback), R(10),
B(Mov), R(5), R(7),
B(JumpIfFalse), U8(7),
B(CallRuntime), U16(Runtime::kThrowStaticPrototypeError), R(0), U8(0),
B(Ldar), R(10),
B(StaCurrentContextSlot), U8(5),
B(CallRuntime), U16(Runtime::kDefineClass), R(6), U8(5),
B(Star), R(6),
B(Mov), R(5), R(0),
B(CreateClosure), U8(12), U8(8), U8(2),
B(Star), R(7),
B(StaNamedProperty), R(5), U8(7), U8(9),
B(CreateClosure), U8(13), U8(11), U8(2),
B(Star), R(9),
B(CallProperty0), R(9), R(0), U8(12),
B(PopContext), R(4),
B(Mov), R(0), R(3),
/* 197 S> */ B(Ldar), R(2),
/* 197 E> */ B(Construct), R(2), R(0), U8(0), U8(14),
/* 206 S> */ B(Ldar), R(0),
/* 206 E> */ B(Construct), R(0), R(0), U8(0), U8(16),
B(LdaUndefined),
/* 215 S> */ B(Return),
]
constant pool: [
FIXED_ARRAY_TYPE,
FIXED_ARRAY_TYPE,
SHARED_FUNCTION_INFO_TYPE,
ONE_BYTE_INTERNALIZED_STRING_TYPE ["b"],
ONE_BYTE_INTERNALIZED_STRING_TYPE ["d"],
ONE_BYTE_INTERNALIZED_STRING_TYPE ["prototype"],
SHARED_FUNCTION_INFO_TYPE,
SYMBOL_TYPE,
SHARED_FUNCTION_INFO_TYPE,
FIXED_ARRAY_TYPE,
FIXED_ARRAY_TYPE,
SHARED_FUNCTION_INFO_TYPE,
SHARED_FUNCTION_INFO_TYPE,
SHARED_FUNCTION_INFO_TYPE,
]
handlers: [
]
---
snippet: "
{
class A extends class {} {
a;
['b'];
static c;
static ['d'];
}
class B extends class {} {
a = 1;
['b'] = this.a;
static c = 3;
static ['d'] = this.c;
foo() { return 1; }
constructor() {
super();
}
}
class C extends class {} {
class C extends B {
a = 1;
['b'] = this.a;
static c = 3;
static ['d'] = super.foo();
constructor() {
(() => super())();
}
@ -35,115 +165,173 @@ snippet: "
new C;
}
"
frame size: 14
frame size: 15
parameter count: 1
bytecode array length: 240
bytecode array length: 346
bytecodes: [
/* 30 E> */ B(StackCheck),
B(Ldar), R(closure),
B(CreateBlockContext), U8(0),
B(PushContext), R(6),
B(LdaTheHole),
B(Star), R(13),
B(CreateClosure), U8(2), U8(0), U8(2),
B(Star), R(10),
B(StaCurrentContextSlot), U8(4),
B(LdaTheHole),
B(StaCurrentContextSlot), U8(5),
B(LdaTheHole),
B(Star), R(14),
B(CreateClosure), U8(3), U8(0), U8(2),
B(Star), R(11),
B(LdaConstant), U8(2),
B(Star), R(12),
B(Mov), R(11), R(13),
B(CallRuntime), U16(Runtime::kDefineClass), R(12), U8(3),
B(Star), R(12),
B(CreateClosure), U8(4), U8(1), U8(2),
B(Star), R(7),
B(LdaConstant), U8(1),
B(Star), R(11),
B(Mov), R(10), R(12),
B(CallRuntime), U16(Runtime::kDefineClass), R(11), U8(3),
B(Star), R(11),
B(CreateClosure), U8(3), U8(1), U8(2),
B(Star), R(6),
B(LdaConstant), U8(0),
B(Star), R(7),
B(Mov), R(6), R(8),
B(Mov), R(12), R(9),
B(CallRuntime), U16(Runtime::kDefineClass), R(7), U8(3),
B(Star), R(7),
B(Mov), R(8), R(2),
B(CreateClosure), U8(4), U8(2), U8(2),
B(Star), R(8),
B(StaNamedProperty), R(6), U8(5), U8(3),
B(CreateClosure), U8(6), U8(5), U8(2),
B(Star), R(10),
B(CallProperty0), R(10), R(2), U8(6),
B(Mov), R(2), R(3),
B(LdaTheHole),
B(Star), R(13),
/* 38 E> */ B(CreateClosure), U8(9), U8(8), U8(2),
B(Star), R(10),
B(LdaConstant), U8(8),
B(LdaConstant), U8(5),
B(StaCurrentContextSlot), U8(4),
B(Star), R(11),
B(Mov), R(10), R(12),
B(CallRuntime), U16(Runtime::kDefineClass), R(11), U8(3),
B(Star), R(11),
B(CreateClosure), U8(10), U8(9), U8(2),
B(Star), R(6),
B(LdaConstant), U8(6),
B(Star), R(12),
B(LdaConstant), U8(7),
B(Star), R(7),
B(Mov), R(6), R(8),
B(Mov), R(12), R(9),
B(CallRuntime), U16(Runtime::kDefineClass), R(7), U8(3),
B(Star), R(7),
B(Mov), R(8), R(1),
B(CreateClosure), U8(11), U8(10), U8(2),
B(TestEqualStrictNoFeedback), R(12),
B(Mov), R(13), R(10),
B(Mov), R(7), R(9),
B(JumpIfFalse), U8(7),
B(CallRuntime), U16(Runtime::kThrowStaticPrototypeError), R(0), U8(0),
B(Ldar), R(12),
B(StaCurrentContextSlot), U8(5),
B(CallRuntime), U16(Runtime::kDefineClass), R(8), U8(5),
B(Star), R(8),
B(StaNamedProperty), R(6), U8(5), U8(11),
B(CreateClosure), U8(12), U8(13), U8(2),
B(Star), R(10),
B(CallProperty0), R(10), R(1), U8(14),
B(Mov), R(1), R(4),
B(Mov), R(7), R(2),
B(CreateClosure), U8(8), U8(2), U8(2),
B(Star), R(9),
B(StaNamedProperty), R(7), U8(9), U8(3),
B(CreateClosure), U8(10), U8(5), U8(2),
B(Star), R(11),
B(CallProperty0), R(11), R(2), U8(6),
B(PopContext), R(6),
B(Mov), R(2), R(3),
B(Ldar), R(closure),
/* 38 E> */ B(CreateBlockContext), U8(11),
B(PushContext), R(6),
B(LdaTheHole),
B(Star), R(13),
/* 93 E> */ B(CreateClosure), U8(15), U8(16), U8(2),
B(Star), R(10),
B(LdaConstant), U8(14),
B(StaCurrentContextSlot), U8(4),
B(LdaTheHole),
B(StaCurrentContextSlot), U8(5),
B(LdaTheHole),
B(Star), R(14),
B(CreateClosure), U8(14), U8(8), U8(2),
B(Star), R(11),
B(Mov), R(10), R(12),
B(CallRuntime), U16(Runtime::kDefineClass), R(11), U8(3),
B(Star), R(11),
B(CreateClosure), U8(16), U8(17), U8(2),
B(Star), R(6),
B(LdaConstant), U8(13),
B(Star), R(12),
B(Mov), R(11), R(13),
B(CallRuntime), U16(Runtime::kDefineClass), R(12), U8(3),
B(Star), R(12),
B(CreateClosure), U8(15), U8(9), U8(2),
B(Star), R(7),
B(Mov), R(6), R(8),
B(Mov), R(12), R(9),
B(CallRuntime), U16(Runtime::kDefineClass), R(7), U8(3),
B(Star), R(7),
B(Mov), R(8), R(0),
B(CreateClosure), U8(17), U8(18), U8(2),
B(LdaConstant), U8(12),
B(Star), R(8),
B(StaNamedProperty), R(6), U8(5), U8(19),
B(CreateClosure), U8(18), U8(21), U8(2),
B(Star), R(10),
B(CallProperty0), R(10), R(0), U8(22),
B(LdaConstant), U8(5),
B(StaCurrentContextSlot), U8(4),
B(Star), R(11),
B(LdaConstant), U8(6),
B(Star), R(12),
B(LdaConstant), U8(7),
B(TestEqualStrictNoFeedback), R(12),
B(Mov), R(7), R(9),
B(Mov), R(13), R(10),
B(JumpIfFalse), U8(7),
B(CallRuntime), U16(Runtime::kThrowStaticPrototypeError), R(0), U8(0),
B(Ldar), R(12),
B(StaCurrentContextSlot), U8(5),
B(CreateClosure), U8(16), U8(10), U8(2),
B(Star), R(13),
B(CallRuntime), U16(Runtime::kDefineClass), R(8), U8(6),
B(Star), R(8),
B(Mov), R(7), R(1),
B(CreateClosure), U8(17), U8(11), U8(2),
B(Star), R(9),
B(StaNamedProperty), R(7), U8(9), U8(12),
B(CreateClosure), U8(18), U8(14), U8(2),
B(Star), R(11),
B(CallProperty0), R(11), R(1), U8(15),
B(PopContext), R(6),
B(Mov), R(1), R(4),
B(Ldar), R(closure),
/* 122 E> */ B(CreateBlockContext), U8(19),
B(PushContext), R(6),
B(LdaTheHole),
B(StaCurrentContextSlot), U8(4),
B(LdaTheHole),
B(StaCurrentContextSlot), U8(5),
/* 313 E> */ B(CreateClosure), U8(21), U8(17), U8(2),
B(Star), R(7),
B(LdaConstant), U8(20),
B(Star), R(8),
B(LdaConstant), U8(5),
B(StaCurrentContextSlot), U8(4),
B(Star), R(11),
B(LdaConstant), U8(6),
B(Star), R(12),
B(LdaConstant), U8(7),
B(TestEqualStrictNoFeedback), R(12),
B(Mov), R(1), R(10),
B(Mov), R(7), R(9),
B(JumpIfFalse), U8(7),
B(CallRuntime), U16(Runtime::kThrowStaticPrototypeError), R(0), U8(0),
B(Ldar), R(12),
B(StaCurrentContextSlot), U8(5),
B(CallRuntime), U16(Runtime::kDefineClass), R(8), U8(5),
B(Star), R(8),
B(Mov), R(7), R(0),
B(CreateClosure), U8(22), U8(18), U8(2),
B(Star), R(9),
B(StaNamedProperty), R(7), U8(9), U8(19),
B(CreateClosure), U8(23), U8(21), U8(2),
B(Star), R(11),
B(Ldar), R(0),
B(StaNamedProperty), R(11), U8(24), U8(22),
B(CallProperty0), R(11), R(0), U8(24),
B(PopContext), R(6),
B(Mov), R(0), R(5),
/* 311 S> */ B(Ldar), R(2),
/* 311 E> */ B(Construct), R(2), R(0), U8(0), U8(24),
/* 320 S> */ B(Ldar), R(1),
/* 320 E> */ B(Construct), R(1), R(0), U8(0), U8(26),
/* 329 S> */ B(Ldar), R(0),
/* 329 E> */ B(Construct), R(0), R(0), U8(0), U8(28),
/* 456 S> */ B(Ldar), R(3),
/* 456 E> */ B(Construct), R(3), R(0), U8(0), U8(26),
/* 465 S> */ B(Ldar), R(4),
/* 465 E> */ B(Construct), R(4), R(0), U8(0), U8(28),
/* 474 S> */ B(Ldar), R(0),
/* 474 E> */ B(Construct), R(0), R(0), U8(0), U8(30),
B(LdaUndefined),
/* 338 S> */ B(Return),
/* 483 S> */ B(Return),
]
constant pool: [
FIXED_ARRAY_TYPE,
FIXED_ARRAY_TYPE,
FIXED_ARRAY_TYPE,
SHARED_FUNCTION_INFO_TYPE,
SHARED_FUNCTION_INFO_TYPE,
ONE_BYTE_INTERNALIZED_STRING_TYPE ["b"],
ONE_BYTE_INTERNALIZED_STRING_TYPE ["d"],
ONE_BYTE_INTERNALIZED_STRING_TYPE ["prototype"],
SHARED_FUNCTION_INFO_TYPE,
SYMBOL_TYPE,
SHARED_FUNCTION_INFO_TYPE,
FIXED_ARRAY_TYPE,
FIXED_ARRAY_TYPE,
FIXED_ARRAY_TYPE,
SHARED_FUNCTION_INFO_TYPE,
SHARED_FUNCTION_INFO_TYPE,
SHARED_FUNCTION_INFO_TYPE,
SHARED_FUNCTION_INFO_TYPE,
SHARED_FUNCTION_INFO_TYPE,
FIXED_ARRAY_TYPE,
FIXED_ARRAY_TYPE,
SHARED_FUNCTION_INFO_TYPE,
SHARED_FUNCTION_INFO_TYPE,
SHARED_FUNCTION_INFO_TYPE,
SYMBOL_TYPE,
SHARED_FUNCTION_INFO_TYPE,
FIXED_ARRAY_TYPE,
FIXED_ARRAY_TYPE,
SHARED_FUNCTION_INFO_TYPE,
SHARED_FUNCTION_INFO_TYPE,
SHARED_FUNCTION_INFO_TYPE,
SHARED_FUNCTION_INFO_TYPE,
FIXED_ARRAY_TYPE,
FIXED_ARRAY_TYPE,
SHARED_FUNCTION_INFO_TYPE,
SHARED_FUNCTION_INFO_TYPE,
SHARED_FUNCTION_INFO_TYPE,
SHARED_FUNCTION_INFO_TYPE,
]
handlers: [
]

View File

@ -278,8 +278,8 @@ void ProgramOptions::UpdateFromHeader(std::istream& stream) {
do_expressions_ = ParseBoolean(line.c_str() + 16);
} else if (line.compare(0, 17, "async iteration: ") == 0) {
async_iteration_ = ParseBoolean(line.c_str() + 17);
} else if (line.compare(0, 14, "public fields: ") == 0) {
public_fields_ = ParseBoolean(line.c_str() + 14);
} else if (line.compare(0, 15, "public fields: ") == 0) {
public_fields_ = ParseBoolean(line.c_str() + 15);
} else if (line == "---") {
break;
} else if (line.empty()) {

View File

@ -2240,23 +2240,48 @@ TEST(ClassFields) {
BytecodeExpectationsPrinter printer(CcTest::isolate());
const char* snippets[] = {
"{\n"
" class A {\n"
" a;\n"
" ['b'];\n"
" static c;\n"
" static ['d'];\n"
" }\n"
"\n"
" class B {\n"
" a = 1;\n"
" ['b'] = this.a;\n"
" static c = 3;\n"
" static ['d'] = this.c;\n"
" }\n"
" new A;\n"
" new B;\n"
"}\n",
"{\n"
" class A extends class {} {\n"
" a;\n"
" ['b'];\n"
" static c;\n"
" static ['d'];\n"
" }\n"
"\n"
" class B extends class {} {\n"
" a = 1;\n"
" ['b'] = this.a;\n"
" static c = 3;\n"
" static ['d'] = this.c;\n"
" foo() { return 1; }\n"
" constructor() {\n"
" super();\n"
" }\n"
" }\n"
"\n"
" class C extends class {} {\n"
" class C extends B {\n"
" a = 1;\n"
" ['b'] = this.a;\n"
" static c = 3;\n"
" static ['d'] = super.foo();\n"
" constructor() {\n"
" (() => super())();\n"
" }\n"