summaryrefslogtreecommitdiff
path: root/deps/npm/test/tap/outdated-json.js
blob: 77db52cc725211316478f406af9fe422a6e7d247 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
var fs = require('graceful-fs')
var path = require('path')

var mr = require('npm-registry-mock')
var test = require('tap').test

var common = require('../common-tap.js')
var server

var pkg = common.pkg

var EXEC_OPTS = { cwd: pkg }

var json = {
  name: 'outdated-json',
  author: 'Rockbert',
  version: '0.0.0',
  dependencies: {
    underscore: '~1.3.1'
  },
  devDependencies: {
    request: '~0.9.0'
  }
}

var expected = {
  underscore: {
    current: '1.3.3',
    wanted: '1.3.3',
    latest: '1.5.1',
    location: 'node_modules' + path.sep + 'underscore'
  },
  request: {
    current: '0.9.5',
    wanted: '0.9.5',
    latest: '2.27.0',
    location: 'node_modules' + path.sep + 'request'
  }
}

test('setup', function (t) {
  fs.writeFileSync(
    path.join(pkg, 'package.json'),
    JSON.stringify(json, null, 2)
  )
  process.chdir(pkg)
  mr({ port: common.port }, function (er, s) {
    t.ifError(er, 'mock registry should never fail to start')
    server = s
    common.npm(
      [
        '--registry', common.registry,
        '--silent',
        'install'
      ],
      EXEC_OPTS,
      function (err, code) {
        t.ifError(err, 'npm install ran without issue')
        t.notOk(code, 'npm install ran without raising error code')

        t.end()
      }
    )
  })
})

test('it should log json data', function (t) {
  common.npm(
    [
      '--registry', common.registry,
      '--silent',
      '--json',
      'outdated'
    ],
    EXEC_OPTS,
    function (err, code, stdout) {
      t.ifError(err, 'npm outdated ran without error')
      t.is(code, 1, 'npm outdated exited with code 1')
      var out
      t.doesNotThrow(function () {
        out = JSON.parse(stdout)
      }, 'output correctly parsed as JSON')
      t.deepEqual(out, expected)

      t.end()
    }
  )
})

test('it should log json data even when the list is empty', function (t) {
  common.npm(
    [
      'rm',
      'request',
      'underscore'
    ],
    EXEC_OPTS,
    function (er, code, stdout) {
      t.ifError(er, 'run without error')
      t.is(code, 0, 'successful exit status')
      common.npm(
        [
          '--registry', common.registry,
          '--silent',
          '--json',
          'outdated'
        ],
        EXEC_OPTS,
        function (er, code, stdout) {
          t.ifError(er, 'run without error')
          t.is(code, 0, 'successful exit status')
          t.same(JSON.parse(stdout), {}, 'got an empty object printed')
          t.end()
        }
      )
    }
  )
})

test('cleanup', function (t) {
  server.close()
  t.end()
})