mirror of https://github.com/lukechilds/node.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
78 lines
2.0 KiB
78 lines
2.0 KiB
// if "npm rebuild" is run with bundled dependencies,
|
|
// message "already built" should not be error
|
|
var test = require('tap').test
|
|
var path = require('path')
|
|
var osenv = require('osenv')
|
|
var rimraf = require('rimraf')
|
|
var npmlog = require('npmlog')
|
|
var mkdirp = require('mkdirp')
|
|
var requireInject = require('require-inject')
|
|
|
|
var npm = require('../../lib/npm.js')
|
|
|
|
var PKG_DIR = path.resolve(__dirname, 'build-already-built')
|
|
var fakePkg = 'foo'
|
|
|
|
test('setup', function (t) {
|
|
cleanup()
|
|
|
|
t.end()
|
|
})
|
|
|
|
test("issue #6735 build 'already built' message", function (t) {
|
|
npm.load({ loglevel: 'warn' }, function () {
|
|
// capture log messages with level
|
|
var log = ''
|
|
npmlog.on('log', function (chunk) {
|
|
log += chunk.level + ' ' + chunk.message + '\n'
|
|
})
|
|
|
|
mkdirp.sync(fakePkg)
|
|
var folder = path.resolve(fakePkg)
|
|
|
|
var global = npm.config.get('global')
|
|
|
|
var build = requireInject('../../lib/build', {
|
|
})
|
|
|
|
t.test('pin previous behavior', function (t) {
|
|
build([fakePkg], global, false, false, function (err) {
|
|
t.ok(err, 'build failed as expected')
|
|
t.similar(err.message, /package.json/, 'missing package.json as expected')
|
|
t.notSimilar(log, /already built/, 'no already built message written')
|
|
|
|
t.end()
|
|
})
|
|
})
|
|
|
|
t.test('simulate rebuild of bundledDependency', function (t) {
|
|
log = ''
|
|
|
|
build._didBuild[folder] = true
|
|
|
|
build([fakePkg], global, false, false, function (err) {
|
|
t.ok(err, 'build failed as expected')
|
|
t.similar(err.message, /package.json/, 'missing package.json as expected')
|
|
|
|
t.similar(log, /already built/, 'already built message written')
|
|
t.notSimilar(log, /ERR! already built/, 'already built message written is not error')
|
|
t.similar(log, /info already built/, 'already built message written is info')
|
|
|
|
t.end()
|
|
})
|
|
})
|
|
|
|
t.end()
|
|
})
|
|
})
|
|
|
|
test('cleanup', function (t) {
|
|
cleanup()
|
|
|
|
t.end()
|
|
})
|
|
|
|
function cleanup () {
|
|
process.chdir(osenv.tmpdir())
|
|
rimraf.sync(PKG_DIR)
|
|
}
|
|
|