7cdf4c69b0
In stress runs a GC may kick in before assertOptimized() is called on the optimized function, causing it to deoptimize and the test would fail even if the function is optimized as expected. Adding --no-stress-flush-code --no-flush-bytecode fixes the timing issue. Bug: v8:12332 Change-Id: If43c2a06e84c0e3b5e21f7bde160340a0fc742f4 Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3237326 Reviewed-by: Leszek Swirski <leszeks@chromium.org> Commit-Queue: Joyee Cheung <joyee@igalia.com> Cr-Commit-Position: refs/heads/main@{#77645}
62 lines
1.8 KiB
JavaScript
62 lines
1.8 KiB
JavaScript
// Copyright 2021 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 --trace-opt --trace-deopt
|
|
// Flags: --no-stress-flush-code --no-flush-bytecode
|
|
let privateSymbol = %CreatePrivateSymbol("private");
|
|
let privateName = %CreatePrivateNameSymbol("privateName");
|
|
|
|
function test() {
|
|
"use strict";
|
|
|
|
// These computed properties are translated into JSStoreDataPropertyInLiteral
|
|
// ops, and AccessInfoFactory::ComputePropertyAccessInfo should find a
|
|
// suitable map transition when optimizing. Even if the implementation details
|
|
// are ignored, we still want to assert that these properties are installed as
|
|
// non-enumerable, due to being private symbols.
|
|
|
|
let obj = {
|
|
[privateSymbol]: "private",
|
|
[privateName]: "privateName",
|
|
};
|
|
|
|
assertPropertiesEqual(Object.getOwnPropertyDescriptor(obj, privateSymbol), {
|
|
value: "private",
|
|
writable: true,
|
|
configurable: true,
|
|
enumerable: false,
|
|
});
|
|
|
|
assertPropertiesEqual(Object.getOwnPropertyDescriptor(obj, privateName), {
|
|
value: "privateName",
|
|
writable: true,
|
|
configurable: true,
|
|
enumerable: false,
|
|
});
|
|
|
|
// They don't leak via Object.keys(), Object.getOwnPropertyNames, or
|
|
// Object.getOwnPropertySymbols
|
|
let props = Object.getOwnPropertyNames(obj);
|
|
assertFalse(props.includes(privateSymbol));
|
|
assertFalse(props.includes(privateName));
|
|
|
|
let symbols = Object.getOwnPropertySymbols(obj);
|
|
assertFalse(symbols.includes(privateSymbol));
|
|
assertFalse(symbols.includes(privateName));
|
|
|
|
let keys = Object.keys(obj);
|
|
assertFalse(keys.includes(privateSymbol));
|
|
assertFalse(keys.includes(privateName));
|
|
|
|
return obj;
|
|
}
|
|
|
|
%PrepareFunctionForOptimization(test);
|
|
test();
|
|
test();
|
|
test();
|
|
%OptimizeFunctionOnNextCall(test);
|
|
test();
|
|
assertOptimized(test);
|