Skip to content

ref(build): Add central build directory to packages without CDN bundles (Part 1) #4854

New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Merged
merged 10 commits into from
Apr 6, 2022
7 changes: 6 additions & 1 deletion packages/core/.npmignore
Original file line number Diff line number Diff line change
@@ -1,4 +1,9 @@
# Info: the paths in this file are specified so that they align with the file
# structure in `./build` where this file is copied to. This is done by the
# prepack script `sentry-javascript/scripts/prepack.ts`.

*

!/dist/**/*
!/esm/**/*
!/build/types/**/*
!/types/**/*
8 changes: 4 additions & 4 deletions packages/core/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -9,8 +9,8 @@
"engines": {
"node": ">=6"
},
"main": "dist/index.js",
"module": "esm/index.js",
"main": "build/dist/index.js",
"module": "build/esm/index.js",
"types": "build/types/index.d.ts",
"publishConfig": {
"access": "public"
Expand All @@ -35,9 +35,9 @@
"build:es5:watch": "yarn build:cjs:watch # *** backwards compatibility - remove in v7 ***",
"build:esm:watch": "tsc -p tsconfig.esm.json --watch",
"build:types:watch": "tsc -p tsconfig.types.json --watch",
"build:npm": "npm pack",
"build:npm": "ts-node ../../scripts/prepack.ts -noBundles && npm pack ./build",
"circularDepCheck": "madge --circular src/index.ts",
"clean": "rimraf dist esm coverage",
"clean": "rimraf dist esm build coverage",
"fix": "run-s fix:eslint fix:prettier",
"fix:eslint": "eslint . --format stylish --fix",
"fix:prettier": "prettier --write \"{src,test,scripts}/**/*.ts\"",
Expand Down
2 changes: 1 addition & 1 deletion packages/core/tsconfig.cjs.json
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,6 @@

"compilerOptions": {
"module": "commonjs",
"outDir": "dist"
"outDir": "build/dist"
}
}
2 changes: 1 addition & 1 deletion packages/core/tsconfig.esm.json
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,6 @@

"compilerOptions": {
"module": "es6",
"outDir": "esm"
"outDir": "build/esm"
}
}
3 changes: 3 additions & 0 deletions packages/gatsby/.eslintrc.js
Original file line number Diff line number Diff line change
Expand Up @@ -6,5 +6,8 @@ module.exports = {
parserOptions: {
jsx: true,
},
// ignoring the package-specific prepack script here b/c it is not
// covered by a `tsconfig` which makes eslint throw an error
ignorePatterns: ['scripts/prepack.ts'],
extends: ['../../.eslintrc.js'],
};
9 changes: 8 additions & 1 deletion packages/gatsby/.npmignore
Original file line number Diff line number Diff line change
@@ -1,6 +1,13 @@
# Info: the paths in this file are specified so that they align with the file
# structure in `./build` where this file is copied to. This is done by the
# prepack script `sentry-javascript/scripts/prepack.ts`.

*

!/dist/**/*
!/esm/**/*
!/build/types/**/*
!/types/**/*

# Gatsby specific
!gatsby-browser.js
!gatsby-node.js
6 changes: 3 additions & 3 deletions packages/gatsby/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -13,8 +13,8 @@
"engines": {
"node": ">=6"
},
"main": "dist/index.js",
"module": "esm/index.js",
"main": "build/dist/index.js",
"module": "build/esm/index.js",
"types": "build/types/index.d.ts",
"publishConfig": {
"access": "public"
Expand Down Expand Up @@ -46,7 +46,7 @@
"build:es5:watch": "yarn build:cjs:watch # *** backwards compatibility - remove in v7 ***",
"build:esm:watch": "tsc -p tsconfig.esm.json --watch",
"build:types:watch": "tsc -p tsconfig.types.json --watch",
"build:npm": "npm pack",
"build:npm": "ts-node ../../scripts/prepack.ts -noBundles && npm pack ./build",
"circularDepCheck": "madge --circular src/index.ts",
"clean": "rimraf dist esm build coverage",
"fix": "run-s fix:eslint fix:prettier",
Expand Down
27 changes: 27 additions & 0 deletions packages/gatsby/scripts/prepack.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
/* eslint-disable no-console */

// DO NOT RUN this script yourself!
// This is invoked from the main `prepack.ts` script in `sentry-javascript/scripts/prepack.ts`.

import * as fs from 'fs';
import * as path from 'path';

const PACKAGE_ASSETS = ['gatsby-browser.js', 'gatsby-node.js'];

export function prepack(buildDir: string): boolean {
// copy package-specific assets to build dir
return PACKAGE_ASSETS.every(asset => {
const assetPath = path.resolve(asset);
try {
if (!fs.existsSync(assetPath)) {
console.error(`Asset ${asset} does not exist.`);
return false;
}
fs.copyFileSync(assetPath, path.resolve(buildDir, asset));
} catch (error) {
console.error(`Error while copying ${asset} to ${buildDir}`);
return false;
}
return true;
});
}
2 changes: 1 addition & 1 deletion packages/gatsby/tsconfig.cjs.json
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,6 @@

"compilerOptions": {
"module": "commonjs",
"outDir": "dist"
"outDir": "build/dist"
}
}
2 changes: 1 addition & 1 deletion packages/gatsby/tsconfig.esm.json
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,6 @@

