var fs = require('graceful-fs') var path = require('path') var mr = require('npm-registry-mock') var test = require('tap').test var npm = require('../../') var common = require('../common-tap.js') // config var pkg = common.pkg var cache = common.cache var originalLog var json = { name: 'outdated', description: 'fixture', version: '0.0.1', dependencies: { underscore: '1.3.1', async: '0.2.9', checker: '0.5.1' } } test('setup', function (t) { originalLog = console.log fs.writeFileSync( path.join(pkg, 'package.json'), JSON.stringify(json, null, 2) ) process.chdir(pkg) t.end() }) test('it should not throw', function (t) { var output = [] var expOut = [ path.resolve(pkg, 'node_modules', 'async') + ':async@0.2.9' + ':async@0.2.9' + ':async@0.2.10' + '\n' + path.resolve(pkg, 'node_modules', 'checker') + ':checker@0.5.1' + ':checker@0.5.1' + ':checker@0.5.2' + '\n' + path.resolve(pkg, 'node_modules', 'underscore') + ':underscore@1.3.1' + ':underscore@1.3.1' + ':underscore@1.5.1' ] var expData = [ [ pkg, 'async', '0.2.9', '0.2.9', '0.2.10', '0.2.9', null ], [ pkg, 'checker', '0.5.1', '0.5.1', '0.5.2', '0.5.1', null ], [ pkg, 'underscore', '1.3.1', '1.3.1', '1.5.1', '1.3.1', null ] ] console.log = function () {} mr({ port: common.port }, function (er, s) { npm.load( { cache: cache, loglevel: 'silent', parseable: true, registry: common.registry }, function () { npm.install('.', function (err) { t.ifError(err, 'install success') console.log = function () { output.push.apply(output, arguments) } npm.outdated(function (er, d) { t.ifError(err, 'outdated completed without error') t.equals(process.exitCode, 1, 'exitCode set to 1') process.exitCode = 0 output = output.map(function (x) { return x.replace(/\r/g, '') }) console.log = originalLog t.same(output, expOut) t.same(d, expData) s.close() t.end() }) }) } ) }) }) test('cleanup', function (t) { console.log = originalLog t.end() })