a9e70a6ffc
The information that such functions must be parsed in module mode didn't get properly propagated. Also refactor some related code to make it more robust. In particular, set parsing_module_ at parser construction time only. Bug: v8:1569, v8:6919 Change-Id: Id136fb15c240373cad07c82025b778d0c0c43148 Reviewed-on: https://chromium-review.googlesource.com/716478 Commit-Queue: Georg Neis <neis@chromium.org> Reviewed-by: Marja Hölttä <marja@chromium.org> Reviewed-by: Sathya Gunasekaran <gsathya@chromium.org> Reviewed-by: Yang Guo <yangguo@chromium.org> Reviewed-by: Adam Klein <adamk@chromium.org> Cr-Commit-Position: refs/heads/master@{#48811}
45 lines
1.5 KiB
JavaScript
45 lines
1.5 KiB
JavaScript
// Copyright 2017 the V8 project authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
// found in the LICENSE file.
|
|
|
|
// MODULE
|
|
// Flags: --harmony-import-meta
|
|
|
|
import foreign, { url as otherUrl } from './modules-skip-export-import-meta.js';
|
|
|
|
assertEquals("object", typeof import.meta);
|
|
assertEquals(null, Object.getPrototypeOf(import.meta));
|
|
assertSame(import.meta, import.meta);
|
|
|
|
const loadImportMetaArrow = () => import.meta;
|
|
assertSame(loadImportMetaArrow(), import.meta);
|
|
function loadImportMetaFn() {
|
|
try {
|
|
throw new Error('force catch code path for nested context');
|
|
} catch (e) {
|
|
return import.meta;
|
|
}
|
|
}
|
|
loadImportMetaFn();
|
|
assertSame(loadImportMetaFn(), import.meta);
|
|
|
|
// This property isn't part of the spec itself but is mentioned as an example
|
|
assertMatches(/\/modules-import-meta\.js$/, import.meta.url);
|
|
|
|
import.meta.x = 42;
|
|
assertEquals(42, import.meta.x);
|
|
Object.assign(import.meta, { foo: "bar" })
|
|
assertEquals("bar", import.meta.foo);
|
|
|
|
// PerformEval parses its argument for the goal symbol Script. So the following
|
|
// should fail just as it does for every other Script context.
|
|
//
|
|
// See:
|
|
// https://github.com/tc39/proposal-import-meta/issues/7#issuecomment-329363083
|
|
assertThrows(() => eval('import.meta'), SyntaxError);
|
|
assertThrows(() => new Function('return import.meta;'), SyntaxError);
|
|
|
|
assertNotEquals(foreign, import.meta);
|
|
assertMatches(/\/modules-skip-export-import-meta\.js$/, foreign.url);
|
|
assertEquals(foreign.url, otherUrl);
|