-
Notifications
You must be signed in to change notification settings - Fork 3.3k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
fix(libnpmexec): don't detach output from npm
The npm output function refers to this.log. libnpmexec has that passed in, which decoupled the function from the npm object. This fixes it, and sets the tests up in a way where if the output function ever becomes detached from this.npm in the same way, tests will fail. PR-URL: #3329 Credit: @wraithgar Close: #3329 Reviewed-by: @ruyadorno
- Loading branch information
Showing
6 changed files
with
89 additions
and
48 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,8 +1,6 @@ | ||
const t = require('tap') | ||
const mockNpm = require('../fixtures/mock-npm') | ||
const { resolve, delimiter } = require('path') | ||
const OUTPUT = [] | ||
const output = (...msg) => OUTPUT.push(msg) | ||
|
||
const ARB_CTOR = [] | ||
const ARB_ACTUAL_TREE = {} | ||
|
@@ -36,6 +34,7 @@ const config = { | |
package: [], | ||
'script-shell': 'shell-cmd', | ||
} | ||
|
||
const npm = mockNpm({ | ||
flatOptions, | ||
config, | ||
|
@@ -53,7 +52,6 @@ const npm = mockNpm({ | |
LOG_WARN.push(args) | ||
}, | ||
}, | ||
output, | ||
}) | ||
|
||
const RUN_SCRIPTS = [] | ||
|
@@ -225,7 +223,7 @@ t.test('npm exec <noargs>, run interactive shell', t => { | |
ARB_CTOR.length = 0 | ||
MKDIRPS.length = 0 | ||
ARB_REIFY.length = 0 | ||
OUTPUT.length = 0 | ||
npm._mockOutputs.length = 0 | ||
exec.exec([], er => { | ||
if (er) | ||
throw er | ||
|
@@ -256,7 +254,7 @@ t.test('npm exec <noargs>, run interactive shell', t => { | |
process.stdin.isTTY = true | ||
run(t, true, () => { | ||
t.strictSame(LOG_WARN, []) | ||
t.strictSame(OUTPUT, [ | ||
t.strictSame(npm._mockOutputs, [ | ||
[`\nEntering npm script environment at location:\n${process.cwd()}\nType 'exit' or ^D when finished\n`], | ||
], 'printed message about interactive shell') | ||
t.end() | ||
|
@@ -270,7 +268,7 @@ t.test('npm exec <noargs>, run interactive shell', t => { | |
|
||
run(t, true, () => { | ||
t.strictSame(LOG_WARN, []) | ||
t.strictSame(OUTPUT, [ | ||
t.strictSame(npm._mockOutputs, [ | ||
[`\u001b[0m\u001b[0m\n\u001b[0mEntering npm script environment\u001b[0m\u001b[0m at location:\u001b[0m\n\u001b[0m\u001b[2m${process.cwd()}\u001b[22m\u001b[0m\u001b[1m\u001b[22m\n\u001b[1mType 'exit' or ^D when finished\u001b[22m\n\u001b[1m\u001b[22m`], | ||
], 'printed message about interactive shell') | ||
t.end() | ||
|
@@ -282,7 +280,7 @@ t.test('npm exec <noargs>, run interactive shell', t => { | |
process.stdin.isTTY = false | ||
run(t, true, () => { | ||
t.strictSame(LOG_WARN, []) | ||
t.strictSame(OUTPUT, [], 'no message about interactive shell') | ||
t.strictSame(npm._mockOutputs, [], 'no message about interactive shell') | ||
t.end() | ||
}) | ||
}) | ||
|
@@ -294,7 +292,7 @@ t.test('npm exec <noargs>, run interactive shell', t => { | |
t.strictSame(LOG_WARN, [ | ||
['exec', 'Interactive mode disabled in CI environment'], | ||
]) | ||
t.strictSame(OUTPUT, [], 'no message about interactive shell') | ||
t.strictSame(npm._mockOutputs, [], 'no message about interactive shell') | ||
t.end() | ||
}) | ||
}) | ||
|
@@ -316,7 +314,7 @@ t.test('npm exec <noargs>, run interactive shell', t => { | |
ARB_CTOR.length = 0 | ||
MKDIRPS.length = 0 | ||
ARB_REIFY.length = 0 | ||
OUTPUT.length = 0 | ||
npm._mockOutputs.length = 0 | ||
RUN_SCRIPTS.length = 0 | ||
t.end() | ||
}) | ||
|
@@ -1195,22 +1193,22 @@ t.test('workspaces', t => { | |
return rej(er) | ||
|
||
t.strictSame(LOG_WARN, []) | ||
t.strictSame(OUTPUT, [ | ||
t.strictSame(npm._mockOutputs, [ | ||
[`\nEntering npm script environment in workspace [email protected] at location:\n${resolve(npm.localPrefix, 'packages/a')}\nType 'exit' or ^D when finished\n`], | ||
], 'printed message about interactive shell') | ||
res() | ||
}) | ||
}) | ||
|
||
config.color = true | ||
OUTPUT.length = 0 | ||
npm._mockOutputs.length = 0 | ||
await new Promise((res, rej) => { | ||
exec.execWorkspaces([], ['a'], er => { | ||
if (er) | ||
return rej(er) | ||
|
||
t.strictSame(LOG_WARN, []) | ||
t.strictSame(OUTPUT, [ | ||
t.strictSame(npm._mockOutputs, [ | ||
[`\u001b[0m\u001b[0m\n\u001b[0mEntering npm script environment\u001b[0m\u001b[0m in workspace \u001b[[email protected]\u001b[39m at location:\u001b[0m\n\u001b[0m\u001b[2m${resolve(npm.localPrefix, 'packages/a')}\u001b[22m\u001b[0m\u001b[1m\u001b[22m\n\u001b[1mType 'exit' or ^D when finished\u001b[22m\n\u001b[1m\u001b[22m`], | ||
], 'printed message about interactive shell') | ||
res() | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters