diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-19 00:47:55 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-19 00:47:55 +0000 |
commit | 26a029d407be480d791972afb5975cf62c9360a6 (patch) | |
tree | f435a8308119effd964b339f76abb83a57c29483 /js/src/tests/test262/built-ins/WeakRef/returns-new-object-from-constructor-with-symbol-target.js | |
parent | Initial commit. (diff) | |
download | firefox-26a029d407be480d791972afb5975cf62c9360a6.tar.xz firefox-26a029d407be480d791972afb5975cf62c9360a6.zip |
Adding upstream version 124.0.1.upstream/124.0.1
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'js/src/tests/test262/built-ins/WeakRef/returns-new-object-from-constructor-with-symbol-target.js')
-rw-r--r-- | js/src/tests/test262/built-ins/WeakRef/returns-new-object-from-constructor-with-symbol-target.js | 32 |
1 files changed, 32 insertions, 0 deletions
diff --git a/js/src/tests/test262/built-ins/WeakRef/returns-new-object-from-constructor-with-symbol-target.js b/js/src/tests/test262/built-ins/WeakRef/returns-new-object-from-constructor-with-symbol-target.js new file mode 100644 index 0000000000..5954875ef1 --- /dev/null +++ b/js/src/tests/test262/built-ins/WeakRef/returns-new-object-from-constructor-with-symbol-target.js @@ -0,0 +1,32 @@ +// |reftest| shell-option(--enable-symbols-as-weakmap-keys) skip-if(release_or_beta||!this.hasOwnProperty('WeakRef')||!xulRuntime.shell) -- symbols-as-weakmap-keys is not released yet, WeakRef is not enabled unconditionally, requires shell-options +// Copyright (C) 2022 Igalia, S.L. All rights reserved. +// This code is governed by the BSD license found in the LICENSE file. + +/*--- +esid: sec-weak-ref-target +description: > + Returns a new ordinary object from the WeakRef constructor when called with a + Symbol target +info: | + WeakRef ( _target_ ) + 3. Let _weakRef_ be ? OrdinaryCreateFromConstructor(NewTarget, + *"%WeakRefPrototype%"*, « [[WeakRefTarget]] »). + 4. Perfom AddToKeptObjects(_target_). + 5. Set _weakRef_.[[WeakRefTarget]] to _target_. + 6. Return _weakRef_. +features: [Symbol, WeakRef, symbols-as-weakmap-keys] +---*/ + +var target = Symbol('a description'); +var wr = new WeakRef(target); + +assert.sameValue(wr instanceof WeakRef, true, 'object is instanceof WeakRef'); +assert.sameValue(Object.getPrototypeOf(wr), WeakRef.prototype, 'prototype is WeakRef.prototype'); + +wr = new WeakRef(Symbol.hasInstance); + +assert.sameValue(wr instanceof WeakRef, true, 'object is instanceof WeakRef'); +assert.sameValue(Object.getPrototypeOf(wr), WeakRef.prototype, 'prototype is WeakRef.prototype'); + + +reportCompare(0, 0); |