From f4a0e7b17cd2427799885529dc098aabde925c2c Mon Sep 17 00:00:00 2001 From: atao Date: Tue, 29 Jun 2021 13:13:24 +0200 Subject: [PATCH] build(esm): migrate to ES Modules Migrate to ESM to allow updating packages with no more CJS support such as supports-color or terminal-link. Don't wait for jprichardson/node-fs-extra#746. BREAKING CHANGE: remove support to Node 10 --- .github/workflows/publish.yml | 2 +- .vscode/settings.json | 7 +++++ CONTRIBUTING.md | 24 +++++++++++------ README.md | 2 +- USAGE | 2 +- babel.config.cjs | 4 +-- bin/fse.js | 2 +- make.sh | 2 +- package-lock.json | 50 ++++++++++++++++++++++++++++------- package.json | 11 ++++---- src/config.ts | 5 +++- src/tasks/help.ts | 7 +++-- src/tasks/version.ts | 5 +++- src/tsconfig.json | 4 +-- src/wrapper.ts | 5 +++- test/cli.test.ts | 7 +++-- test/tsconfig.json | 8 +++--- tools/package.json | 3 +++ 18 files changed, 109 insertions(+), 41 deletions(-) create mode 100644 tools/package.json diff --git a/.github/workflows/publish.yml b/.github/workflows/publish.yml index d1f6636..04d47b8 100644 --- a/.github/workflows/publish.yml +++ b/.github/workflows/publish.yml @@ -16,7 +16,7 @@ jobs: - uses: actions/checkout@v2 - uses: actions/setup-node@v1 with: - node-version: 12 + node-version: 12.20 registry-url: https://npm.pkg.github.com/ scope: '@atao60' - run: npm ci diff --git a/.vscode/settings.json b/.vscode/settings.json index e6c0660..5fe0628 100644 --- a/.vscode/settings.json +++ b/.vscode/settings.json @@ -30,9 +30,12 @@ "typescript.tsdk": "node_modules/typescript/lib", "cSpell.ignoreWords": [ "anyfileext", + "apigithub", + "apigithuburl", "browserslistrc", "commitlint", "currentinputs", + "def", "dirpath", "florian", "fullcheck", @@ -40,9 +43,12 @@ "fulltest", "fulltext", "gerth", + "gitquery", "globaltest", "hassy", "ignorecase", + "job", + "js", "khaled", "kreuzer", "logerror", @@ -61,6 +67,7 @@ "preinstall", "readdirp", "refname", + "repos", "rootpath", "shortpath", "startingat", diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index d38075d..8fef18a 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -107,10 +107,11 @@ At the moment there is no CI/Build configuration on [Github](https://github.com) ## Prerequisites * [Git](https://git-scm.com/) -* [Node.js](https://nodejs.org/) -* [Npm](https://www.npmjs.com/) - comes with Node.js -* [Npx](https://github.com/npm/npx#readme) - comes with Node.js +* [Node.js](https://nodejs.org/) - *at least version 12.20* +* [Npm](https://www.npmjs.com/) - *comes with Node.js* +* [Npx](https://github.com/npm/npx#readme) - *comes with Node.js* * [Docker](https://www.docker.com/) +* [nvm](https://github.com/nvm-sh/nvm) - *optional* and possibly: * a [GitHub account](https://github.com/) @@ -126,6 +127,8 @@ git --version docker --version # check if BuildKit can be used, i.e. with Docker 18.09 or higher +nvm --version # required only if you need to install Node with at least version 12.20 or higher + npm list -g --depth 0 2>&1 | grep fse-cli # (°°) ``` @@ -138,6 +141,8 @@ npm list -g --depth 0 2>&1 | grep fse-cli # (°°) ### Fork ```bash +node --version ### check Node.js is installed with at least version 12.20 + sudo npm uninstall -g @atao60/fse-cli ### if needed; required to avoid any issue with `npm link`, see below git clone https://github.com/atao60/fse-cli.git atao60-fse-cli @@ -213,17 +218,20 @@ npm start ### will rebuild and test after each code change ``` ### Iterate tests over main versions of Node.js -To ensure this package `@atao60/fse-cli` is compatible with all major versions of [Node.js](https://nodejs.org), a [Docker](https://www.docker.com/) image with the last release of each of them is used to run the tests: +To ensure this package `@atao60/fse-cli` is compatible with all major versions of [Node.js](https://nodejs.org), a [Docker](https://www.docker.com/)(°) image with the last release of each of them is used to run the tests: ```bash ./make.sh nodecheckall ``` -The checked versions of [Node.js](https://nodejs.org) are from 10 to 16. +The checked releases of [Node.js](https://nodejs.org) are from 12 to last available one as long as a version compatible with [ESM](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide/Modules) is available(°°). -> As soon as [Docker](https://www.docker.com/) is installed, some Bourne shell or compatible should be available, allowing running `make.sh`. +> (°) As soon as [Docker](https://www.docker.com/) is installed, some Bourne shell or compatible one should be available, allowing cross-platform running of `make.sh`. ->[EOL](https://en.wikipedia.org/wiki/End-of-life_product) of `Node.js` 10 was the 30th April 2021, see [Node.js' Releases](https://github.com/nodejs/Release). -Even if [Docker Official Images for Node.js](https://hub.docker.com/_/node) doesn't support any more versions below 12, older versions are still available. +> (°°) Already reached [EOL](https://en.wikipedia.org/wiki/End-of-life_product) of [Node.js' Releases](https://github.com/nodejs/Release) are: +- 10: 30th April 2021, +- 13: 1st of june 2020, +- 15: 1st of june 2021. +As release 15 is compatible with `ESM`, it's not been removed from checking yet. > Don't forget to regularly check and clean up disk space used by [Docker](https://www.docker.com/): `docker system df` and `docker system prune` are your friends here! diff --git a/README.md b/README.md index 86fc729..be0429f 100644 --- a/README.md +++ b/README.md @@ -4,7 +4,7 @@ Welcome to @atao/fse-cli A [CLI](https://en.wikipedia.org/wiki/Command-line_interface) for [fs-extra](https://github.com/jprichardson/node-fs-extra). -> Releases (0.0.x) will be the last ones to support version 10 of [Node.js](https://nodejs.org). +> Releases (0.0.x) will be the last ones to support LTS release [10](https://nodejs.org/download/release/v10.24.1/) of [Node.js](https://nodejs.org). Moreover the releases [11](https://nodejs.org/download/release/v11.15.0/) and [13](https://nodejs.org/download/release/v13.14.0/) are also no more supported. ## 💡 Rational Everyone needs simple file system operations like copy, remove, clean, ... that can be used from the terminal or via scripts. diff --git a/USAGE b/USAGE index 35ac325..4f12f02 100644 --- a/USAGE +++ b/USAGE @@ -38,7 +38,7 @@ or the environment variable 'FSE_CLI_QUIET=true'. `fse remove --quiet ` * touch Ensures that the file exists. If the file that is requested to be created is in directories that do not exist, - these directories are created. If the file already exists, it is NOT MODIFIED." + these directories are created. If the file already exists, it is NOT MODIFIED. Aliases: ***ensureFile***, ***touch*** `fse touch --quiet ` diff --git a/babel.config.cjs b/babel.config.cjs index 8e98ed2..faea32e 100644 --- a/babel.config.cjs +++ b/babel.config.cjs @@ -1,5 +1,5 @@ const targets = { - node: "10.15.3" // See also engines.node in package.json + node: "12.20.0" // See also engines.node in package.json // With @atao/fse-cli, indeed no '.browserslistrc' }; @@ -45,7 +45,7 @@ const presets = [ }, // Now Babel defaults 'modules' to 'auto', not any more to 'commonjs' (which won’t tree-shake.) // So no more need to setup 'modules' to 'false': - // modules: false, + modules: false, targets } ] diff --git a/bin/fse.js b/bin/fse.js index edda235..0277db3 100755 --- a/bin/fse.js +++ b/bin/fse.js @@ -1,3 +1,3 @@ #!/usr/bin/env node -require('../dist/index.js'); +import '../dist/index.js'; diff --git a/make.sh b/make.sh index 0c12308..a1e7363 100755 --- a/make.sh +++ b/make.sh @@ -5,7 +5,7 @@ MAKE=$0 OWNER=atao60 NAME=fse-cli VERSION=${2:-10.15.3} -ALL_MAIN_VERSIONS="10 11 12 13 14 15 16" +ALL_MAIN_VERSIONS="12 14 15 16" TEST_IMAGE_NAME=$OWNER/$NAME-test diff --git a/package-lock.json b/package-lock.json index f1c078f..87c3901 100644 --- a/package-lock.json +++ b/package-lock.json @@ -7636,6 +7636,15 @@ "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", "dev": true }, + "supports-color": { + "version": "8.1.1", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz", + "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==", + "dev": true, + "requires": { + "has-flag": "^4.0.0" + } + }, "to-regex-range": { "version": "5.0.1", "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", @@ -9294,12 +9303,20 @@ "dev": true }, "supports-color": { - "version": "8.1.1", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz", - "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==", + "version": "9.0.1", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-9.0.1.tgz", + "integrity": "sha512-e8HnXOAd61fVNyYRcKoqGNpnpceN/+IbDlWCBVjeqfASq/kbH4JwNj1Y4TFrve+w838Ff4eupPKXtY03zhCBKQ==", "dev": true, "requires": { - "has-flag": "^4.0.0" + "has-flag": "^5.0.0" + }, + "dependencies": { + "has-flag": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-5.0.0.tgz", + "integrity": "sha512-dmhh9fPE7WRat4yiFvyhXh7LytudXDcE89VEdR3sxfWQKtFPr7jpXip5H402aeFfA36ucqSKecGEapc7N44k+g==", + "dev": true + } } }, "supports-hyperlinks": { @@ -9362,12 +9379,27 @@ "dev": true }, "terminal-link": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/terminal-link/-/terminal-link-2.1.1.tgz", - "integrity": "sha512-un0FmiRUQNr5PJqy9kP7c40F5BOfpGlYTrxonDChEZB7pzZxRNp/bt+ymiy9/npwXya9KH99nJ/GXFIiUkYGFQ==", + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/terminal-link/-/terminal-link-3.0.0.tgz", + "integrity": "sha512-flFL3m4wuixmf6IfhFJd1YPiLiMuxEc8uHRM1buzIeZPm22Au2pDqBJQgdo7n1WfPU1ONFGv7YDwpFBmHGF6lg==", "requires": { - "ansi-escapes": "^4.2.1", - "supports-hyperlinks": "^2.0.0" + "ansi-escapes": "^5.0.0", + "supports-hyperlinks": "^2.2.0" + }, + "dependencies": { + "ansi-escapes": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-5.0.0.tgz", + "integrity": "sha512-5GFMVX8HqE/TB+FuBJGuO5XG0WrsA6ptUqoODaT/n9mmUaZFkqnBueB4leqGBCmrUHnCnC4PCZTCd0E7QQ83bA==", + "requires": { + "type-fest": "^1.0.2" + } + }, + "type-fest": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-1.2.1.tgz", + "integrity": "sha512-SbmIRuXhJs8KTneu77Ecylt9zuqL683tuiLYpTRil4H++eIhqCmx6ko6KAFem9dty8sOdnEiX7j4K1nRE628fQ==" + } } }, "text-extensions": { diff --git a/package.json b/package.json index 2465ba6..9d2ceae 100644 --- a/package.json +++ b/package.json @@ -2,8 +2,9 @@ "name": "@atao60/fse-cli", "version": "0.0.63", "description": "A cli for fs-extra", - "main": "./dist/index.js", + "exports": "./dist/index.js", "types": "./dist/index-types.d.ts", + "type": "module", "bin": { "fse": "./bin/fse.js", "fse-cli": "./bin/fse.js", @@ -126,8 +127,8 @@ "author": "Pierre Raoul ", "license": "MIT", "engines": { - "node": ">=10.15.3", - "npm": ">=6.4.1" + "node": "^12.20.0 || ^14.13.1 || >=16.0.0", + "npm": ">=6.14.11" }, "dependencies": { "@babel/runtime": "^7.13.10", @@ -139,7 +140,7 @@ "inquirer": "^8.0.0", "regenerator-runtime": "^0.13.7", "source-map-support": "^0.5.19", - "terminal-link": "^2.1.1", + "terminal-link": "^3.0.0", "tslib": "^2.2.0" }, "devDependencies": { @@ -189,7 +190,7 @@ "npm-force-resolutions": "0.0.10", "readdirp": "^3.6.0", "standard-version": "^9.2.0", - "supports-color": "^8.1.1", + "supports-color": "^9.0.1", "ts-node": "^10.0.0", "typescript": "^4.2" }, diff --git a/src/config.ts b/src/config.ts index bc8c9ef..e30e2a2 100644 --- a/src/config.ts +++ b/src/config.ts @@ -2,11 +2,14 @@ import arg from 'arg'; import chalk from 'chalk'; import inquirer from 'inquirer'; const { prompt } = inquirer; -import { basename, join } from 'path'; +import { basename, dirname, join } from 'path'; import { exit } from 'process'; +import { fileURLToPath } from 'url'; import { JobDef } from './job-def.js'; +const __dirname = dirname(fileURLToPath(import.meta.url)); + // !!! ⚠️ Don't forget to update the section 'bin' of package.json for any change of jobLinks ⚠️ !!! const jobLinks = Object.freeze({ copy: 'copy', diff --git a/src/tasks/help.ts b/src/tasks/help.ts index b01b0df..0992f3c 100644 --- a/src/tasks/help.ts +++ b/src/tasks/help.ts @@ -1,12 +1,15 @@ +import chalk, { Chalk } from 'chalk'; import fse from 'fs-extra'; const { existsSync, readFileSync } = fse; -import { join } from 'path'; -import chalk, { Chalk } from 'chalk'; +import { dirname, join } from 'path'; import terminalLink from 'terminal-link'; +import { fileURLToPath } from 'url'; import { job as version } from './version.js'; import { info } from '../logger.js'; +const __dirname = dirname(fileURLToPath(import.meta.url)); + const versionDef = { name: 'help', spec: {}, diff --git a/src/tasks/version.ts b/src/tasks/version.ts index 623e12a..415c817 100644 --- a/src/tasks/version.ts +++ b/src/tasks/version.ts @@ -1,9 +1,12 @@ import fse from 'fs-extra'; const { existsSync, readFileSync } = fse; -import { join } from 'path'; +import { dirname, join } from 'path'; +import { fileURLToPath } from 'url'; import * as logger from '../logger.js'; +const __dirname = dirname(fileURLToPath(import.meta.url)); + const versionDef = { name: 'version', spec: {}, diff --git a/src/tsconfig.json b/src/tsconfig.json index 80014c4..168599a 100644 --- a/src/tsconfig.json +++ b/src/tsconfig.json @@ -8,11 +8,11 @@ "strict": true, "outDir": "../dist", "baseUrl": "", - "module": "commonjs", + "module": "ES2020", "moduleResolution": "node", "lib": [ "es2018", "dom" ] } -} +} \ No newline at end of file diff --git a/src/wrapper.ts b/src/wrapper.ts index 9376494..9e7e613 100644 --- a/src/wrapper.ts +++ b/src/wrapper.ts @@ -1,4 +1,7 @@ -import { join } from 'path'; +import { dirname, join } from 'path'; +import { fileURLToPath } from 'url'; + +const __dirname = dirname(fileURLToPath(import.meta.url)); const tasksSubDir = 'tasks'; diff --git a/test/cli.test.ts b/test/cli.test.ts index 8998e09..4e7c48a 100644 --- a/test/cli.test.ts +++ b/test/cli.test.ts @@ -3,14 +3,17 @@ import gfs from 'graceful-fs'; const { closeSync, existsSync, mkdtempSync, mkdirSync, openSync, readFileSync, rmdirSync, statSync, unlinkSync, writeSync } = gfs; import mocha from 'mocha'; const { describe, it } = mocha; -import { join } from 'path'; +import { dirname, join } from 'path'; import { env } from 'process'; -import { format as printf } from 'util'; import sc from 'supports-color'; const { stdout: supportsColorStdout } = sc; +import { fileURLToPath } from 'url'; +import { format as printf } from 'util'; import { execute as run } from './cmd.js'; +const __dirname = dirname(fileURLToPath(import.meta.url)); + const LIB_DIR = join(__dirname, env.APP_CODE_PATH || '../../dist'); // os.tmpdir() is not used here, to stay inside project folder const TMP_DIR = join(__dirname, env.PROJECT_TARGET_PATH || '../.tmp-dir'); diff --git a/test/tsconfig.json b/test/tsconfig.json index 7d4e5d3..ee71076 100644 --- a/test/tsconfig.json +++ b/test/tsconfig.json @@ -7,12 +7,14 @@ "allowSyntheticDefaultImports": true, "outDir": "../dist", "baseUrl": "", - "module": "commonjs", + "module": "ES2020", "moduleResolution": "node", "lib": [ "es2018", "dom" ] }, - "include": ["**/*.test.ts"] -} + "include": [ + "**/*.test.ts" + ] +} \ No newline at end of file diff --git a/tools/package.json b/tools/package.json new file mode 100644 index 0000000..6a0d2ef --- /dev/null +++ b/tools/package.json @@ -0,0 +1,3 @@ +{ + "type": "commonjs" +} \ No newline at end of file