"compilerOptions": {
"module": "es6",
"outDir": "esm"
"outDir": "build/esm"
}
}
7 changes: 6 additions & 1 deletion packages/hub/.npmignore
Original file line number Diff line number Diff line change
@@ -1,4 +1,9 @@
# Info: the paths in this file are specified so that they align with the file
# structure in `./build` where this file is copied to. This is done by the
# prepack script `sentry-javascript/scripts/prepack.ts`.

*

!/dist/**/*
!/esm/**/*
!/build/types/**/*
!/types/**/*
8 changes: 4 additions & 4 deletions packages/hub/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -9,8 +9,8 @@
"engines": {
"node": ">=6"
},
"main": "dist/index.js",
"module": "esm/index.js",
"main": "build/dist/index.js",
"module": "build/esm/index.js",
"types": "build/types/index.d.ts",
"publishConfig": {
"access": "public"
Expand All @@ -33,6 +33,7 @@
"build:es5:watch": "yarn build:cjs:watch # *** backwards compatibility - remove in v7 ***",
"build:esm:watch": "tsc -p tsconfig.esm.json --watch",
"build:types:watch": "tsc -p tsconfig.types.json --watch",
"build:npm": "ts-node ../../scripts/prepack.ts -noBundles && npm pack ./build",
"circularDepCheck": "madge --circular src/index.ts",
"clean": "rimraf dist esm coverage",
"fix": "run-s fix:eslint fix:prettier",
Expand All @@ -41,8 +42,7 @@
"link:yarn": "yarn link",
"lint": "run-s lint:prettier lint:eslint",
"lint:eslint": "eslint . --cache --cache-location '../../eslintcache/' --format stylish",
"lint:prettier": "prettier --check \"{src,test,scripts}/**/*.ts\"",
"build:npm": "npm pack",
"lint:prettier": "prettier --check \"{src,test}/**/*.ts\"",
"test": "jest",
"test:watch": "jest --watch"
},
Expand Down
2 changes: 1 addition & 1 deletion packages/hub/tsconfig.cjs.json
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,6 @@

"compilerOptions": {
"module": "commonjs",
"outDir": "dist"
"outDir": "build/dist"
}
}
2 changes: 1 addition & 1 deletion packages/hub/tsconfig.esm.json
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,6 @@

"compilerOptions": {
"module": "es6",
"outDir": "esm"
"outDir": "build/esm"
}
}
7 changes: 6 additions & 1 deletion packages/minimal/.npmignore
Original file line number Diff line number Diff line change
@@ -1,4 +1,9 @@
# Info: the paths in this file are specified so that they align with the file
# structure in `./build` where this file is copied to. This is done by the
# prepack script `sentry-javascript/scripts/prepack.ts`.

*

!/dist/**/*
!/esm/**/*
!/build/types/**/*
!/types/**/*
8 changes: 4 additions & 4 deletions packages/minimal/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -9,8 +9,8 @@
"engines": {
"node": ">=6"
},
"main": "dist/index.js",
"module": "esm/index.js",
"main": "build/dist/index.js",
"module": "build/esm/index.js",
"types": "build/types/index.d.ts",
"publishConfig": {
"access": "public"
Expand All @@ -33,16 +33,16 @@
"build:es5:watch": "yarn build:cjs:watch # *** backwards compatibility - remove in v7 ***",
"build:esm:watch": "tsc -p tsconfig.esm.json --watch",
"build:types:watch": "tsc -p tsconfig.types.json --watch",
"build:npm": "ts-node ../../scripts/prepack.ts -noBundles && npm pack ./build",
"circularDepCheck": "madge --circular src/index.ts",
"clean": "rimraf dist esm coverage",
"clean": "rimraf dist esm build coverage",
"fix": "run-s fix:eslint fix:prettier",
"fix:eslint": "eslint . --format stylish --fix",
"fix:prettier": "prettier --write \"{src,test,scripts}/**/*.ts\"",
"link:yarn": "yarn link",
"lint": "run-s lint:prettier lint:eslint",
"lint:eslint": "eslint . --cache --cache-location '../../eslintcache/' --format stylish",
"lint:prettier": "prettier --check \"{src,test,scripts}/**/*.ts\"",
"build:npm": "npm pack",
"test": "jest",
"test:watch": "jest --watch"
},
Expand Down
2 changes: 1 addition & 1 deletion packages/minimal/tsconfig.cjs.json
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,6 @@

"compilerOptions": {
"module": "commonjs",
"outDir": "dist"
"outDir": "build/dist"
}
}
2 changes: 1 addition & 1 deletion packages/minimal/tsconfig.esm.json
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,6 @@

