From 9ca8c79cc1dc77bbe4f53f0854e0fb3eab591525 Mon Sep 17 00:00:00 2001 From: Kanad Gupta Date: Tue, 10 Dec 2024 12:02:58 -0600 Subject: [PATCH 01/10] chore: rename getPkgVersion file --- src/lib/{getPkgVersion.ts => getPkg.ts} | 0 1 file changed, 0 insertions(+), 0 deletions(-) rename src/lib/{getPkgVersion.ts => getPkg.ts} (100%) diff --git a/src/lib/getPkgVersion.ts b/src/lib/getPkg.ts similarity index 100% rename from src/lib/getPkgVersion.ts rename to src/lib/getPkg.ts From e338820ce7d61a109c3d65bcda128f0f476f8d16 Mon Sep 17 00:00:00 2001 From: Kanad Gupta Date: Tue, 10 Dec 2024 12:04:10 -0600 Subject: [PATCH 02/10] refactor: split out getPkgVersion, sync import of package.json file --- src/lib/getPkg.ts | 35 ++++++++++++++++++++++++++++------- 1 file changed, 28 insertions(+), 7 deletions(-) diff --git a/src/lib/getPkg.ts b/src/lib/getPkg.ts index 335f7929b..cf9c44266 100644 --- a/src/lib/getPkg.ts +++ b/src/lib/getPkg.ts @@ -1,8 +1,8 @@ import type { Hook } from '@oclif/core'; -import semver from 'semver'; +import { readFileSync } from 'node:fs'; -import pkg from '../package.json' with { type: 'json' }; +import semver from 'semver'; import { error } from './logger.js'; @@ -13,6 +13,15 @@ const registryUrl = 'https://registry.npmjs.com/rdme'; */ type npmDistTag = 'latest'; +/** + * A synchronous function that reads the `package.json` file for use elsewhere. + * Until we drop support Node.js 20, we need to import this way to avoid ExperimentalWarning outputs. + * + * @see {@link https://nodejs.org/docs/latest-v20.x/api/esm.html#import-attributes} + * @see {@link https://www.stefanjudis.com/snippets/how-to-import-json-files-in-es-modules-node-js/} + */ +export const pkg = JSON.parse(readFileSync(new URL('../../package.json', import.meta.url), { encoding: 'utf-8' })); + /** * Return the major Node.js version specified in our `package.json` config. * @@ -27,6 +36,18 @@ export function getNodeVersion(): string { return parsedVersion.version; } +/** + * The current `rdme` version, as specified in the `package.json` + * or in the oclif hook context. + * + * @example "8.0.0" + * @note we mock this function in our snapshots + * @see {@link https://stackoverflow.com/a/54245672} + */ +export function getPkgVersion(this: Hook.Context | void): string { + return this?.config?.version || pkg.version; +} + /** * The current `rdme` version * @@ -34,20 +55,20 @@ export function getNodeVersion(): string { * the version from the `package.json` is returned. * @example "8.0.0" * @see {@link https://docs.npmjs.com/adding-dist-tags-to-packages} - * @note we mock this function in our snapshots, hence it's not the default + * @note we mock this function in our snapshots * @see {@link https://stackoverflow.com/a/54245672} */ -export async function getPkgVersion(this: Hook.Context | void, npmDistTag?: npmDistTag): Promise { +export async function getPkgVersionFromNPM(this: Hook.Context | void, npmDistTag?: npmDistTag): Promise { if (npmDistTag) { return fetch(registryUrl) .then(res => res.json() as Promise<{ 'dist-tags': Record }>) .then(body => body['dist-tags'][npmDistTag]) .catch(err => { error(`error fetching version from npm registry: ${err.message}`); - return pkg.version; + return getPkgVersion.call(this); }); } - return this?.config?.version || pkg.version; + return getPkgVersion.call(this); } /** @@ -56,5 +77,5 @@ export async function getPkgVersion(this: Hook.Context | void, npmDistTag?: npmD * @example 8 */ export async function getMajorPkgVersion(this: Hook.Context | void, npmDistTag?: npmDistTag): Promise { - return semver.major(await getPkgVersion.call(this, npmDistTag)); + return semver.major(await getPkgVersionFromNPM.call(this, npmDistTag)); } From 7fc8c2f03cc4f9c5d5848fff2ac84917a22d99e2 Mon Sep 17 00:00:00 2001 From: Kanad Gupta Date: Tue, 10 Dec 2024 12:04:55 -0600 Subject: [PATCH 03/10] refactor: move all production code to use new function --- src/lib/configstore.ts | 2 +- src/lib/createGHA/index.ts | 2 +- src/lib/readmeAPIFetch.ts | 5 ++--- 3 files changed, 4 insertions(+), 5 deletions(-) diff --git a/src/lib/configstore.ts b/src/lib/configstore.ts index 7fc7fccc0..d4517a480 100644 --- a/src/lib/configstore.ts +++ b/src/lib/configstore.ts @@ -1,6 +1,6 @@ import Configstore from 'configstore'; -import pkg from '../package.json' with { type: 'json' }; +import { pkg } from './getPkg.js'; const configstore = new Configstore( /** diff --git a/src/lib/createGHA/index.ts b/src/lib/createGHA/index.ts index 539c428ff..ffa744099 100644 --- a/src/lib/createGHA/index.ts +++ b/src/lib/createGHA/index.ts @@ -8,7 +8,7 @@ import prompts from 'prompts'; import { simpleGit } from 'simple-git'; import configstore from '../configstore.js'; -import { getMajorPkgVersion } from '../getPkgVersion.js'; +import { getMajorPkgVersion } from '../getPkg.js'; import isCI, { isNpmScript, isTest } from '../isCI.js'; import { info } from '../logger.js'; import promptTerminal from '../promptWrapper.js'; diff --git a/src/lib/readmeAPIFetch.ts b/src/lib/readmeAPIFetch.ts index 920ca2b79..0237fe8a2 100644 --- a/src/lib/readmeAPIFetch.ts +++ b/src/lib/readmeAPIFetch.ts @@ -5,13 +5,12 @@ import path from 'node:path'; import mime from 'mime-types'; import { ProxyAgent } from 'undici'; -import pkg from '../package.json' with { type: 'json' }; - import { APIv1Error } from './apiError.js'; import config from './config.js'; import { git } from './createGHA/index.js'; import isCI, { ciName, isGHA } from './isCI.js'; import { debug, warn } from './logger.js'; +import { getPkgVersion } from './getPkg.js'; const SUCCESS_NO_CONTENT = 204; @@ -90,7 +89,7 @@ function parseWarningHeader(header: string): WarningHeader[] { */ export function getUserAgent() { const gh = isGHA() ? '-github' : ''; - return `rdme${gh}/${pkg.version}`; + return `rdme${gh}/${getPkgVersion()}`; } /** From 0dd3f418d07a439290c7b5a08d0ff49800984e48 Mon Sep 17 00:00:00 2001 From: Kanad Gupta Date: Tue, 10 Dec 2024 12:06:49 -0600 Subject: [PATCH 04/10] test: backfill a few missing import attributes --- __tests__/commands/logout.test.ts | 2 +- __tests__/commands/open.test.ts | 2 +- __tests__/commands/whoami.test.ts | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/__tests__/commands/logout.test.ts b/__tests__/commands/logout.test.ts index b0fab24e6..901e7dea9 100644 --- a/__tests__/commands/logout.test.ts +++ b/__tests__/commands/logout.test.ts @@ -1,6 +1,6 @@ import { describe, afterEach, beforeAll, it, expect } from 'vitest'; -import pkg from '../../package.json'; +import pkg from '../../package.json' with { type: 'json' }; import Command from '../../src/commands/logout.js'; import configStore from '../../src/lib/configstore.js'; import { runCommandAndReturnResult } from '../helpers/oclif.js'; diff --git a/__tests__/commands/open.test.ts b/__tests__/commands/open.test.ts index 80b961dd3..3ab9829f0 100644 --- a/__tests__/commands/open.test.ts +++ b/__tests__/commands/open.test.ts @@ -3,7 +3,7 @@ import type { Version } from '../../src/commands/versions/index.js'; import chalk from 'chalk'; import { describe, afterEach, beforeAll, it, expect } from 'vitest'; -import pkg from '../../package.json'; +import pkg from '../../package.json' with { type: 'json' }; import Command from '../../src/commands/open.js'; import configStore from '../../src/lib/configstore.js'; import { getAPIv1Mock } from '../helpers/get-api-mock.js'; diff --git a/__tests__/commands/whoami.test.ts b/__tests__/commands/whoami.test.ts index 10c898255..aecd0bbee 100644 --- a/__tests__/commands/whoami.test.ts +++ b/__tests__/commands/whoami.test.ts @@ -1,6 +1,6 @@ import { describe, afterEach, it, expect, beforeAll } from 'vitest'; -import pkg from '../../package.json'; +import pkg from '../../package.json' with { type: 'json' }; import Command from '../../src/commands/whoami.js'; import configStore from '../../src/lib/configstore.js'; import { runCommandAndReturnResult } from '../helpers/oclif.js'; From 174c36c1a0dfe884c240c52872a67200ac6b36b7 Mon Sep 17 00:00:00 2001 From: Kanad Gupta Date: Tue, 10 Dec 2024 12:07:20 -0600 Subject: [PATCH 05/10] chore: fix a few import paths --- __tests__/helpers/get-gha-setup.ts | 2 +- __tests__/lib/createGHA.test.ts | 2 +- bin/set-version-output.js | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/__tests__/helpers/get-gha-setup.ts b/__tests__/helpers/get-gha-setup.ts index 528f6ca80..cd382c773 100644 --- a/__tests__/helpers/get-gha-setup.ts +++ b/__tests__/helpers/get-gha-setup.ts @@ -6,7 +6,7 @@ import { vi } from 'vitest'; import configstore from '../../src/lib/configstore.js'; import { git } from '../../src/lib/createGHA/index.js'; -import * as getPkgVersion from '../../src/lib/getPkgVersion.js'; +import * as getPkgVersion from '../../src/lib/getPkg.js'; import getGitRemoteMock from './get-git-mock.js'; diff --git a/__tests__/lib/createGHA.test.ts b/__tests__/lib/createGHA.test.ts index a1cd3d9b8..943bb90f9 100644 --- a/__tests__/lib/createGHA.test.ts +++ b/__tests__/lib/createGHA.test.ts @@ -10,7 +10,7 @@ import { describe, beforeEach, afterEach, it, expect, vi, type MockInstance, bef import configstore from '../../src/lib/configstore.js'; import { getConfigStoreKey, getGHAFileName, git } from '../../src/lib/createGHA/index.js'; -import { getMajorPkgVersion } from '../../src/lib/getPkgVersion.js'; +import { getMajorPkgVersion } from '../../src/lib/getPkg.js'; import { after, before } from '../helpers/get-gha-setup.js'; import getGitRemoteMock from '../helpers/get-git-mock.js'; import ghaWorkflowSchema from '../helpers/github-workflow-schema.json' with { type: 'json' }; diff --git a/bin/set-version-output.js b/bin/set-version-output.js index 41de6484b..0aee75ce5 100755 --- a/bin/set-version-output.js +++ b/bin/set-version-output.js @@ -3,7 +3,7 @@ import * as core from '@actions/core'; // eslint-disable-next-line import/extensions -import { getNodeVersion, getMajorPkgVersion } from '../dist/lib/getPkgVersion.js'; +import { getNodeVersion, getMajorPkgVersion } from '../dist/lib/getPkg.js'; /** * Sets output parameters for GitHub Actions workflow so we can do From 8f294e099e7f320472663a29735882281dec2a9f Mon Sep 17 00:00:00 2001 From: Kanad Gupta Date: Tue, 10 Dec 2024 12:07:27 -0600 Subject: [PATCH 06/10] test: fix up test + import paths --- __tests__/lib/getPkgVersion.test.ts | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/__tests__/lib/getPkgVersion.test.ts b/__tests__/lib/getPkgVersion.test.ts index 9bf6e7285..ac3f6aff9 100644 --- a/__tests__/lib/getPkgVersion.test.ts +++ b/__tests__/lib/getPkgVersion.test.ts @@ -3,7 +3,7 @@ import semver from 'semver'; import { describe, beforeEach, afterEach, it, expect, vi, type MockInstance } from 'vitest'; import pkg from '../../package.json' with { type: 'json' }; -import { getNodeVersion, getPkgVersion } from '../../src/lib/getPkgVersion.js'; +import { getNodeVersion, getPkgVersion, getPkgVersionFromNPM } from '../../src/lib/getPkg.js'; describe('#getNodeVersion()', () => { it('should extract version that matches range in package.json', () => { @@ -27,7 +27,7 @@ describe('#getPkgVersion()', () => { }); it('should grab version from package.json by default', () => { - return expect(getPkgVersion()).resolves.toBe(pkg.version); + return expect(getPkgVersion()).toBe(pkg.version); }); it('should fetch version from npm registry', async () => { @@ -35,7 +35,7 @@ describe('#getPkgVersion()', () => { .get('/rdme') .reply(200, { 'dist-tags': { latest: '1.0' } }); - await expect(getPkgVersion('latest')).resolves.toBe('1.0'); + await expect(getPkgVersionFromNPM('latest')).resolves.toBe('1.0'); mock.done(); }); @@ -43,7 +43,7 @@ describe('#getPkgVersion()', () => { it('should fallback if npm registry fails', async () => { const mock = nock('https://registry.npmjs.com', { encodedQueryParams: true }).get('/rdme').reply(500); - await expect(getPkgVersion('latest')).resolves.toBe(pkg.version); + await expect(getPkgVersionFromNPM('latest')).resolves.toBe(pkg.version); mock.done(); }); From 010f492c3d9357174de1f8c2f3356a32a691091c Mon Sep 17 00:00:00 2001 From: Kanad Gupta Date: Tue, 10 Dec 2024 12:08:19 -0600 Subject: [PATCH 07/10] fix: remove CLI flag from entrypoint --- bin/run.js | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/bin/run.js b/bin/run.js index 4a32f3b6b..0875bc524 100755 --- a/bin/run.js +++ b/bin/run.js @@ -1,6 +1,4 @@ -#!/usr/bin/env -S node --no-warnings=ExperimentalWarning -// ^ we need this env variable above to hide the ExperimentalWarnings -// source: https://github.com/nodejs/node/issues/10802#issuecomment-573376999 +#!/usr/bin/env node import stringArgv from 'string-argv'; From c52f1a94529f4386c615981540adb460a174d519 Mon Sep 17 00:00:00 2001 From: Kanad Gupta Date: Tue, 10 Dec 2024 12:10:15 -0600 Subject: [PATCH 08/10] chore: can i remove this too? --- bin/dev.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/bin/dev.js b/bin/dev.js index 7122c2827..c87b65b4a 100755 --- a/bin/dev.js +++ b/bin/dev.js @@ -1,4 +1,4 @@ -#!/usr/bin/env -S npx tsx +#!/usr/bin/env npx tsx async function main() { const { execute } = await import('@oclif/core'); From 23aabddbc5c595d4f74dbdbb4208e16559050d66 Mon Sep 17 00:00:00 2001 From: Kanad Gupta Date: Tue, 10 Dec 2024 12:23:04 -0600 Subject: [PATCH 09/10] chore: lint --- src/lib/readmeAPIFetch.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/lib/readmeAPIFetch.ts b/src/lib/readmeAPIFetch.ts index 0237fe8a2..56aab4b4e 100644 --- a/src/lib/readmeAPIFetch.ts +++ b/src/lib/readmeAPIFetch.ts @@ -8,9 +8,9 @@ import { ProxyAgent } from 'undici'; import { APIv1Error } from './apiError.js'; import config from './config.js'; import { git } from './createGHA/index.js'; +import { getPkgVersion } from './getPkg.js'; import isCI, { ciName, isGHA } from './isCI.js'; import { debug, warn } from './logger.js'; -import { getPkgVersion } from './getPkg.js'; const SUCCESS_NO_CONTENT = 204; From e3017a09e8596011de5edee7558bf4d9fda8ce82 Mon Sep 17 00:00:00 2001 From: Kanad Gupta Date: Tue, 10 Dec 2024 12:24:21 -0600 Subject: [PATCH 10/10] ci: add another assertion --- .github/workflows/release.yml | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index 818bef5a9..7de901613 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -48,3 +48,20 @@ jobs: with: github_token: ${{ secrets.RELEASE_GH_TOKEN }} branch: next + + # quick assertion to validate that rdme CLI can be installed and run on ubuntu + postrelease: + name: Post-release checks + needs: release + runs-on: ubuntu-latest + if: ${{ github.ref }} == 'refs/heads/next' + steps: + - name: Set up Node.js + uses: actions/setup-node@v4 + with: + node-version: lts/* + - name: Install `rdme` from npm + run: npm install -g rdme@next + - name: Print rdme CLI version + run: rdme --version + timeout-minutes: 1