Summary:
Our post install scripts didn't propagate installation errors in CI (or locally), leading to problems only appearing later in time, causing a lot of lost time {emoji:1f605}
Also moved printing what package is installing to _before_ running the script, so that you have actual useful info in case it fails.
Compilation errors of pkg and doctor were printed in our CI, but never threw exceptions.
Fixed the cause of those compilation errors as well using `skipLibCheck` like done in the root tsconfig
Reviewed By: jknoxville
Differential Revision: D20470985
fbshipit-source-id: 1b13d4d2c096f253cc9c1f0aac06982fc4aedf55
72 lines
2.2 KiB
TypeScript
72 lines
2.2 KiB
TypeScript
/**
|
|
* Copyright (c) Facebook, Inc. and its affiliates.
|
|
*
|
|
* This source code is licensed under the MIT license found in the
|
|
* LICENSE file in the root directory of this source tree.
|
|
*
|
|
* @format
|
|
*/
|
|
|
|
import path from 'path';
|
|
import util from 'util';
|
|
import globImport from 'glob';
|
|
import {exec as execImport} from 'child_process';
|
|
const glob = util.promisify(globImport);
|
|
const exec = util.promisify(execImport);
|
|
const PACKAGES = [
|
|
'headless-tests',
|
|
'static',
|
|
'doctor',
|
|
'pkg',
|
|
'plugins/*',
|
|
'plugins/fb/*',
|
|
'plugins/fb/layout/*',
|
|
];
|
|
const WINDOWS = /^win/.test(process.platform);
|
|
const YARN_PATH =
|
|
process.argv.length > 2
|
|
? path.join(__dirname, process.argv[2])
|
|
: 'yarn' + (WINDOWS ? '.cmd' : '');
|
|
|
|
Promise.all(
|
|
PACKAGES.map(pattern =>
|
|
glob(path.join(__dirname, '..', pattern, 'package.json')),
|
|
),
|
|
)
|
|
.then(async packages => {
|
|
const flattenPackages = packages.reduce((acc, cv) => acc.concat(cv), []);
|
|
console.log(
|
|
`Installing dependencies for ${flattenPackages.length} plugins`,
|
|
);
|
|
for (const pkg of flattenPackages) {
|
|
console.log(`Installing dependencies for ${pkg}...`);
|
|
// @ts-ignore
|
|
const {stderr, error} = await exec(
|
|
// This script is itself executed by yarn (as postinstall script),
|
|
// therefore another yarn instance is running, while we are trying to
|
|
// install the plugin dependencies. We are setting a different port
|
|
// for the mutex of this yarn instance to make sure, it is not blocked
|
|
// by the yarn instance which is executing this script. Otherwise this
|
|
// will cause a deadlock.
|
|
[YARN_PATH, '--mutex', 'network:30330'].join(' '),
|
|
{
|
|
cwd: pkg.replace('/package.json', ''),
|
|
},
|
|
);
|
|
if (stderr) {
|
|
if (error && error.code !== 0) {
|
|
console.warn(`❌ Installing dependencies for ${pkg} failed`);
|
|
throw stderr;
|
|
}
|
|
console.warn(stderr);
|
|
}
|
|
}
|
|
})
|
|
// eslint-disable-next-line
|
|
.then(() => console.log('📦 Installed all plugin dependencies!'))
|
|
.catch(err => {
|
|
console.error(err);
|
|
console.error('❌ Installing plugin dependencies failed.');
|
|
process.exit(1);
|
|
});
|