| // Copyright 2018 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. |
| |
| // Flags: --allow-natives-syntax --opt --noalways-opt |
| |
| // Test that JSResolvePromise takes a proper stability dependency |
| // on the resolutions map if the infer receiver maps are unreliable |
| // (as is the case for HeapConstants). |
| (function() { |
| // We need an object literal which gets a stable map initially. |
| function makeObjectWithStableMap() { |
| return {a:1, b:1, c:1}; |
| } |
| const a = makeObjectWithStableMap(); |
| |
| function foo() { |
| return Promise.resolve(a); |
| } |
| |
| %PrepareFunctionForOptimization(foo); |
| assertInstanceof(foo(), Promise); |
| assertInstanceof(foo(), Promise); |
| %OptimizeFunctionOnNextCall(foo); |
| assertInstanceof(foo(), Promise); |
| assertOptimized(foo); |
| |
| // Now invalidate the stability of a's map. |
| const b = makeObjectWithStableMap(); |
| b.d = 1; |
| |
| // This should deoptimize foo. |
| assertUnoptimized(foo); |
| })(); |
| |
| // Same test with async functions. |
| (function() { |
| // We need an object literal which gets a stable map initially, |
| // it needs to be different from the above, otherwise the map |
| // is already not stable when we get here. |
| function makeObjectWithStableMap() { |
| return {x:1, y:1}; |
| } |
| const a = makeObjectWithStableMap(); |
| |
| async function foo() { |
| return a; |
| } |
| |
| %PrepareFunctionForOptimization(foo); |
| assertInstanceof(foo(), Promise); |
| assertInstanceof(foo(), Promise); |
| %OptimizeFunctionOnNextCall(foo); |
| assertInstanceof(foo(), Promise); |
| assertOptimized(foo); |
| |
| // Now invalidate the stability of a's map. |
| const b = makeObjectWithStableMap(); |
| b.z = 1; |
| |
| // This should deoptimize foo. |
| assertUnoptimized(foo); |
| })(); |