v8/test/mjsunit/compiler/store-data-property-in-literal-private.js
Joyee Cheung 7cdf4c69b0 Fix flakes in store-data-property-in-literal-private.js
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}
2021-11-02 11:44:01 +00:00

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);