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