blob: 962ab72444747b33e0dae2bb5f151ed832978af3 [file] [log] [blame]
// if "npm init" is interrupted with ^C, don't report
// "init written successfully"
var test = require("tap").test
var path = require("path")
var osenv = require("osenv")
var rimraf = require("rimraf")
var npmlog = require("npmlog")
var requireInject = require("require-inject")
var npm = require("../../lib/npm.js")
var PKG_DIR = path.resolve(__dirname, "init-interrupt")
test("setup", function (t) {
cleanup()
t.end()
})
test("issue #6684 remove confusing message", function (t) {
var initJsonMock = function (dir, input, config, cb) {
process.nextTick(function () {
cb({message : "canceled"})
})
}
initJsonMock.yes = function () { return true }
npm.load({loglevel : "silent"}, function () {
var log = ""
var init = requireInject("../../lib/init", {
"init-package-json": initJsonMock
})
// capture log messages
npmlog.on("log", function (chunk) { log += chunk.message + "\n" } )
init([], function (err, code) {
t.ifError(err, "init ran successfully")
t.notOk(code, "exited without issue")
t.notSimilar(log, /written successfully/, "no success message written")
t.similar(log, /canceled/, "alerted that init was canceled")
t.end()
})
})
})
test("cleanup", function (t) {
cleanup()
t.end()
})
function cleanup () {
process.chdir(osenv.tmpdir())
rimraf.sync(PKG_DIR)
}