| OLD | NEW |
| 1 // Copyright 2016 the V8 project authors. All rights reserved. | 1 // Copyright 2016 the V8 project authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "src/wasm/wasm-macro-gen.h" | 5 #include "src/wasm/wasm-macro-gen.h" |
| 6 | 6 |
| 7 #include "test/cctest/cctest.h" | 7 #include "test/cctest/cctest.h" |
| 8 #include "test/cctest/compiler/value-helper.h" | 8 #include "test/cctest/compiler/value-helper.h" |
| 9 #include "test/cctest/wasm/test-signatures.h" | 9 #include "test/cctest/wasm/test-signatures.h" |
| 10 #include "test/cctest/wasm/wasm-run-utils.h" | 10 #include "test/cctest/wasm/wasm-run-utils.h" |
| (...skipping 33 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 44 } | 44 } |
| 45 } | 45 } |
| 46 | 46 |
| 47 struct ExceptionInfo { | 47 struct ExceptionInfo { |
| 48 const char* func_name; | 48 const char* func_name; |
| 49 int line_nr; | 49 int line_nr; |
| 50 int column; | 50 int column; |
| 51 }; | 51 }; |
| 52 | 52 |
| 53 template <int N> | 53 template <int N> |
| 54 void CheckExceptionInfos(Handle<Object> exc, | 54 void CheckExceptionInfos(Isolate* isolate, Handle<Object> exc, |
| 55 const ExceptionInfo (&excInfos)[N]) { | 55 const ExceptionInfo (&excInfos)[N]) { |
| 56 // Check that it's indeed an Error object. | 56 // Check that it's indeed an Error object. |
| 57 CHECK(exc->IsJSError()); | 57 CHECK(Object::IsErrorObject(isolate, exc)); |
| 58 | 58 |
| 59 // Extract stack frame from the exception. | 59 // Extract stack frame from the exception. |
| 60 Local<v8::Value> localExc = Utils::ToLocal(exc); | 60 Local<v8::Value> localExc = Utils::ToLocal(exc); |
| 61 v8::Local<v8::StackTrace> stack = v8::Exception::GetStackTrace(localExc); | 61 v8::Local<v8::StackTrace> stack = v8::Exception::GetStackTrace(localExc); |
| 62 PrintStackTrace(stack); | 62 PrintStackTrace(stack); |
| 63 CHECK(!stack.IsEmpty()); | 63 CHECK(!stack.IsEmpty()); |
| 64 CHECK_EQ(N, stack->GetFrameCount()); | 64 CHECK_EQ(N, stack->GetFrameCount()); |
| 65 | 65 |
| 66 for (int frameNr = 0; frameNr < N; ++frameNr) { | 66 for (int frameNr = 0; frameNr < N; ++frameNr) { |
| 67 v8::Local<v8::StackFrame> frame = stack->GetFrame(frameNr); | 67 v8::Local<v8::StackFrame> frame = stack->GetFrame(frameNr); |
| (...skipping 43 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 111 CHECK(returnObjMaybe.is_null()); | 111 CHECK(returnObjMaybe.is_null()); |
| 112 | 112 |
| 113 // The column is 1-based, so add 1 to the actual byte offset. | 113 // The column is 1-based, so add 1 to the actual byte offset. |
| 114 ExceptionInfo expected_exceptions[] = { | 114 ExceptionInfo expected_exceptions[] = { |
| 115 {"a", 3, 8}, // - | 115 {"a", 3, 8}, // - |
| 116 {"js", 4, 2}, // - | 116 {"js", 4, 2}, // - |
| 117 {"<WASM UNNAMED>", static_cast<int>(wasm_index), 3}, // - | 117 {"<WASM UNNAMED>", static_cast<int>(wasm_index), 3}, // - |
| 118 {"<WASM UNNAMED>", static_cast<int>(wasm_index_2), 2}, // - | 118 {"<WASM UNNAMED>", static_cast<int>(wasm_index_2), 2}, // - |
| 119 {"callFn", 1, 24} // - | 119 {"callFn", 1, 24} // - |
| 120 }; | 120 }; |
| 121 CheckExceptionInfos(maybe_exc.ToHandleChecked(), expected_exceptions); | 121 CheckExceptionInfos(isolate, maybe_exc.ToHandleChecked(), |
| 122 expected_exceptions); |
| 122 } | 123 } |
| 123 | 124 |
| 124 // Trigger a trap in WASM, stack should be JS -> WASM -> WASM. | 125 // Trigger a trap in WASM, stack should be JS -> WASM -> WASM. |
| 125 TEST(CollectDetailedWasmStack_WasmError) { | 126 TEST(CollectDetailedWasmStack_WasmError) { |
| 126 TestSignatures sigs; | 127 TestSignatures sigs; |
| 127 TestingModule module; | 128 TestingModule module; |
| 128 | 129 |
| 129 WasmFunctionCompiler comp1(sigs.i_v(), &module, | 130 WasmFunctionCompiler comp1(sigs.i_v(), &module, |
| 130 ArrayVector("exec_unreachable")); | 131 ArrayVector("exec_unreachable")); |
| 131 // Set the execution context, such that a runtime error can be thrown. | 132 // Set the execution context, such that a runtime error can be thrown. |
| (...skipping 21 matching lines...) Expand all Loading... |
| 153 MaybeHandle<Object> maybe_return_obj = | 154 MaybeHandle<Object> maybe_return_obj = |
| 154 Execution::TryCall(isolate, js_trampoline, global, 1, args, &maybe_exc); | 155 Execution::TryCall(isolate, js_trampoline, global, 1, args, &maybe_exc); |
| 155 CHECK(maybe_return_obj.is_null()); | 156 CHECK(maybe_return_obj.is_null()); |
| 156 | 157 |
| 157 // The column is 1-based, so add 1 to the actual byte offset. | 158 // The column is 1-based, so add 1 to the actual byte offset. |
| 158 ExceptionInfo expected_exceptions[] = { | 159 ExceptionInfo expected_exceptions[] = { |
| 159 {"<WASM UNNAMED>", static_cast<int>(wasm_index), 2}, // - | 160 {"<WASM UNNAMED>", static_cast<int>(wasm_index), 2}, // - |
| 160 {"<WASM UNNAMED>", static_cast<int>(wasm_index_2), 2}, // - | 161 {"<WASM UNNAMED>", static_cast<int>(wasm_index_2), 2}, // - |
| 161 {"callFn", 1, 24} //- | 162 {"callFn", 1, 24} //- |
| 162 }; | 163 }; |
| 163 CheckExceptionInfos(maybe_exc.ToHandleChecked(), expected_exceptions); | 164 CheckExceptionInfos(isolate, maybe_exc.ToHandleChecked(), |
| 165 expected_exceptions); |
| 164 } | 166 } |
| OLD | NEW |