From 366bee6fc0df668edce873970183305deae701cd Mon Sep 17 00:00:00 2001 From: Leo Balter <leonardo.balter@gmail.com> Date: Fri, 26 Oct 2018 14:29:57 -0400 Subject: [PATCH] Add template for with expression --- .../invalid/nested-with-expression.template | 30 +++++++++++++++++++ .../valid/nested-with-expression.template | 28 +++++++++++++++++ 2 files changed, 58 insertions(+) create mode 100644 src/dynamic-import/syntax/invalid/nested-with-expression.template create mode 100644 src/dynamic-import/syntax/valid/nested-with-expression.template diff --git a/src/dynamic-import/syntax/invalid/nested-with-expression.template b/src/dynamic-import/syntax/invalid/nested-with-expression.template new file mode 100644 index 0000000000..3178c74e55 --- /dev/null +++ b/src/dynamic-import/syntax/invalid/nested-with-expression.template @@ -0,0 +1,30 @@ +// Copyright (C) 2018 Rick Waldron. All rights reserved. +// Copyright (C) 2018 the V8 project authors. All rights reserved. +// This code is governed by the BSD license found in the LICENSE file. +/*--- +path: language/expressions/dynamic-import/syntax/invalid/nested-with-expression- +name: nested with syntax in the expression position +esid: sec-import-call-runtime-semantics-evaluation +info: | + ImportCall : + import( AssignmentExpression ) + + 1. Let referencingScriptOrModule be ! GetActiveScriptOrModule(). + 2. Assert: referencingScriptOrModule is a Script Record or Module Record (i.e. is not null). + 3. Let argRef be the result of evaluating AssignmentExpression. + 4. Let specifier be ? GetValue(argRef). + 5. Let promiseCapability be ! NewPromiseCapability(%Promise%). + 6. Let specifierString be ToString(specifier). + 7. IfAbruptRejectPromise(specifierString, promiseCapability). + 8. Perform ! HostImportModuleDynamically(referencingScriptOrModule, specifierString, promiseCapability). + 9. Return promiseCapability.[[Promise]]. +features: [dynamic-import] +flags: [noStrict] +negative: + phase: parse + type: SyntaxError +---*/ + +throw "Test262: This statement should not be evaluated."; + +with (/*{ import }*/) {} diff --git a/src/dynamic-import/syntax/valid/nested-with-expression.template b/src/dynamic-import/syntax/valid/nested-with-expression.template new file mode 100644 index 0000000000..c1f1f25a39 --- /dev/null +++ b/src/dynamic-import/syntax/valid/nested-with-expression.template @@ -0,0 +1,28 @@ +// Copyright (C) 2018 Rick Waldron. All rights reserved. +// Copyright (C) 2018 the V8 project authors. All rights reserved. +// This code is governed by the BSD license found in the LICENSE file. +/*--- +path: language/expressions/dynamic-import/syntax/valid/nested-with-expression- +name: nested with syntax in the expression position +esid: sec-import-call-runtime-semantics-evaluation +info: | + ImportCall : + import( AssignmentExpression ) + + 1. Let referencingScriptOrModule be ! GetActiveScriptOrModule(). + 2. Assert: referencingScriptOrModule is a Script Record or Module Record (i.e. is not null). + 3. Let argRef be the result of evaluating AssignmentExpression. + 4. Let specifier be ? GetValue(argRef). + 5. Let promiseCapability be ! NewPromiseCapability(%Promise%). + 6. Let specifierString be ToString(specifier). + 7. IfAbruptRejectPromise(specifierString, promiseCapability). + 8. Perform ! HostImportModuleDynamically(referencingScriptOrModule, specifierString, promiseCapability). + 9. Return promiseCapability.[[Promise]]. +features: [dynamic-import] +flags: [noStrict] +---*/ + +with (/*{ import }*/) { + assert.sameValue(then, Promise.prototype.then); + assert.sameValue(constructor, Promise); +} -- GitLab