blob: 347364ea99e24b986945f5ac8e721ac33c7f644c [file] [log] [blame]
var tap = require('tap')
var crypto = require('crypto')
var fs = require('fs')
var server = require('./lib/server.js')
var common = require('./lib/common.js')
var auth = {
username: 'username',
password: '%1234@asdf%',
email: 'ogd@aoaioxxysz.net'
}
var client = common.freshClient()
var _auth = new Buffer('username:%1234@asdf%').toString('base64')
tap.test('publish', function (t) {
// not really a tarball, but doesn't matter
var bodyPath = require.resolve('../package.json')
var tarball = fs.createReadStream(bodyPath)
var pd = fs.readFileSync(bodyPath)
var pkg = require('../package.json')
pkg.name = '@npm/npm-registry-client'
server.expect('/@npm%2fnpm-registry-client', function (req, res) {
t.equal(req.method, 'PUT')
t.equal(req.headers.authorization, 'Basic ' + _auth)
var b = ''
req.setEncoding('utf8')
req.on('data', function (d) {
b += d
})
req.on('end', function () {
var o = JSON.parse(b)
t.equal(o._id, '@npm/npm-registry-client')
t.equal(o['dist-tags'].latest, pkg.version)
t.has(o.versions[pkg.version], pkg)
t.same(o.maintainers, [ { name: 'username', email: 'ogd@aoaioxxysz.net' } ])
t.same(o.maintainers, o.versions[pkg.version].maintainers)
var att = o._attachments[ pkg.name + '-' + pkg.version + '.tgz' ]
t.same(att.data, pd.toString('base64'))
var hash = crypto.createHash('sha1').update(pd).digest('hex')
t.equal(o.versions[pkg.version].dist.shasum, hash)
res.statusCode = 201
res.json({ created: true })
})
})
var params = {
metadata: pkg,
access: 'restricted',
body: tarball,
auth: auth
}
client.publish(common.registry, params, function (er, data) {
if (er) throw er
t.deepEqual(data, { created: true })
server.close()
t.end()
})
})