summaryrefslogtreecommitdiff
path: root/deps/npm/test/tap/adduser-legacy-auth.js
blob: f9829c618ac7e8af9844b86ce03b2d0ad12c3cf6 (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
var fs = require('fs')
var path = require('path')
var mkdirp = require('mkdirp')
var rimraf = require('rimraf')
var mr = require('npm-registry-mock')

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

var opts = { cwd: __dirname }
var pkg = path.resolve(__dirname, 'adduser-legacy-auth')
var outfile = path.resolve(pkg, '_npmrc')

var contents = '_auth=' + new Buffer('u:x').toString('base64') + '\n' +
               'registry=https://nonexistent.lvh.me/registry\n' +
               'email=u@p.me\n'

var responses = {
  'Username': 'u\n',
  'Password': 'p\n',
  'Email': 'u@p.me\n'
}

function mocks (server) {
  server.filteringRequestBody(function (r) {
    if (r.match(/"_id":"org\.couchdb\.user:u"/)) {
      return 'auth'
    }
  })
  server.put('/-/user/org.couchdb.user:u', 'auth')
    .reply(409, { error: 'user exists' })
  server.get('/-/user/org.couchdb.user:u?write=true')
    .reply(200, { _rev: '3-deadcafebabebeef' })
  server.put(
    '/-/user/org.couchdb.user:u/-rev/3-deadcafebabebeef',
    'auth',
    { authorization: 'Basic dTpw' }
    ).reply(201, { username: 'u', password: 'p', email: 'u@p.me' })
}

test('setup', function (t) {
  mkdirp(pkg, function (er) {
    t.ifError(er, pkg + ' made successfully')

    fs.writeFile(outfile, contents, function (er) {
      t.ifError(er, 'wrote legacy config')

      t.end()
    })
  })
})

test('npm login', function (t) {
  mr({ port: common.port, plugin: mocks }, function (er, s) {
    var runner = common.npm(
    [
      'login',
      '--registry', common.registry,
      '--loglevel', 'silent',
      '--userconfig', outfile
    ],
    opts,
    function (err, code, stdout, stderr) {
      t.ifError(err, 'npm ran without issue')
      t.notOk(code, 'exited OK')
      t.notOk(stderr, 'no error output')
      var config = fs.readFileSync(outfile, 'utf8')
      t.like(config, /:always-auth=false/, 'always-auth is scoped and false (by default)')
      s.close()
      rimraf(outfile, function (err) {
        t.ifError(err, 'removed config file OK')
        t.end()
      })
    })

    var o = '', e = '', remaining = Object.keys(responses).length
    runner.stdout.on('data', function (chunk) {
      remaining--
      o += chunk

      var label = chunk.toString('utf8').split(':')[0]
      runner.stdin.write(responses[label])

      if (remaining === 0) runner.stdin.end()
    })
    runner.stderr.on('data', function (chunk) { e += chunk })
  })
})

test('cleanup', function (t) {
  rimraf.sync(pkg)
  t.pass('cleaned up')
  t.end()
})