From 73456ffd767b829916e66df531db54dd21398db2 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Eduardo=20Bou=C3=A7as?= Date: Tue, 24 Aug 2021 10:01:14 +0100 Subject: [PATCH] feat: allow .mjs functions (#619) Co-authored-by: kodiakhq[bot] <49736102+kodiakhq[bot]@users.noreply.github.com> --- src/runtimes/node/finder.js | 2 ++ src/runtimes/node/index.js | 7 ++++--- tests/fixtures/node-mjs/func1.mjs | 1 + tests/fixtures/node-mjs/func2/func2.mjs | 1 + tests/fixtures/node-mjs/func3/index.mjs | 1 + tests/main.js | 24 ++++++++++++++++++++++++ 6 files changed, 33 insertions(+), 3 deletions(-) create mode 100644 tests/fixtures/node-mjs/func1.mjs create mode 100644 tests/fixtures/node-mjs/func2/func2.mjs create mode 100644 tests/fixtures/node-mjs/func3/index.mjs diff --git a/src/runtimes/node/finder.js b/src/runtimes/node/finder.js index 08d0af4a1..2aefbd4fb 100644 --- a/src/runtimes/node/finder.js +++ b/src/runtimes/node/finder.js @@ -74,6 +74,8 @@ const getMainFile = function (srcPath, filename, stat) { [ join(srcPath, `${filename}.js`), join(srcPath, 'index.js'), + join(srcPath, `${filename}.mjs`), + join(srcPath, 'index.mjs'), join(srcPath, `${filename}.ts`), join(srcPath, 'index.ts'), ], diff --git a/src/runtimes/node/index.js b/src/runtimes/node/index.js index 547f04e50..ba0875920 100644 --- a/src/runtimes/node/index.js +++ b/src/runtimes/node/index.js @@ -9,9 +9,10 @@ const { getSrcFiles } = require('./src_files') const { zipEsbuild } = require('./zip_esbuild') const { zipZisi } = require('./zip_zisi') -// We use ZISI as the default bundler until the next major release, with the -// exception of TypeScript files, for which the only option is esbuild. -const getDefaultBundler = ({ extension }) => (extension === '.ts' ? JS_BUNDLER_ESBUILD : JS_BUNDLER_ZISI) +// We use ZISI as the default bundler, except for certain extensions, for which +// esbuild is the only option. +const getDefaultBundler = ({ extension }) => + ['.mjs', '.ts'].includes(extension) ? JS_BUNDLER_ESBUILD : JS_BUNDLER_ZISI // A proxy for the `getSrcFiles` function which adds a default `bundler` using // the `getDefaultBundler` function. diff --git a/tests/fixtures/node-mjs/func1.mjs b/tests/fixtures/node-mjs/func1.mjs new file mode 100644 index 000000000..767df32b9 --- /dev/null +++ b/tests/fixtures/node-mjs/func1.mjs @@ -0,0 +1 @@ +export const handler = () => true diff --git a/tests/fixtures/node-mjs/func2/func2.mjs b/tests/fixtures/node-mjs/func2/func2.mjs new file mode 100644 index 000000000..767df32b9 --- /dev/null +++ b/tests/fixtures/node-mjs/func2/func2.mjs @@ -0,0 +1 @@ +export const handler = () => true diff --git a/tests/fixtures/node-mjs/func3/index.mjs b/tests/fixtures/node-mjs/func3/index.mjs new file mode 100644 index 000000000..767df32b9 --- /dev/null +++ b/tests/fixtures/node-mjs/func3/index.mjs @@ -0,0 +1 @@ +export const handler = () => true diff --git a/tests/main.js b/tests/main.js index 57dec83b7..c259b0138 100644 --- a/tests/main.js +++ b/tests/main.js @@ -952,6 +952,30 @@ testBundlers('Handles a TypeScript function with imports', [ESBUILD, ESBUILD_ZIS t.true(typeof require(`${tmpDir}/function.js`).type === 'string') }) +testBundlers( + 'Handles a JavaScript function ({name}.mjs, {name}/{name}.mjs, {name}/index.mjs)', + [ESBUILD, ESBUILD_ZISI, DEFAULT], + async (bundler, t) => { + const { files, tmpDir } = await zipFixture(t, 'node-mjs', { + length: 3, + opts: { config: { '*': { nodeBundler: bundler } } }, + }) + + await unzipFiles(files) + + t.is(files.length, 3) + files.forEach((file) => { + t.is(file.bundler, 'esbuild') + }) + + /* eslint-disable import/no-dynamic-require, node/global-require */ + t.true(require(`${tmpDir}/func1.js`).handler()) + t.true(require(`${tmpDir}/func2.js`).handler()) + t.true(require(`${tmpDir}/func3.js`).handler()) + /* eslint-enable import/no-dynamic-require, node/global-require */ + }, +) + testBundlers( 'Loads a tsconfig.json placed in the same directory as the function', [ESBUILD, ESBUILD_ZISI, DEFAULT],