Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/npm/cli.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorKat Marchán <kzm@sykosomatic.org>2017-01-06 05:08:35 +0300
committerC J Silverio <ceejceej@gmail.com>2017-02-10 02:37:51 +0300
commitd8ee340868106bac4ea8115b2c0fae5745085b1e (patch)
treee09bb1e628584fa9037594007e63ac33d2ad9c09 /test
parent77a0719d82c2b9cf18fe1b1a04ae332d5c006567 (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.js85
-rw-r--r--test/tap/adduser-saml.js85
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()
+})