From 3a126d246789b60bcc8dfd96cf58991e214562b5 Mon Sep 17 00:00:00 2001 From: Mikael Finstad Date: Fri, 5 Apr 2024 21:30:50 +0200 Subject: [PATCH 1/3] fix otp for yarn berry --- source/index.js | 6 +++--- source/npm/handle-npm-error.js | 6 +++++- source/npm/publish.js | 13 +++++++++++++ 3 files changed, 21 insertions(+), 4 deletions(-) diff --git a/source/index.js b/source/index.js index 82e78398..b6da323f 100644 --- a/source/index.js +++ b/source/index.js @@ -14,7 +14,7 @@ import {asyncExitHook} from 'exit-hook'; import logSymbols from 'log-symbols'; import prerequisiteTasks from './prerequisite-tasks.js'; import gitTasks from './git-tasks.js'; -import {getPackagePublishArguments} from './npm/publish.js'; +import {getPackagePublishArguments, runPublish} from './npm/publish.js'; import enable2fa, {getEnable2faArguments} from './npm/enable-2fa.js'; import handleNpmError from './npm/handle-npm-error.js'; import releaseTaskHelper from './release-task-helper.js'; @@ -179,12 +179,12 @@ const np = async (input = 'patch', {packageManager, ...options}, {package_, root task(context, task) { let hasError = false; - return from(execa(...getPublishCommand(options))) + return from(runPublish(getPublishCommand(options))) .pipe( catchError(error => handleNpmError(error, task, otp => { context.otp = otp; - return execa(...getPublishCommand({...options, otp})); + return runPublish(getPublishCommand({...options, otp})); })), ) .pipe( diff --git a/source/npm/handle-npm-error.js b/source/npm/handle-npm-error.js index 9709e2cb..b4f8e6aa 100644 --- a/source/npm/handle-npm-error.js +++ b/source/npm/handle-npm-error.js @@ -9,7 +9,11 @@ const handleNpmError = (error, task, message, executor) => { } // `one-time pass` is for npm and `Two factor authentication` is for Yarn. - if (error.stderr.includes('one-time pass') || error.stdout.includes('Two factor authentication')) { + if ( + error.stderr.includes('one-time pass') // npm + || error.stdout.includes('Two factor authentication') // Yarn v1 + || error.stdout.includes('One-time password:') // Yarn berry + ) { const {title} = task; task.title = `${title} ${chalk.yellow('(waiting for input…)')}`; diff --git a/source/npm/publish.js b/source/npm/publish.js index aeb2131e..d7c8ba1f 100644 --- a/source/npm/publish.js +++ b/source/npm/publish.js @@ -19,3 +19,16 @@ export const getPackagePublishArguments = options => { return arguments_; }; + +export function runPublish(args) { + const cp = execa(...args); + + cp.stdout.on('data', chunk => { + // https://github.com/yarnpkg/berry/blob/a3e5695186f2aec3a68810acafc6c9b1e45191da/packages/plugin-npm/sources/npmHttpUtils.ts#L541 + if (chunk.toString('utf8').includes('One-time password:')) { + cp.kill(); + } + }) + + return cp; +} From ea9da25e80e856290ab6d8557ba24314380f9b7d Mon Sep 17 00:00:00 2001 From: Mikael Finstad Date: Fri, 5 Apr 2024 21:34:20 +0200 Subject: [PATCH 2/3] fix lint --- source/npm/handle-npm-error.js | 2 +- source/npm/publish.js | 8 +++++--- 2 files changed, 6 insertions(+), 4 deletions(-) diff --git a/source/npm/handle-npm-error.js b/source/npm/handle-npm-error.js index b4f8e6aa..1ebaefab 100644 --- a/source/npm/handle-npm-error.js +++ b/source/npm/handle-npm-error.js @@ -10,7 +10,7 @@ const handleNpmError = (error, task, message, executor) => { // `one-time pass` is for npm and `Two factor authentication` is for Yarn. if ( - error.stderr.includes('one-time pass') // npm + error.stderr.includes('one-time pass') // Npm || error.stdout.includes('Two factor authentication') // Yarn v1 || error.stdout.includes('One-time password:') // Yarn berry ) { diff --git a/source/npm/publish.js b/source/npm/publish.js index d7c8ba1f..f25ce2ee 100644 --- a/source/npm/publish.js +++ b/source/npm/publish.js @@ -1,3 +1,5 @@ +import {execa} from 'execa'; + export const getPackagePublishArguments = options => { const arguments_ = ['publish']; @@ -20,15 +22,15 @@ export const getPackagePublishArguments = options => { return arguments_; }; -export function runPublish(args) { - const cp = execa(...args); +export function runPublish(arguments_) { + const cp = execa(...arguments_); cp.stdout.on('data', chunk => { // https://github.com/yarnpkg/berry/blob/a3e5695186f2aec3a68810acafc6c9b1e45191da/packages/plugin-npm/sources/npmHttpUtils.ts#L541 if (chunk.toString('utf8').includes('One-time password:')) { cp.kill(); } - }) + }); return cp; } From 5e97814567888560c9bfacf45844da456ec4862d Mon Sep 17 00:00:00 2001 From: Mikael Finstad Date: Sat, 6 Apr 2024 23:10:14 +0200 Subject: [PATCH 3/3] fix tests --- test/index.js | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/test/index.js b/test/index.js index 047104d8..0224da46 100644 --- a/test/index.js +++ b/test/index.js @@ -62,7 +62,10 @@ test('skip enabling 2FA if the package exists', async t => { verifyWorkingTreeIsClean: sinon.stub(), }, '../source/npm/enable-2fa.js': enable2faStub, - '../source/npm/publish.js': sinon.stub().returns({pipe: sinon.stub()}), + '../source/npm/publish.js': { + getPackagePublishArguments: sinon.stub().returns([]), + runPublish: sinon.stub().returns(fakeExecaReturn()), + }, }); await t.notThrowsAsync(npMock('1.0.0', { @@ -91,7 +94,10 @@ test('skip enabling 2FA if the `2fa` option is false', async t => { verifyWorkingTreeIsClean: sinon.stub(), }, '../source/npm/enable-2fa.js': enable2faStub, - '../source/npm/publish.js': sinon.stub().returns({pipe: sinon.stub()}), + '../source/npm/publish.js': { + getPackagePublishArguments: sinon.stub().returns([]), + runPublish: sinon.stub().returns(fakeExecaReturn()), + }, }); await t.notThrowsAsync(npMock('1.0.0', {