summaryrefslogtreecommitdiffstats
path: root/js/src/tests/test262/language/expressions/assignment/dstr/obj-id-init-fn-name-cover.js
diff options
context:
space:
mode:
Diffstat (limited to 'js/src/tests/test262/language/expressions/assignment/dstr/obj-id-init-fn-name-cover.js')
-rw-r--r--js/src/tests/test262/language/expressions/assignment/dstr/obj-id-init-fn-name-cover.js46
1 files changed, 46 insertions, 0 deletions
diff --git a/js/src/tests/test262/language/expressions/assignment/dstr/obj-id-init-fn-name-cover.js b/js/src/tests/test262/language/expressions/assignment/dstr/obj-id-init-fn-name-cover.js
new file mode 100644
index 0000000000..53d2ac1f63
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/assignment/dstr/obj-id-init-fn-name-cover.js
@@ -0,0 +1,46 @@
+// This file was procedurally generated from the following sources:
+// - src/dstr-assignment/obj-id-init-fn-name-cover.case
+// - src/dstr-assignment/default/assignment-expr.template
+/*---
+description: Assignment of function `name` attribute (CoverParenthesizedExpression) (AssignmentExpression)
+esid: sec-variable-statement-runtime-semantics-evaluation
+features: [destructuring-binding]
+flags: [generated]
+includes: [propertyHelper.js]
+info: |
+ VariableDeclaration : BindingPattern Initializer
+
+ 1. Let rhs be the result of evaluating Initializer.
+ 2. Let rval be GetValue(rhs).
+ 3. ReturnIfAbrupt(rval).
+ 4. Return the result of performing BindingInitialization for
+ BindingPattern passing rval and undefined as arguments.
+
+ AssignmentProperty : IdentifierReference Initializeropt
+ [...] 6. If Initializeropt is present and v is undefined, then
+ [...]
+ d. If IsAnonymousFunctionDefinition(Initializer) is true, then
+ i. Let hasNameProperty be HasOwnProperty(v, "name").
+ ii. ReturnIfAbrupt(hasNameProperty).
+ iii. If hasNameProperty is false, perform SetFunctionName(v, P).
+
+---*/
+var xCover, cover;
+
+var result;
+var vals = {};
+
+result = { xCover = (0, function() {}), cover = (function() {}) } = vals;
+
+assert.notSameValue(xCover.name, 'xCover');
+
+verifyProperty(cover, 'name', {
+ enumerable: false,
+ writable: false,
+ configurable: true,
+ value: 'cover'
+});
+
+assert.sameValue(result, vals);
+
+reportCompare(0, 0);