"compilerOptions": {
"module": "es6",
"outDir": "esm"
"outDir": "build/esm"
}
}
59 changes: 48 additions & 11 deletions scripts/prepack.ts
Original file line number Diff line number Diff line change
Expand Up @@ -11,18 +11,23 @@ import * as fse from 'fs-extra';
import * as path from 'path';

const NPM_BUILD_DIR = 'build/npm';
const BUILD_DIR = 'build';

const ASSETS = ['README.md', 'LICENSE', 'package.json', '.npmignore'];
const ENTRY_POINTS = ['main', 'module', 'types'];

const packageWithBundles = !process.argv.includes('-noBundles');
const buildDir = packageWithBundles ? NPM_BUILD_DIR : BUILD_DIR;

// check if build dir exists
try {
if (!fs.existsSync(path.resolve(NPM_BUILD_DIR))) {
console.error(`Directory ${NPM_BUILD_DIR} DOES NOT exist`);
if (!fs.existsSync(path.resolve(buildDir))) {
console.error(`Directory ${buildDir} DOES NOT exist`);
console.error("This script should only be executed after you've run `yarn build`.");
process.exit(1);
}
} catch (error) {
console.error(`Error while looking up directory ${NPM_BUILD_DIR}`);
console.error(`Error while looking up directory ${buildDir}`);
process.exit(1);
}

Expand All @@ -34,9 +39,9 @@ ASSETS.forEach(asset => {
console.error(`Asset ${asset} does not exist.`);
process.exit(1);
}
fs.copyFileSync(assetPath, path.resolve(NPM_BUILD_DIR, asset));
fs.copyFileSync(assetPath, path.resolve(buildDir, asset));
} catch (error) {
console.error(`Error while copying ${asset} to ${NPM_BUILD_DIR}`);
console.error(`Error while copying ${asset} to ${buildDir}`);
process.exit(1);
}
});
Expand All @@ -45,28 +50,30 @@ ASSETS.forEach(asset => {
// copy CDN bundles into npm dir to temporarily keep bundles in npm tarball
// inside the tarball, they are located in `build/`
// for now, copy it by default, unless explicitly forbidden via an command line arg
const tmpCopyBundles = !process.argv.includes('-skipBundleCopy');
const tmpCopyBundles = packageWithBundles && !process.argv.includes('-skipBundleCopy');
if (tmpCopyBundles) {
const npmTmpBundlesPath = path.resolve(NPM_BUILD_DIR, 'build');
const npmTmpBundlesPath = path.resolve(buildDir, 'build');
const cdnBundlesPath = path.resolve('build', 'bundles');
try {
if (!fs.existsSync(npmTmpBundlesPath)) {
fs.mkdirSync(npmTmpBundlesPath);
}
void fse.copy(cdnBundlesPath, npmTmpBundlesPath);
} catch (error) {
console.error(`Error while tmp copying CDN bundles to ${NPM_BUILD_DIR}`);
console.error(`Error while tmp copying CDN bundles to ${buildDir}`);
process.exit(1);
}
}
// end remove

// package.json modifications
const packageJsonPath = path.resolve(NPM_BUILD_DIR, 'package.json');
const packageJsonPath = path.resolve(buildDir, 'package.json');
// eslint-disable-next-line @typescript-eslint/no-var-requires
const pkgJson: { [key: string]: unknown } = require(packageJsonPath);

// modify entry points to point to correct paths (i.e. strip out the build directory)
ENTRY_POINTS.filter(entryPoint => pkgJson[entryPoint]).forEach(entryPoint => {
pkgJson[entryPoint] = (pkgJson[entryPoint] as string).replace(`${NPM_BUILD_DIR}/`, '');
pkgJson[entryPoint] = (pkgJson[entryPoint] as string).replace(`${buildDir}/`, '');
});

delete pkgJson.scripts;
Expand All @@ -81,4 +88,34 @@ try {
process.exit(1);
}

console.log(`\nSuccessfully finished prepack commands for ${pkgJson.name}\n`);
async function runPackagePrepack(packagePrepackPath: string): Promise<void> {
const { prepack } = await import(packagePrepackPath);
if (prepack && typeof prepack === 'function') {
const isSuccess = prepack(buildDir);
if (!isSuccess) {
process.exit(1);
}
} else {
console.error(`Could not find a prepack function in ${packagePrepackPath}.`);
console.error(
'Make sure, your package-specific prepack script exports `function prepack(buildDir: string): boolean`.',
);
process.exit(1);
}
}

// execute package specific settings
// 1. check if a package called `<package-root>/scripts/prepack.ts` exitsts
// if yes, 2.) execute that script for things that are package-specific
void (async () => {
const packagePrepackPath = path.resolve('scripts', 'prepack.ts');
try {
if (fs.existsSync(packagePrepackPath)) {
await runPackagePrepack(packagePrepackPath);
}
} catch (error) {
console.error(`Error while trying to access ${packagePrepackPath.toString()}`);
process.exit(1);
}
console.log(`\nSuccessfully finished prepack commands for ${pkgJson.name}\n`);
})();