Index: test/unittests/interpreter/bytecodes-unittest.cc |
diff --git a/test/unittests/interpreter/bytecodes-unittest.cc b/test/unittests/interpreter/bytecodes-unittest.cc |
index ec31c91cc6976885e047b61942b9391bc630bfb2..baf1e915e05908440cb5f0392aa9349794283fd3 100644 |
--- a/test/unittests/interpreter/bytecodes-unittest.cc |
+++ b/test/unittests/interpreter/bytecodes-unittest.cc |
@@ -6,8 +6,8 @@ |
#include "src/v8.h" |
+#include "src/interpreter/bytecode-register.h" |
#include "src/interpreter/bytecodes.h" |
-#include "test/unittests/interpreter/bytecode-utils.h" |
#include "test/unittests/test-utils.h" |
namespace v8 { |
@@ -146,72 +146,6 @@ TEST(Bytecodes, DebugBreakExistForEachBytecode) { |
#undef CHECK_DEBUG_BREAK_SIZE |
} |
-TEST(Bytecodes, DecodeBytecodeAndOperands) { |
- struct BytecodesAndResult { |
- const uint8_t bytecode[32]; |
- const size_t length; |
- int parameter_count; |
- const char* output; |
- }; |
- |
- const BytecodesAndResult cases[] = { |
- {{B(LdaSmi), U8(1)}, 2, 0, " LdaSmi [1]"}, |
- {{B(Wide), B(LdaSmi), U16(1000)}, 4, 0, " LdaSmi.Wide [1000]"}, |
- {{B(ExtraWide), B(LdaSmi), U32(100000)}, |
- 6, |
- 0, |
- "LdaSmi.ExtraWide [100000]"}, |
- {{B(LdaSmi), U8(-1)}, 2, 0, " LdaSmi [-1]"}, |
- {{B(Wide), B(LdaSmi), U16(-1000)}, 4, 0, " LdaSmi.Wide [-1000]"}, |
- {{B(ExtraWide), B(LdaSmi), U32(-100000)}, |
- 6, |
- 0, |
- "LdaSmi.ExtraWide [-100000]"}, |
- {{B(Star), R8(5)}, 2, 0, " Star r5"}, |
- {{B(Wide), B(Star), R16(136)}, 4, 0, " Star.Wide r136"}, |
- {{B(Wide), B(Call), R16(134), R16(135), U16(2), U16(177)}, |
- 10, |
- 0, |
- "Call.Wide r134, r135, #2, [177]"}, |
- {{B(Ldar), |
- static_cast<uint8_t>(Register::FromParameterIndex(2, 3).ToOperand())}, |
- 2, |
- 3, |
- " Ldar a1"}, |
- {{B(Wide), B(CreateObjectLiteral), U16(513), U16(1027), U8(165)}, |
- 7, |
- 0, |
- "CreateObjectLiteral.Wide [513], [1027], #165"}, |
- {{B(ExtraWide), B(JumpIfNull), U32(123456789)}, |
- 6, |
- 0, |
- "JumpIfNull.ExtraWide [123456789]"}, |
- }; |
- |
- for (size_t i = 0; i < arraysize(cases); ++i) { |
- // Generate reference string by prepending formatted bytes. |
- std::stringstream expected_ss; |
- std::ios default_format(nullptr); |
- default_format.copyfmt(expected_ss); |
- // Match format of Bytecodes::Decode() for byte representations. |
- expected_ss.fill('0'); |
- expected_ss.flags(std::ios::right | std::ios::hex); |
- for (size_t b = 0; b < cases[i].length; b++) { |
- expected_ss << std::setw(2) << static_cast<uint32_t>(cases[i].bytecode[b]) |
- << ' '; |
- } |
- expected_ss.copyfmt(default_format); |
- expected_ss << cases[i].output; |
- |
- // Generate decoded byte output. |
- std::stringstream actual_ss; |
- Bytecodes::Decode(actual_ss, cases[i].bytecode, cases[i].parameter_count); |
- |
- // Compare. |
- CHECK_EQ(actual_ss.str(), expected_ss.str()); |
- } |
-} |
- |
TEST(Bytecodes, DebugBreakForPrefixBytecodes) { |
CHECK_EQ(Bytecode::kDebugBreakWide, |
Bytecodes::GetDebugBreak(Bytecode::kWide)); |