node/deps/npm/node_modules/npm-registry-client/test/logout.js
Forrest L Norvell 1e2fa1537f deps: upgrade npm to 2.6.0
PR-URL: https://github.com/iojs/io.js/pull/904
Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl>
Reviewed-By: Colin Ihrig <cjihrig@gmail.com>
2015-02-22 07:42:24 +01:00

75 lines
1.5 KiB
JavaScript

var test = require("tap").test
var server = require("./lib/server.js")
var common = require("./lib/common.js")
var client = common.freshClient()
function nop () {}
var URI = "http://localhost:1337/rewrite"
var TOKEN = "b00b00feed"
var PARAMS = {
auth: {
token: TOKEN
}
}
test("logout call contract", function (t) {
t.throws(function () {
client.logout(undefined, PARAMS, nop)
}, "requires a URI")
t.throws(function () {
client.logout([], PARAMS, nop)
}, "requires URI to be a string")
t.throws(function () {
client.logout(URI, undefined, nop)
}, "requires params object")
t.throws(function () {
client.logout(URI, "", nop)
}, "params must be object")
t.throws(function () {
client.logout(URI, PARAMS, undefined)
}, "requires callback")
t.throws(function () {
client.logout(URI, PARAMS, "callback")
}, "callback must be function")
t.throws(
function () {
var params = {
auth: {}
}
client.logout(URI, params, nop)
},
{ name: "AssertionError", message: "can only log out for token auth" },
"auth must include token"
)
t.end()
})
test("log out from a token-based registry", function (t) {
server.expect("DELETE", "/-/user/token/" + TOKEN, function (req, res) {
t.equal(req.method, "DELETE")
t.equal(req.headers.authorization, "Bearer " + TOKEN, "request is authed")
res.json({message: "ok"})
})
client.logout(URI, PARAMS, function (er) {
t.ifError(er, "no errors")
t.end()
})
})
test("cleanup", function (t) {
server.close()
t.end()
})