From 75dba51f5617df7e68348871f7961a1f7f5ba4b5 Mon Sep 17 00:00:00 2001 From: n1474335 Date: Mon, 28 Mar 2022 10:52:28 +0100 Subject: [PATCH] Improve CJS and ESM module support #1037 --- Gruntfile.js | 9 +----- package.json | 11 +++----- src/node/{repl.js => repl.mjs} | 4 +-- src/node/{cjs.js => wrapper.js} | 0 tests/node/consumers/esm-consumer.mjs | 24 ++++++++++++++-- .../consumers/esm-deep-import-consumer.mjs | 28 ------------------- 6 files changed, 29 insertions(+), 47 deletions(-) rename src/node/{repl.js => repl.mjs} (92%) rename src/node/{cjs.js => wrapper.js} (100%) delete mode 100644 tests/node/consumers/esm-deep-import-consumer.mjs diff --git a/Gruntfile.js b/Gruntfile.js index 725e14a5c3..accda364c6 100755 --- a/Gruntfile.js +++ b/Gruntfile.js @@ -50,7 +50,7 @@ module.exports = function (grunt) { grunt.registerTask("testnodeconsumer", "A task which checks whether consuming CJS and ESM apps work with the CyberChef build", - ["exec:setupNodeConsumers", "exec:testCJSNodeConsumer", "exec:testESMNodeConsumer", "exec:testESMDeepImportNodeConsumer", "exec:teardownNodeConsumers"]); + ["exec:setupNodeConsumers", "exec:testCJSNodeConsumer", "exec:testESMNodeConsumer", "exec:teardownNodeConsumers"]); grunt.registerTask("default", "Lints the code base", @@ -403,13 +403,6 @@ module.exports = function (grunt) { ]), stdout: false, }, - testESMDeepImportNodeConsumer: { - command: chainCommands([ - `cd ${nodeConsumerTestPath}`, - `node ${nodeFlags} esm-deep-import-consumer.mjs`, - ]), - stdout: false, - }, fixCryptoApiImports: { command: [ `[[ "$OSTYPE" == "darwin"* ]]`, diff --git a/package.json b/package.json index 73d2d6558f..8b97c4a1f5 100644 --- a/package.json +++ b/package.json @@ -27,13 +27,10 @@ "type": "git", "url": "https://github.com/gchq/CyberChef/" }, - "main": "src/node/cjs.js", - "module": "src/node/index.mjs", + "main": "src/node/wrapper.js", "exports": { - ".": { - "require": "./src/node/cjs.js", - "import": "./src/node/index.mjs" - } + "import": "./src/node/index.mjs", + "require": "./src/node/wrapper.js" }, "bugs": "https://github.com/gchq/CyberChef/issues", "browserslist": [ @@ -174,7 +171,7 @@ "scripts": { "start": "npx grunt dev", "build": "npx grunt prod", - "repl": "node src/node/repl.js", + "repl": "node --experimental-modules --experimental-json-modules --experimental-specifier-resolution=node --no-warnings src/node/repl.mjs", "test": "npx grunt configTests && node --experimental-modules --experimental-json-modules --no-warnings --no-deprecation tests/node/index.mjs && node --experimental-modules --experimental-json-modules --no-warnings --no-deprecation tests/operations/index.mjs", "test-node-consumer": "npx grunt testnodeconsumer", "testui": "npx grunt testui", diff --git a/src/node/repl.js b/src/node/repl.mjs similarity index 92% rename from src/node/repl.js rename to src/node/repl.mjs index 2915463029..9846ff31b1 100644 --- a/src/node/repl.js +++ b/src/node/repl.mjs @@ -7,8 +7,8 @@ * @license Apache-2.0 */ -const chef = require("./cjs.js"); -const repl = require("repl"); +import chef from "./index.mjs"; +import repl from "repl"; /* eslint no-console: ["off"] */ diff --git a/src/node/cjs.js b/src/node/wrapper.js similarity index 100% rename from src/node/cjs.js rename to src/node/wrapper.js diff --git a/tests/node/consumers/esm-consumer.mjs b/tests/node/consumers/esm-consumer.mjs index 3536ef0055..2919e53370 100644 --- a/tests/node/consumers/esm-consumer.mjs +++ b/tests/node/consumers/esm-consumer.mjs @@ -7,8 +7,28 @@ */ import assert from "assert"; import chef from "cyberchef"; +import { bake, toHex, reverse, unique, multiply } from "cyberchef"; -const d = chef.bake("Testing, 1 2 3", [ +const a = bake("Testing, 1 2 3", [ + toHex, + reverse, + { + op: unique, + args: { + delimiter: "Space", + } + }, + { + op: multiply, + args: { + delimiter: "Space", + } + } +]); + +assert.equal(a.value, "630957449041920"); + +const b = chef.bake("Testing, 1 2 3", [ chef.toHex, chef.reverse, { @@ -25,4 +45,4 @@ const d = chef.bake("Testing, 1 2 3", [ } ]); -assert.equal(d.value, "630957449041920"); +assert.equal(b.value, "630957449041920"); diff --git a/tests/node/consumers/esm-deep-import-consumer.mjs b/tests/node/consumers/esm-deep-import-consumer.mjs deleted file mode 100644 index 8b1eb4e94a..0000000000 --- a/tests/node/consumers/esm-deep-import-consumer.mjs +++ /dev/null @@ -1,28 +0,0 @@ -/** - * Tests to ensure that a consuming app can use named imports from deep import patch - * - * @author d98762625 [d98762625@gmail.com] - * @copyright Crown Copyright 2019 - * @license Apache-2.0 - */ -import assert from "assert"; -import { bake, toHex, reverse, unique, multiply } from "cyberchef"; - -const d = bake("Testing, 1 2 3", [ - toHex, - reverse, - { - op: unique, - args: { - delimiter: "Space", - } - }, - { - op: multiply, - args: { - delimiter: "Space", - } - } -]); - -assert.equal(d.value, "630957449041920");