97fce6214e
A bug in error printing meant that we failed to do proper type checks before calling into C++ code, which could lead to RUNTIME_ASSERT failures if methods are called on alternative receivers. This patch adds the right type checks. BUG=chromium:596718 LOG=Y R=adamk Review URL: https://codereview.chromium.org/1831053003 Cr-Commit-Position: refs/heads/master@{#35069}
13 lines
603 B
JavaScript
13 lines
603 B
JavaScript
// 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.
|
|
|
|
Error.prepareStackTrace = function(e, frames) { return frames; }
|
|
assertThrows(() => new Error().stack[0].getMethodName.call({}), TypeError);
|
|
|
|
Error.prepareStackTrace = function(e, frames) { return frames.map(frame => new Proxy(frame, {})); }
|
|
assertThrows(() => new Error().stack[0].getMethodName(), TypeError);
|
|
|
|
Error.prepareStackTrace = function(e, frames) { return frames; }
|
|
assertEquals(null, new Error().stack[0].getMethodName());
|