summaryrefslogtreecommitdiff
path: root/test/language/expressions/optional-chaining/optional-call-preserves-this.js
diff options
context:
space:
mode:
authorMaximilian Goldstein <max.goldstein@qt.io>2021-04-09 15:03:20 +0200
committerMaximilian Goldstein <max.goldstein@qt.io>2021-04-13 11:45:16 +0000
commit4dad98d63c279b989fdb48006fbd1db8ee27bc7f (patch)
tree40bc5864e3df0edd9960b8acfdc769ff894a24ba /test/language/expressions/optional-chaining/optional-call-preserves-this.js
parent5a105134b9fdf9abc0dc12dc3e44027529634715 (diff)
downloadqtdeclarative-testsuites-snapshot-20180312-3c69133-based.tar.gz
Add optional chaining testssnapshot-20180312-3c69133-based
Change-Id: Ia87313a2756dfbc3d90128ac77cd4dc6c8c137df Reviewed-by: Ulf Hermann <ulf.hermann@qt.io> (cherry picked from commit 7d1cf05c547a636495b2731c4fc2842a01849064) Reviewed-by: Fabian Kosmale <fabian.kosmale@qt.io>
Diffstat (limited to 'test/language/expressions/optional-chaining/optional-call-preserves-this.js')
-rw-r--r--test/language/expressions/optional-chaining/optional-call-preserves-this.js27
1 files changed, 27 insertions, 0 deletions
diff --git a/test/language/expressions/optional-chaining/optional-call-preserves-this.js b/test/language/expressions/optional-chaining/optional-call-preserves-this.js
new file mode 100644
index 000000000..9e1eee629
--- /dev/null
+++ b/test/language/expressions/optional-chaining/optional-call-preserves-this.js
@@ -0,0 +1,27 @@
+// Copyright (C) 2019 Sony Interactive Entertainment Inc. All rights reserved.
+// This code is governed by the BSD license found in the LICENSE file.
+/*---
+esid: sec-optional-chaining-chain-evaluation
+description: >
+ optional call must preserve this context, as with a non-optional call
+info: |
+ OptionalChain : ?. Arguments
+ 1. Let thisChain be this OptionalChain.
+ 2. Let tailCall be IsInTailPosition(thisChain).
+ 3. Return ? EvaluateCall(baseValue, baseReference, Arguments, tailCall).
+features: [optional-chaining]
+---*/
+
+const a = {
+ b() { return this._b; },
+ _b: { c: 42 }
+};
+
+assert.sameValue(a?.b().c, 42);
+assert.sameValue((a?.b)().c, 42);
+
+assert.sameValue(a.b?.().c, 42);
+assert.sameValue((a.b)?.().c, 42);
+
+assert.sameValue(a?.b?.().c, 42);
+assert.sameValue((a?.b)?.().c, 42);