Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/npm/cli.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorRebecca Turner <me@re-becca.org>2017-05-10 23:55:00 +0300
committerRebecca Turner <me@re-becca.org>2017-05-26 04:55:13 +0300
commiteca4f1f34e0fff579902d4d678f9c5ac845e0c59 (patch)
tree4e6202df5b2e63062148e1cdb15806e86ba00d4f /test
parente02601c4dafd109faf6ddfc4343c9b059e8b2aa0 (diff)
test: shrinkwrap-nested
Diffstat (limited to 'test')
-rw-r--r--test/tap/shrinkwrap-nested.js (renamed from test/need-npm5-update/shrinkwrap-nested.js)58
1 files changed, 38 insertions, 20 deletions
diff --git a/test/need-npm5-update/shrinkwrap-nested.js b/test/tap/shrinkwrap-nested.js
index 92c81f29e..d94e5ce22 100644
--- a/test/need-npm5-update/shrinkwrap-nested.js
+++ b/test/tap/shrinkwrap-nested.js
@@ -1,5 +1,6 @@
'use strict'
var test = require('tap').test
+var Bluebird = require('bluebird')
var Tacks = require('tacks')
var File = Tacks.File
var Dir = Tacks.Dir
@@ -8,16 +9,16 @@ var path = require('path')
var common = require('../common-tap.js')
var testdir = path.resolve(__dirname, path.basename(__filename, '.js'))
-var modAdir = path.resolve(testdir, 'modA')
-var modB1dir = path.resolve(testdir, 'modB@1')
-var modB2dir = path.resolve(testdir, 'modB@2')
-var modCdir = path.resolve(testdir, 'modC')
+var modAtgz = path.resolve(testdir, 'modA') + '-1.0.0.tgz'
+var modB1tgz = path.resolve(testdir, 'modB') + '-1.0.0.tgz'
+var modB2tgz = path.resolve(testdir, 'modB') + '-2.0.0.tgz'
+var modCtgz = path.resolve(testdir, 'modC') + '-1.0.0.tgz'
var fixture = new Tacks(Dir({
'package.json': File({
dependencies: {
- modA: 'file://' + modAdir,
- modC: 'file://' + modCdir
+ modA: 'file://' + modAtgz,
+ modC: 'file://' + modCtgz
}
}),
'npm-shrinkwrap.json': File({
@@ -25,12 +26,12 @@ var fixture = new Tacks(Dir({
modA: {
version: '1.0.0',
from: 'modA',
- resolved: 'file://' + modAdir
+ resolved: 'file://' + modAtgz
},
modB: {
version: '1.0.0',
from: 'modB@1',
- resolved: 'file://' + modB1dir
+ resolved: 'file://' + modB1tgz
}
}
}),
@@ -39,7 +40,7 @@ var fixture = new Tacks(Dir({
name: 'modA',
version: '1.0.0',
dependencies: {
- 'modB': 'file://' + modB1dir
+ 'modB': 'file://' + modB1tgz
}
})
}),
@@ -62,7 +63,7 @@ var fixture = new Tacks(Dir({
name: 'modC',
version: '1.0.0',
dependencies: {
- 'modB': 'file://' + modB2dir
+ 'modB': 'file://' + modB2tgz
}
})
})
@@ -74,22 +75,22 @@ var newShrinkwrap = new Tacks(Dir({
modA: {
version: '1.0.0',
from: 'modA',
- resolved: 'file://' + modAdir
+ resolved: 'file://' + modAtgz
},
modB: {
version: '1.0.0',
from: 'modB@1',
- resolved: 'file://' + modB1dir
+ resolved: 'file://' + modB1tgz
},
modC: {
version: '1.0.0',
from: 'modC',
- resolved: 'file://' + modCdir,
+ resolved: 'file://' + modCtgz,
dependencies: {
modB: {
version: '1.0.0',
from: 'modB@1',
- resolved: 'file://' + modB1dir
+ resolved: 'file://' + modB1tgz
}
}
}
@@ -100,10 +101,10 @@ var newShrinkwrap = new Tacks(Dir({
'package.json': File({
_requested: {
name: 'modB',
- raw: 'modB@file:' + modB1dir,
- rawSpec: 'file:' + modB1dir,
+ raw: 'modB@file:' + modB1tgz,
+ rawSpec: 'file:' + modB1tgz,
scope: null,
- spec: modB1dir,
+ spec: modB1tgz,
type: 'directory'
},
dependencies: { },
@@ -128,9 +129,26 @@ function cleanup () {
test('setup', function (t) {
cleanup()
setup()
- common.npm(['install'], {cwd: testdir, stdio: [0, 2, 2]}, function (err, code) {
- if (err) throw err
- t.is(code, 0)
+ return Bluebird.try(() => {
+ return Bluebird.join(
+ common.npm(['pack', 'file:modB@1'], {cwd: testdir, stdio: [0, 2, 2]}),
+ common.npm(['pack', 'file:modB@2'], {cwd: testdir, stdio: [0, 2, 2]}),
+ function (b1, b2) {
+ t.is(b1[0], 0, 'pack modB@1')
+ t.is(b2[0], 0, 'pack modB@2')
+ })
+ }).then(() => {
+ return Bluebird.join(
+ common.npm(['pack', 'file:modA'], {cwd: testdir, stdio: [0, 2, 2]}),
+ common.npm(['pack', 'file:modC'], {cwd: testdir, stdio: [0, 2, 2]}),
+ function (a, c) {
+ t.is(a[0], 0, 'pack modA')
+ t.is(c[0], 0, 'pack modC')
+ })
+ }).then(() => {
+ return common.npm(['install'], {cwd: testdir, stdio: [0, 2, 2]})
+ }).spread((code) => {
+ t.is(code, 0, 'top level install')
t.end()
})
})