-
Notifications
You must be signed in to change notification settings - Fork 3.4k
/
Copy pathadduser-oauth.js
82 lines (74 loc) · 2.24 KB
/
adduser-oauth.js
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
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: common.pkg }
var pkg = common.pkg
var fakeBrowser = path.resolve(pkg, '_script.sh')
var configfile = path.resolve(pkg, '_npmrc')
var outfile = path.resolve(pkg, '_outfile')
var ssoUri = common.registry + '/-/oauth/foo'
common.pendIfWindows('This is trickier to convert without opening new shells')
function mocks (server) {
server.filteringRequestBody(function (r) {
if (r.match(/"_id":"org\.couchdb\.user:npm_oauth_auth_dummy_user"/)) {
return 'auth'
} else {
return 'invalid'
}
})
server.post('/-/v1/#', 'invalid').reply(404, 'not found')
server.put('/-/user/org.couchdb.user:npm_oauth_auth_dummy_user', 'auth')
.reply(201, { token: 'foo', sso: ssoUri })
}
test('setup', function (t) {
mkdirp.sync(pkg)
fs.writeFileSync(configfile, '')
var s = '#!/usr/bin/env bash\n' +
'echo "$@" > ' + outfile + '\n'
fs.writeFileSync(fakeBrowser, s, 'ascii')
fs.chmodSync(fakeBrowser, '0755')
t.pass('made script')
t.end()
})
test('npm login', function (t) {
mr({ port: common.port, plugin: mocks }, function (er, s) {
s.get(
'/-/whoami', { authorization: 'Bearer foo' }
).max(1).reply(401, {})
common.npm(
[
'login',
'--registry', common.registry,
'--auth-type=oauth',
'--loglevel', 'silent',
'--userconfig', configfile,
'--browser', fakeBrowser
],
opts,
function (err, code, stdout, stderr) {
t.ifError(err, 'npm ran without issue')
t.equal(code, 0, 'exited OK')
t.notOk(stderr, 'no error output')
stderr && t.comment('stderr - ', stderr)
t.matches(stdout, /Logged in as igotauthed/,
'successfully authenticated and output the given username')
s.close()
rimraf.sync(configfile)
rimraf.sync(outfile)
t.end()
}
)
s.get(
'/-/whoami', { authorization: 'Bearer foo' }
).reply(200, { username: 'igotauthed' })
})
})
test('cleanup', function (t) {
rimraf.sync(pkg)
t.pass('cleaned up')
t.end()
})