node/deps/npm/test/tap/publish-config.js

52 lines
1.5 KiB
JavaScript
Raw Normal View History

2013-11-21 03:08:52 +08:00
var common = require('../common-tap.js')
2012-08-22 06:29:03 +08:00
var test = require('tap').test
var fs = require('fs')
2013-10-25 00:21:59 +08:00
var osenv = require('osenv')
2012-08-22 06:29:03 +08:00
var pkg = process.env.npm_config_tmp || '/tmp'
pkg += '/npm-test-publish-config'
require('mkdirp').sync(pkg)
fs.writeFileSync(pkg + '/package.json', JSON.stringify({
name: 'npm-test-publish-config',
version: '1.2.3',
2013-11-21 03:08:52 +08:00
publishConfig: { registry: common.registry }
2012-08-22 06:29:03 +08:00
}), 'utf8')
var spawn = require('child_process').spawn
var npm = require.resolve('../../bin/npm-cli.js')
var node = process.execPath
test(function (t) {
var child
require('http').createServer(function (req, res) {
t.pass('got request on the fakey fake registry')
t.end()
this.close()
res.statusCode = 500
res.end('{"error":"sshhh. naptime nao. \\^O^/ <(YAWWWWN!)"}')
child.kill()
2013-11-21 03:08:52 +08:00
}).listen(common.port, function () {
2012-08-22 06:29:03 +08:00
t.pass('server is listening')
// don't much care about listening to the child's results
// just wanna make sure it hits the server we just set up.
//
// there are plenty of other tests to verify that publish
// itself functions normally.
2013-05-15 05:37:59 +08:00
//
// Make sure that we don't sit around waiting for lock files
2013-12-12 02:20:26 +08:00
child = spawn(node, [npm, 'publish', '--email=fancy', '--_auth=feast'], {
2013-05-15 05:37:59 +08:00
cwd: pkg,
env: {
npm_config_cache_lock_stale: 1000,
npm_config_cache_lock_wait: 1000,
HOME: process.env.HOME,
Path: process.env.PATH,
2013-10-25 00:21:59 +08:00
PATH: process.env.PATH,
USERPROFILE: osenv.home()
2013-05-15 05:37:59 +08:00
}
2012-08-22 06:29:03 +08:00
})
})
})