summaryrefslogtreecommitdiff
path: root/deps/npm/node_modules/npm-registry-client/test/adduser-update.js
blob: 03a1edbb26f62f63d2df1c8f44f1db003e7cc9f2 (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
var tap = require('tap')
var server = require('./fixtures/server.js')
var RC = require('../')
var client = new RC({
    cache: __dirname + '/fixtures/cache'
  , registry: 'http://localhost:' + server.port })

var userdata =
{ name: 'username',
  email: 'i@izs.me',
  _id: 'org.couchdb.user:username',
  type: 'user',
  roles: [],
  _rev: "1-15aac515ac515aac515aac515aac5125"
}

, password = "password"
, username = "username"
, crypto = require("crypto")
, SD = require('string_decoder').StringDecoder
, decoder = new SD


function sha (s) {
  return crypto.createHash("sha1").update(s).digest("hex")
}

tap.test("update a user acct", function (t) {
  server.expect("PUT", "/-/user/org.couchdb.user:username", function (req, res) {
    t.equal(req.method, "PUT")
    res.statusCode = 409
    res.json({error: "conflict"})
  })

  server.expect("GET", "/-/user/org.couchdb.user:username", function (req, res) {
    t.equal(req.method, "GET")
    res.json(userdata)
  })

  server.expect("PUT", "/-/user/org.couchdb.user:username/-rev/" + userdata._rev, function (req, res) {
    t.equal(req.method, "PUT")

    var b = ""
    req.on("data", function (d) {
      b += decoder.write(d)
    })

    req.on("end", function () {
      var o = JSON.parse(b)
      var salt = o.salt
      userdata.salt = salt
      userdata.password_sha = sha(password + salt)
      userdata.date = o.date
      t.deepEqual(o, userdata)

      res.statusCode = 201
      res.json({created:true})
    })
  })



  client.adduser(username, password, "i@izs.me", function (er, data, raw, res) {
    if (er) throw er
    t.deepEqual(data, { created: true })
    t.end()
  })
})