v8/test/mjsunit/regress/regress-unlink-closures-on-deopt.js
Mythri A ae1af6a568 [cleanup] Add %PrepareFunctionForOptimize for tests that use %OptimizeOsr
Bug: v8:8394, v8:8801, v8:9183
Change-Id: I29ff1a6dda97e89335b30fcc8c380bcb4055e1fb
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1664690
Reviewed-by: Ross McIlroy <rmcilroy@chromium.org>
Commit-Queue: Mythri Alle <mythria@chromium.org>
Cr-Commit-Position: refs/heads/master@{#62254}
2019-06-18 16:47:29 +00:00

40 lines
853 B
JavaScript

// Copyright 2017 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 --noalways-opt
function foo() {
function g(o) {
return o.f;
}
return g;
}
let g1 = foo();
let g2 = foo();
%PrepareFunctionForOptimization(g1);
%PrepareFunctionForOptimization(g2);
g1({ f : 1});
g1({ f : 2});
g2({ f : 2});
g2({ f : 2});
%OptimizeFunctionOnNextCall(g1);
%OptimizeFunctionOnNextCall(g2);
g1({ f : 1});
g2({ f : 2});
g1({});
assertUnoptimized(g1);
// Deoptimization of g1 should also deoptimize g2 because they should share
// the optimized code object. (Unfortunately, this test bakes in various
// other assumptions about dealing with optimized code, and thus might break
// in future.)
assertUnoptimized(g2);
g2({});