Index: test/unittests/interpreter/bytecode-decoder-unittest.cc |
diff --git a/test/unittests/interpreter/bytecode-decoder-unittest.cc b/test/unittests/interpreter/bytecode-decoder-unittest.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..4e60a6e7d20ac4b8130023236c853c95345b7af2 |
--- /dev/null |
+++ b/test/unittests/interpreter/bytecode-decoder-unittest.cc |
@@ -0,0 +1,86 @@ |
+// Copyright 2015 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 <vector> |
+ |
+#include "src/v8.h" |
+ |
+#include "src/interpreter/bytecode-decoder.h" |
+#include "test/unittests/interpreter/bytecode-utils.h" |
+#include "test/unittests/test-utils.h" |
+ |
+namespace v8 { |
+namespace internal { |
+namespace interpreter { |
+ |
+TEST(BytecodeDecoder, 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 BytecodeDecoder::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; |
+ BytecodeDecoder::Decode(actual_ss, cases[i].bytecode, |
+ cases[i].parameter_count); |
+ |
+ // Compare. |
+ CHECK_EQ(actual_ss.str(), expected_ss.str()); |
+ } |
+} |
+ |
+} // namespace interpreter |
+} // namespace internal |
+} // namespace v8 |