-
-
Notifications
You must be signed in to change notification settings - Fork 16
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
Add support for Rush monorepos #53
Comments
Hope that helps |
@hugocxl Thanks for your reply. I'm using webpack to bundle the source code, though there's still a Here are the files: tsconfig.json {
"extends": "../../../common/config/tsconfig-node.base.json",
"compilerOptions": {
"baseUrl": ".",
"outDir": "dist"
}
} tsconfig-node.base.json {
"$schema": "https://json.schemastore.org/tsconfig",
"display": "Node 16",
"compilerOptions": {
"lib": [
"es2021"
],
"module": "commonjs",
"target": "es2021",
"types": ["node", "mocha"],
"strict": true,
"esModuleInterop": true,
"skipLibCheck": true,
"forceConsistentCasingInFileNames": true,
"experimentalDecorators": true,
"emitDecoratorMetadata": true,
"sourceMap": true,
"resolveJsonModule": true,
"paths": {
"@hero/core": ["../../libs/core"]
}
}
} webpack.config.js const { resolve, join } = require('path');
const nodeExternals = require('webpack-node-externals');
const TerserPlugin = require('terser-webpack-plugin');
module.exports = {
entry: resolve(__dirname, 'src/index.ts'),
mode: 'production',
devtool: 'source-map',
watchOptions: {
aggregateTimeout: 200,
},
stats: {
errorDetails: true,
},
optimization: {
minimizer: [
new TerserPlugin({
terserOptions: {
keep_classnames: true,
},
}),
],
},
module: {
rules: [
{
test: /\.tsx?$/,
use: 'ts-loader',
exclude: /node_modules/,
},
{
test: /\.(mjml)$/,
type: 'asset/resource',
},
],
},
target: 'node', // in order to ignore built-in modules like path, fs, etc.
externalsPresets: { node: true },
externals: [
nodeExternals({
//allowlist: [/^@the-hero-group/],
}),
], // in order to ignore all modules in node_modules folder
resolve: {
extensions: ['.ts', '.js'],
alias: {
'@the-hero-group/core': join(__dirname, '../../libs/core'),
},
},
output: {
filename: 'main.bundle.js',
path: resolve(__dirname, 'dist'),
library: {
type: 'this',
},
},
}; About your (2): Are you sure about that? I'm using the |
mmmm I think you're missing the |
@hugocxl I tried adding So it seems it using the directory of the |
It is not common to have a nested structure for your packages, and I don't think isolate-package supports it. See this section I would advise you to move apps and libs to the top level if you can. Also, if apps/backend is your only package deploying to firebase, I think there should be no reason to have the firebase files in the root of the monorepo. You could colocate them with the backend code. |
For debugging it might be helpful to first use isolate-package without the firebase tools. Then you can just execute And in the config set "logLevel" to "debug" so that you get verbose output. |
Hi @0x80, thanks for your input. I just wanted to give an update since I've been testing a few configurations. I took your advice and moved the I didn't get
I assume if the |
Thanks for your feedback. Odd that those files are considered "temporary". But compatibility seems doable then. I will see what is needed to make those paths configurable and not depend on a root manifest file. Is there anything specific I could use to detect a Rush monorepo? And would |
@0x80 Can be detected when there's a The I was mistaken about the lockfile this is located under the path And yes those paths are fixed and are used by all Rush setups. If you want, I can set up a basic Rush.js mono repo for you to test your changes |
@dominicbartl Thanks, yes if it's not too much work I think that could be very helpful 👍 |
Alright, I will set it up with a little explanation tomorrow and post the link here. |
@0x80 Here you go: https://github.com/dominicbartl/rush-isolate I included 2 packages Just let me know if you have any questions or need help |
@dominicbartl For PNPM it seems I have it working in 1.13.0-1. You can install it with @next. There were a few more hoops to jump through than I imagined, but the good thing is that no additional config is required I think. For details see: If you have Rush monorepos that are using npm or yarn it would be helpful if you could test those as well. |
It has now been published in the latest versions of isolate-package and firebase-tools-with-isolate |
@0x80 Amazing work, thanks a lot for your support. I just tested the new version and I encountered one issue, when deploying the functions. 1. Frozen lockfile
I upgraded to the latest version of pnpm ( cd apps/functions
rushx isolate
cd isolate
CI=true NODE_ENV=production pnpm install The generated lockfile version from |
@dominicbartl please make a separate issue for this as it seems unrelated to the Rush compatibility. I'm not sure I understand the problem. Isn't this a version incompatibility between pnpm on your system and pnpm that is used to read your lockfile in the cloud deployment? Is the error coming from Firebase deploy? The part that handles the pnpm lockfile is the same for non-Rush monorepos, and my deployments still work, so I'm trying to understand where it comes from. |
@0x80 Found the mismatch, was more pnpm than Rush related. The lockfile in the repo was version 5.4 and Rush didn't update the lockfile after updating pnpm. After deleting the lockfile and installing the dependencies again, the lockfile was version 6 and everything worked as expected. Not sure why running Rush commandsThis is just for reference if someone is using Rush and stumbles over this post Rush has the ability to add repo-wide commands using autoinstallers. Autoinstallers are packages with dependencies used by tools/scripts which automatically get installed when a command is run. # This creates the common/autoinstallers/firebase/package.json file
rush init-autoinstaller --name firebase Add rush update-autoinstaller --name firebase To add the command, add this to
After that, you can run the following command in any directory containing a # Show help
rush deploy-firebase --help
# Run deployment
rush deploy-firebase --project <project> |
Hi @0x80,
first, thanks a lot for all the time you're spending on this issue.
I have a Rush mono-repo (though I think this shouldn't make a difference) and I'm currently replacing my version of bundling dependencies using your
firebase-tools-with-isolate
.I have the following directory structure:
data:image/s3,"s3://crabby-images/6a860/6a86019da95e817fef43825ae751ba2f8f9bc5bf" alt="Screenshot from 2024-02-28 15-24-22"
The directory
packages/apps/backend
contains a set of Firebase functions I want to deploy. The content of myfirebase.json
is the following:When running
data:image/s3,"s3://crabby-images/efd99/efd9986325d0fb119dcdf9ac8394f2d22c3b5015" alt="Screenshot from 2024-02-28 15-31-17"
firebase deploy
, I get the following error:It seems to me that it's trying to isolate the root directory instead of the
backend
directory. It should be looking for atsconfig.json
inpackages/apps/backend
. Is there anything I'm missing?I tried putting the
isolate.config.json
file in the backend directory (same error) as well as in the root directory (throws error since there's no package.json in the root dir)The text was updated successfully, but these errors were encountered: