summaryrefslogtreecommitdiff
path: root/deps/npm/test/tap/shrinkwrap-complete-except-dev.js
diff options
context:
space:
mode:
Diffstat (limited to 'deps/npm/test/tap/shrinkwrap-complete-except-dev.js')
-rw-r--r--deps/npm/test/tap/shrinkwrap-complete-except-dev.js159
1 files changed, 159 insertions, 0 deletions
diff --git a/deps/npm/test/tap/shrinkwrap-complete-except-dev.js b/deps/npm/test/tap/shrinkwrap-complete-except-dev.js
new file mode 100644
index 0000000000..156721507f
--- /dev/null
+++ b/deps/npm/test/tap/shrinkwrap-complete-except-dev.js
@@ -0,0 +1,159 @@
+'use strict'
+var fs = require('graceful-fs')
+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 extend = Object.assign || require('util')._extend
+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 appdir = path.join(testdir, 'app')
+var installedModuleA = path.join(appdir, 'node_modules', 'module-a')
+var installedModuleB = path.join(installedModuleA, 'node_modules', 'module-b')
+var installedModuleC = path.join(appdir, 'node_modules', 'module-c')
+var installedModuleD = path.join(appdir, 'node_modules', 'module-d')
+
+var conf = {
+ cwd: appdir,
+ env: extend(extend({}, process.env), {
+ 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({
+ app: Dir({
+ 'npm-shrinkwrap.json': File({
+ name: 'app',
+ version: '1.0.0',
+ dependencies: {
+ 'module-a': {
+ version: '1.0.0',
+ from: '../module-a',
+ resolved: 'file:../module-a',
+ dependencies: {
+ 'module-b': {
+ version: '1.0.0',
+ from: '../module-b',
+ resolved: 'file:../module-b'
+ }
+ }
+ }
+ }
+ }),
+ 'package.json': File({
+ name: 'app',
+ version: '1.0.0',
+ dependencies: {
+ 'module-a': '../module-a'
+ },
+ devDependencies: {
+ 'module-d': '../module-d'
+ }
+ })
+ }),
+ 'module-a': Dir({
+ 'package.json': File({
+ name: 'module-a',
+ version: '1.0.0',
+ dependencies: {
+ 'module-b': 'file:' + path.join(testdir, 'module-b'),
+ 'module-c': 'file:' + path.join(testdir, 'module-c')
+ }
+ })
+ }),
+ 'module-b': Dir({
+ 'package.json': File({
+ name: 'module-b',
+ version: '1.0.0'
+ })
+ }),
+ 'module-c': Dir({
+ 'package.json': File({
+ name: 'module-c',
+ version: '1.0.0'
+ })
+ }),
+ 'module-d': Dir({
+ 'package.json': File({
+ name: 'module-d',
+ version: '1.0.0'
+ })
+ })
+ })
+}))
+
+function exists (t, filepath, msg) {
+ try {
+ fs.statSync(filepath)
+ t.pass(msg)
+ return true
+ } catch (ex) {
+ t.fail(msg, {found: ex, wanted: 'exists', compare: 'fs.stat(' + filepath + ')'})
+ return false
+ }
+}
+
+function notExists (t, filepath, msg) {
+ try {
+ fs.statSync(filepath)
+ t.fail(msg, {found: true, wanted: 'does not exist', compare: 'fs.stat(' + filepath + ')'})
+ return true
+ } catch (ex) {
+ t.pass(msg)
+ return false
+ }
+}
+
+function setup () {
+ cleanup()
+ fixture.create(basedir)
+}
+
+function cleanup () {
+ fixture.remove(basedir)
+}
+
+test('setup', function (t) {
+ setup()
+ mr({port: common.port, throwOnUnmatched: true}, function (err, s) {
+ if (err) throw err
+ server = s
+ t.done()
+ })
+})
+
+test('example', function (t) {
+ common.npm(['install'], conf, function (err, code, stdout, stderr) {
+ if (err) throw err
+ t.is(code, 0, 'command ran ok')
+ t.comment('1> ' + stdout.trim())
+ t.comment('2> ' + stderr.trim())
+ exists(t, installedModuleA, 'module-a: dep in shrinkwrap installed')
+ exists(t, installedModuleB, 'module-b: nested dep from shrinkwrap nested')
+ notExists(t, installedModuleC, 'module-c: dependency not installed because not in shrinkwrap')
+ exists(t, installedModuleD, 'module-d: dev dependency installed despite not being in shrinkwrap')
+ t.done()
+ })
+})
+
+test('cleanup', function (t) {
+ server.close()
+ cleanup()
+ t.done()
+})