[gjs/esm/static-imports: 1/2] tests: Add ES module static import tests




commit d84bbb60e0a5a0b967c94587e2f8a3f13a6512f3
Author: Philip Chimento <philip chimento gmail com>
Date:   Wed Dec 9 15:12:37 2020 -0800

    tests: Add ES module static import tests
    
    Adds an '-m' flag to minijasmine, to execute the given file as a module.
    (No fancy command line parsing is done; the -m must come after the file
    name.)

 .clang-format                                |  1 +
 installed-tests/esm-test.sh                  | 25 ------------------
 installed-tests/esm.test.in                  |  4 ---
 installed-tests/esm/.eslintrc.yml            |  5 ----
 installed-tests/esm/default-import.js        |  3 ---
 installed-tests/esm/default-import.js.output |  1 -
 installed-tests/esm/exports.js               |  3 ---
 installed-tests/esm/gi-import.js             |  3 ---
 installed-tests/esm/gi-import.js.output      |  1 -
 installed-tests/esm/named-import.js          |  3 ---
 installed-tests/esm/named-import.js.output   |  1 -
 installed-tests/esm/system-import.js         |  3 ---
 installed-tests/esm/system-import.js.output  |  3 ---
 installed-tests/js/.eslintrc.yml             |  6 +++++
 installed-tests/js/jsunit.gresources.xml     |  1 +
 installed-tests/js/meson.build               | 19 ++++++++++++++
 installed-tests/js/modules/exports.js        |  6 +++++
 installed-tests/js/testESModules.js          | 26 +++++++++++++++++++
 installed-tests/meson.build                  | 39 ----------------------------
 installed-tests/minijasmine-module.test.in   |  7 +++++
 installed-tests/minijasmine.cpp              | 17 +++++++++---
 21 files changed, 79 insertions(+), 98 deletions(-)
---
diff --git a/.clang-format b/.clang-format
index deed826d..21a71334 100644
--- a/.clang-format
+++ b/.clang-format
@@ -25,4 +25,5 @@ SpacesBeforeTrailingComments: 2
 # operate on diffs like clang-format does.
 Language: JavaScript
 DisableFormat: true
+SortIncludes: false  # https://bugs.llvm.org/show_bug.cgi?id=27042
 ...
diff --git a/installed-tests/js/.eslintrc.yml b/installed-tests/js/.eslintrc.yml
index a9c37e58..2ecbdb1c 100644
--- a/installed-tests/js/.eslintrc.yml
+++ b/installed-tests/js/.eslintrc.yml
@@ -29,3 +29,9 @@ globals:
   clearTimeout: writable
   setInterval: writable
   setTimeout: writable
+overrides:
+  - files:
+      - testESModules.js
+      - modules/exports.js
+    parserOptions:
+      sourceType: module
diff --git a/installed-tests/js/jsunit.gresources.xml b/installed-tests/js/jsunit.gresources.xml
index 674e342f..5503446d 100644
--- a/installed-tests/js/jsunit.gresources.xml
+++ b/installed-tests/js/jsunit.gresources.xml
@@ -12,6 +12,7 @@
     <file>modules/badOverrides/Gio.js</file>
     <file>modules/badOverrides/Regress.js</file>
     <file>modules/badOverrides/WarnLib.js</file>
+    <file>modules/exports.js</file>
     <file>modules/foobar.js</file>
     <file>modules/lexicalScope.js</file>
     <file>modules/modunicode.js</file>
