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() }) })