Skip to content

Commit

Permalink
#832 Cleanup sub dep install script
Browse files Browse the repository at this point in the history
  • Loading branch information
ianwsperber committed Mar 1, 2017
1 parent c9d011f commit 497162b
Show file tree
Hide file tree
Showing 2 changed files with 25 additions and 44 deletions.
2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -202,7 +202,7 @@
},
"scripts": {
"unit": "tap --harmony ./tests/test_*.js",
"preintegration": "./tests/bin/install_sub_deps",
"preintegration": "./tests/bin/install_sub_deps versioned",
"integration": "tap --harmony ./tests/versioned/*/*.tap.js",
"test": "npm run unit && npm run integration",
"coverage": "nyc tap --harmony ./tests/test_*.js",
Expand Down
67 changes: 24 additions & 43 deletions tests/bin/install_sub_deps
Original file line number Diff line number Diff line change
@@ -1,40 +1,36 @@
#!/usr/bin/env node
// vim: ft=javascript
/* From: https://github.com/newrelic/node-newrelic/blob/master/test/bin/install_sub_deps */
/* Modeled after: https://github.com/newrelic/node-newrelic/blob/master/test/bin/install_sub_deps */
'use strict'

var path = require('path')
var glob = require('glob')
var exec = require('child_process').exec
const path = require('path')
const glob = require('glob')
const assert = require('assert')
const exec = require('child_process').exec

var options = {
}
const folder = process.argv[2];
const retries = 2

var folder
if (process.argv.length > 2) {
folder = process.argv[2]
}
assert(folder, 'Missing folder!');

getPackages(folder, function(packages) {
var correctPackages = packages.filter(function (line) {
return !/node_modules|example/.test(line)
})
install(correctPackages)
})
glob(`**/tests/${folder}/**/package.json`, {}, (err, packages) => {
if (err) { fail(err); }

var retries = 2
function install(packages, retry) {
install(packages.filter((line) => !/node_modules|example/.test(line)));
});

const install = (packages, retry) => {
if (!retry) retry = 0

var failed = []
var counter = 0
packages.forEach(function (packageJsonPath) {
var packagePath = path.resolve(packageJsonPath).split('/').slice(0, -1).join('/')
console.log('installing deps in ' + packagePath)
exec('cd ' + packagePath + '&&rm -rf node_modules&&npm i',
{maxBuffer: 1024 * 500},
function (err, stdout, stderr) {
const failed = []
let counter = 0

packages.forEach((packageJsonPath) => {
const packagePath = path.resolve(packageJsonPath).split('/').slice(0, -1).join('/');

console.log('installing deps in %s', packagePath)
exec(`cd ${packagePath} && rm -rf node_modules && npm i`, {
maxBuffer: 1024 * 500
}, (err, stdout, stderr) => {
if (err || isErrorOutput(stderr)) {
printError(packageJsonPath, err || stderr)
if (retry < retries) {
Expand All @@ -45,9 +41,7 @@ function install(packages, retry) {
if (++counter === packages.length) {
if (failed.length > 0 && retry < retries) {
console.log('%s package(s) failed to install, retrying...', failed.length)
exec('npm cache clean', function() {
install(failed, ++retry)
})
exec('npm cache clean', () => install(failed, ++retry));
}
}
})
Expand All @@ -59,19 +53,6 @@ function isErrorOutput(text) {
return (text && text.indexOf('npm ERR') > -1)
}

function getPackages(folder, callback) {
if (folder) {
glob('**/tests/' + folder + '/**/package.json', options,
function getPackages(err, packages) {
callback(packages)
})
} else {
glob('**/tests/**/package.json', options, function getPackages(err, packages) {
callback(packages)
})
}
}

function printError(packagePath, error) {
console.log('-----------------------------------------------------------')
console.log(packagePath + ' failed installing with the following error:')
Expand Down

0 comments on commit 497162b

Please sign in to comment.