diff --git a/installed-tests/js/meson.build b/installed-tests/js/meson.build
index dae48e07..58385030 100644
--- a/installed-tests/js/meson.build
+++ b/installed-tests/js/meson.build
@@ -194,3 +194,22 @@ gdbus_test_description = configure_file(
 if get_option('installed_tests')
     install_data('testGDBus.js', install_dir: installed_js_tests_dir)
 endif
+
+# testESModules.js is also separate because it needs an extra minijasmine flag
+
+test('ESModules', minijasmine, args: [files('testESModules.js'), '-m'],
+    env: tests_environment, protocol: 'tap', suite: 'JS')
+
+esm_test_description_subst = {
+    'name': 'testESModules.js',
+    'installed_tests_execdir': installed_tests_execdir,
+}
+esm_test_description = configure_file(
+    configuration: esm_test_description_subst,
+    input: '../minijasmine-module.test.in', output: 'testESModules.test',
+    install: get_option('installed_tests'),
+    install_dir: installed_tests_metadir)
+
+if get_option('installed_tests')
+    install_data('testESModules.js', install_dir: installed_js_tests_dir)
+endif
diff --git a/installed-tests/js/modules/exports.js b/installed-tests/js/modules/exports.js
new file mode 100644
index 00000000..180151b9
--- /dev/null
+++ b/installed-tests/js/modules/exports.js
@@ -0,0 +1,6 @@
+// SPDX-License-Identifier: MIT OR LGPL-2.0-or-later
+// SPDX-FileCopyrightText: 2020 Evan Welsh <contact evanwelsh com>
+
+export default 5;
+
+export const NamedExport = 'Hello, World';
diff --git a/installed-tests/js/testESModules.js b/installed-tests/js/testESModules.js
new file mode 100644
index 00000000..14db12d9
--- /dev/null
+++ b/installed-tests/js/testESModules.js
@@ -0,0 +1,26 @@
+// SPDX-License-Identifier: MIT OR LGPL-2.0-or-later
+// SPDX-FileCopyrightText: 2020 Evan Welsh <contact evanwelsh com>
+
+import gi from 'gi';
+import system from 'system';
+
+import $ from 'resource:///org/gjs/jsunit/modules/exports.js';
+import {NamedExport} from 'resource:///org/gjs/jsunit/modules/exports.js';
+
+describe('ES module imports', function () {
+    it('default import', function () {
+        expect($).toEqual(5);
+    });
+
+    it('named import', function () {
+        expect(NamedExport).toEqual('Hello, World');
+    });
+
+    it('system import', function () {
+        expect(system.exit.toString()).toEqual('function exit() {\n    [native code]\n}');
+    });
+
+    it('GObject introspection import', function () {
+        expect(gi.require('GObject').toString()).toEqual('[object GIRepositoryNamespace]');
+    });
+});
diff --git a/installed-tests/meson.build b/installed-tests/meson.build
index 9da3ed0a..11acbe4e 100644
--- a/installed-tests/meson.build
+++ b/installed-tests/meson.build
@@ -44,45 +44,6 @@ endforeach
 
 subdir('js')
 
-# esm script tests #
-
-esm_tests = [
-    'default-import',
-    'named-import',
-    'gi-import',
-    'system-import'
-]
-
-esm_test_driver = find_program(files('esm-test.sh'))
-if get_option('installed_tests')
-    install_data('esm-test.sh', install_dir: installed_tests_execdir)
-endif
-
-foreach test : esm_tests
-    test_file = files('esm' / '@0@.js'.format(test))
-
-    test('@0@ command'.format(test), esm_test_driver,
-        args: test_file, env: tests_environment, protocol: 'tap',
-        suite: 'ESM')
-
-    test_description_subst = {
-        'name': '@0@.js'.format(test),
-        'installed_tests_execdir': installed_tests_execdir,
-    }
-    test_description = configure_file(configuration: test_description_subst,
-        input: 'esm.test.in',
-        output: '@0@.test'.format(test),
-        install: get_option('installed_tests'),
-        install_dir: installed_tests_metadir)
-
-    if get_option('installed_tests')
-        install_data(test_file, install_dir: installed_tests_execdir / 'esm')
-        install_data('esm' / '@0@.js'.format(test),
-            'esm' / '@0@.js.output'.format(test),
-            install_dir: installed_tests_execdir / 'esm')
-    endif
-endforeach
-
 # Debugger script tests #
 
 debugger_tests = [
diff --git a/installed-tests/minijasmine-module.test.in b/installed-tests/minijasmine-module.test.in
new file mode 100644
index 00000000..e9e6b700
--- /dev/null
+++ b/installed-tests/minijasmine-module.test.in
@@ -0,0 +1,7 @@
+# SPDX-License-Identifier: MIT OR LGPL-2.0-or-later
+# SPDX-FileCopyrightText: 2020 Philip Chimento <philip chimento gmail com>
+
+[Test]
+Type=session
+Exec=@installed_tests_execdir@/minijasmine @installed_tests_execdir@/js/@name@ -m
+Output=TAP
diff --git a/installed-tests/minijasmine.cpp b/installed-tests/minijasmine.cpp
index be8ba42f..9cc1d7b3 100644
--- a/installed-tests/minijasmine.cpp
+++ b/installed-tests/minijasmine.cpp
@@ -3,7 +3,9 @@
 // SPDX-FileCopyrightText: 2016 Philip Chimento
 
 #include <locale.h>  // for setlocale, LC_ALL
+#include <stdint.h>
 #include <stdlib.h>  // for exit
+#include <string.h>
 
 #include <gio/gio.h>
 #include <girepository.h>
@@ -62,12 +64,19 @@ main(int argc, char **argv)
     bool success;
     int code;
 
-    success = gjs_context_eval(cx, "imports.minijasmine;", -1,
-                               "<jasmine>", &code, &error);
-    if (!success)
+    int exitcode_ignored;
+    if (!gjs_context_eval(cx, "imports.minijasmine;", -1, "<jasmine>",
+                          &exitcode_ignored, &error))
         bail_out(cx, error->message);
 
-    success = gjs_context_eval_file(cx, argv[1], &code, &error);
+    bool eval_as_module = argc >= 3 && strcmp(argv[2], "-m") == 0;
+    if (eval_as_module) {
+        uint8_t u8_exitcode_ignored;
+        success = gjs_context_eval_module_file(cx, argv[1],
+                                               &u8_exitcode_ignored, &error);
+    } else {
+        success = gjs_context_eval_file(cx, argv[1], &exitcode_ignored, &error);
+    }
     if (!success)
         bail_out(cx, error->message);
 


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]