1 // if "npm rebuild" is run with bundled dependencies,
2 // message "already built" should not be error
3 var test = require("tap").test
4 var path = require("path")
5 var osenv = require("osenv")
6 var rimraf = require("rimraf")
7 var npmlog = require("npmlog")
8 var mkdirp = require("mkdirp")
9 var requireInject = require("require-inject")
11 var npm = require("../../lib/npm.js")
13 var PKG_DIR = path.resolve(__dirname, "build-already-built")
16 test("setup", function (t) {
22 test("issue #6735 build 'already built' message", function (t) {
23 npm.load({loglevel : "warn"}, function () {
24 // capture log messages with level
26 npmlog.on("log", function (chunk) {
27 log += chunk.level + " " + chunk.message + "\n"
31 var folder = path.resolve(fakePkg)
33 var global = npm.config.get("global")
35 var build = requireInject("../../lib/build", {
38 t.test("pin previous behavior", function (t) {
40 build([fakePkg], global, false, false, function (err) {
41 t.ok(err, "build failed as expected")
42 t.similar(err.message, /package.json/, "missing package.json as expected")
43 t.notSimilar(log, /already built/, "no already built message written")
49 t.test("simulate rebuild of bundledDependency", function (t) {
53 build._didBuild[folder] = true
55 build([fakePkg], global, false, false, function (err) {
56 t.ok(err, "build failed as expected")
57 t.similar(err.message, /package.json/, "missing package.json as expected")
59 t.similar(log, /already built/, "already built message written")
60 t.notSimilar(log, /ERR! already built/, "already built message written is not error")
61 t.similar(log, /info already built/, "already built message written is info")
72 test("cleanup", function (t) {
79 process.chdir(osenv.tmpdir())