diff options
author | Kat Marchán <kzm@sykosomatic.org> | 2017-01-06 05:08:35 +0300 |
---|---|---|
committer | C J Silverio <ceejceej@gmail.com> | 2017-02-10 02:37:51 +0300 |
commit | d8ee340868106bac4ea8115b2c0fae5745085b1e (patch) | |
tree | e09bb1e628584fa9037594007e63ac33d2ad9c09 /test | |
parent | 77a0719d82c2b9cf18fe1b1a04ae332d5c006567 (diff) |
test: add tests for oauth and saml support
PR-URL: https://github.com/npm/npm/pull/13389
Credit: @zkat
Reviewed-By: @iarna
Diffstat (limited to 'test')
-rw-r--r-- | test/tap/adduser-oauth.js | 85 | ||||
-rw-r--r-- | test/tap/adduser-saml.js | 85 |
2 files changed, 170 insertions, 0 deletions
diff --git a/test/tap/adduser-oauth.js b/test/tap/adduser-oauth.js new file mode 100644 index 000000000..dc4ff895e --- /dev/null +++ b/test/tap/adduser-oauth.js @@ -0,0 +1,85 @@ +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-oauth') +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' + } + }) + 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, {}) + var runner = 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() + } + ) + + var buf = '' + runner.stdout.on('data', function (chunk) { + buf += chunk.toString('utf8') + if (buf.match(/complete authentication/)) { + s.get( + '/-/whoami', { authorization: 'Bearer foo' } + ).reply(200, { username: 'igotauthed' }) + } + }) + }) +}) + +test('cleanup', function (t) { + rimraf.sync(pkg) + t.pass('cleaned up') + t.end() +}) diff --git a/test/tap/adduser-saml.js b/test/tap/adduser-saml.js new file mode 100644 index 000000000..7fd1da239 --- /dev/null +++ b/test/tap/adduser-saml.js @@ -0,0 +1,85 @@ +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-saml') +var fakeBrowser = path.resolve(pkg, '_script.sh') +var configfile = path.resolve(pkg, '_npmrc') +var outfile = path.resolve(pkg, '_outfile') +var ssoUri = common.registry + '/-/saml/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_saml_auth_dummy_user"/)) { + return 'auth' + } + }) + server.put('/-/user/org.couchdb.user:npm_saml_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, {}) + var runner = common.npm( + [ + 'login', + '--registry', common.registry, + '--auth-type=saml', + '--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() + } + ) + + var buf = '' + runner.stdout.on('data', function (chunk) { + buf += chunk.toString('utf8') + if (buf.match(/complete authentication/)) { + s.get( + '/-/whoami', { authorization: 'Bearer foo' } + ).reply(200, { username: 'igotauthed' }) + } + }) + }) +}) + +test('cleanup', function (t) { + rimraf.sync(pkg) + t.pass('cleaned up') + t.end() +}) |