aboutsummaryrefslogtreecommitdiff
path: root/deps/npm/test/tap/ci-header.js
diff options
context:
space:
mode:
Diffstat (limited to 'deps/npm/test/tap/ci-header.js')
-rw-r--r--deps/npm/test/tap/ci-header.js139
1 files changed, 139 insertions, 0 deletions
diff --git a/deps/npm/test/tap/ci-header.js b/deps/npm/test/tap/ci-header.js
new file mode 100644
index 0000000000..dc20cc53c3
--- /dev/null
+++ b/deps/npm/test/tap/ci-header.js
@@ -0,0 +1,139 @@
+'use strict'
+var path = require('path')
+var test = require('tap').test
+var mr = require('npm-registry-mock')
+var Tacks = require('tacks')
+var File = Tacks.File
+var Dir = Tacks.Dir
+var chain = require('slide').chain
+var common = require('../common-tap.js')
+
+var basedir = path.join(__dirname, path.basename(__filename, '.js'))
+var testdir = path.join(basedir, 'testdir')
+var cachedir = path.join(basedir, 'cache')
+var globaldir = path.join(basedir, 'global')
+var tmpdir = path.join(basedir, 'tmp')
+
+var ciKeys = ['CI', 'TDDIUM', 'JENKINS_URL', 'bamboo.buildKey']
+
+var filteredEnv = common.newEnv().delete(ciKeys)
+
+var conf = function (extraEnv) {
+ return {
+ cwd: testdir,
+ env: filteredEnv.clone().extend(extraEnv, {
+ npm_config_cache: cachedir,
+ npm_config_tmp: tmpdir,
+ npm_config_prefix: globaldir,
+ npm_config_registry: common.registry,
+ npm_config_loglevel: 'warn'
+ })
+ }
+}
+
+var server
+var fixture = new Tacks(Dir({
+ cache: Dir(),
+ global: Dir(),
+ tmp: Dir(),
+ testdir: Dir({
+ 'package.json': File({
+ name: 'example',
+ version: '1.0.0'
+ })
+ })
+}))
+
+function setup () {
+ cleanup()
+ fixture.create(basedir)
+}
+
+function cleanup () {
+ fixture.remove(basedir)
+}
+
+var ciHeaderTestCI = {
+ 'time': {'1.0.0': ''},
+ 'dist-tags': {'latest': '1.0.0'},
+ 'versions': {
+ '1.0.0': {
+ name: 'ci-header-test',
+ version: '1.0.0',
+ gotCI: true
+ }
+ }
+}
+var ciHeaderTestNotCI = {
+ 'time': {'1.0.0': ''},
+ 'dist-tags': {'latest': '1.0.0'},
+ 'versions': {
+ '1.0.0': {
+ name: 'ci-header-test',
+ version: '1.0.0',
+ gotCI: false
+ }
+ }
+}
+
+var ciHeaderTestNoCI = {
+ 'time': {'1.0.0': ''},
+ 'dist-tags': {'latest': '1.0.0'},
+ 'versions': {
+ '1.0.0': {
+ name: 'ci-header-test',
+ version: '1.0.0',
+ gotCI: null
+ }
+ }
+}
+
+test('setup', function (t) {
+ setup()
+ mr({port: common.port, throwOnUnmatched: true}, function (err, s) {
+ if (err) throw err
+ server = s
+ server.get('/ci-header-test', {
+ 'NPM-In-CI': 'true'
+ }).many().reply('200', ciHeaderTestCI)
+ server.get('/ci-header-test', {
+ 'NPM-In-CI': 'false'
+ }).many().reply('200', ciHeaderTestNotCI)
+ server.get('/ci-header-test', {}).many().reply('200', ciHeaderTestNoCI)
+ t.done()
+ })
+})
+
+test('various-ci', function (t) {
+ var todo = ciKeys.map(function (key) { return [checkKey, key] })
+ return chain(todo, t.done)
+
+ function checkKey (key, next) {
+ var env = {}
+ env[key] = 'true'
+
+ common.npm(['view', '--cache-min=0', 'ci-header-test', 'gotCI'], conf(env), function (err, code, stdout, stderr) {
+ if (err) throw err
+ t.is(code, 0, key + ' command ran ok')
+ if (stderr.trim()) t.comment(stderr.trim())
+ t.is(stdout.trim(), 'true', key + ' set results in CI header')
+ next()
+ })
+ }
+})
+
+test('no-ci', function (t) {
+ common.npm(['view', '--cache-min=0', 'ci-header-test', 'gotCI'], conf(), function (err, code, stdout, stderr) {
+ if (err) throw err
+ t.is(code, 0, 'No CI env, command ran ok')
+ if (stderr.trim()) t.comment(stderr.trim())
+ t.is(stdout.trim(), 'false', 'No CI env, not in CI')
+ t.done()
+ })
+})
+
+test('cleanup', function (t) {
+ server.close()
+ cleanup()
+ t.done()
+})