-
Notifications
You must be signed in to change notification settings - Fork 246
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
fix: modules not built sequentially #3045
Conversation
For Go, JS, and Python, the `OneByOneBuilder` is used to build the modules sequentially. The modules are first sorted topologically, then passed into the builder to build one at a time. However, the package builds are kicked off asynchronously, leading to parallel builds and potential build issues when a local package depends on another.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I guess we could do a reduce
to build a single promise chain here but the for/of
loop feels easier to read and fits better with our code style, lint ignores and all. Alternative would be something like:
await this.modules.reduce((previous, mod) => {
return previous.then(() => this.options.codeOnly
? this.generateModuleCode(module, this.options)
: this.buildModule(module, this.options)
);
}, Promise.resolve())
We could have the best of both worlds: chain dependent tasks together and run independent ones in parallel. But of course, there is more effort involved in making this work and may not be worth it. |
jsii-rosetta has a bug where modules are packed in parallel, rather than sequentially. This causes packing failures on v2, where the alpha modules depend on aws-cdk-lib, but may be packed first. The jsii fix is aws/jsii#3045. However, to shortcut the build+test+upgrade+merge+deploy cycle, creating this patch to speed up verification.
jsii-pacmak has a bug where modules are packed in parallel, rather than sequentially. This causes packing failures on v2, where the alpha modules depend on aws-cdk-lib, but may be packed first. The jsii fix is aws/jsii#3045. However, to shortcut the build+test+upgrade+merge+deploy cycle, creating this patch to speed up verification. ---- *By submitting this pull request, I confirm that my contribution is made under the terms of the Apache-2.0 license*
The pack on v2 is currently broken due to a bug in jsii-pacmak <= 1.38.0 that packs all modules in parallel, regardless of dependencies between the modules. That breaks on building the alpha modules, since they rely on aws-cdk-lib, but often end up being packed first. A fix was created in jsii (aws/jsii#3045), but to unblock the build earlier, a patch was created to apply the fix within the CDK prior to the next jsii release (#16871). Unfortunately, our build "transform" step runs a `lerna` command that re-installs jsii-pacmak, removing the patch. Calling `yarn install` here again to re-install and re-apply the patch prior to packing.
The pack on v2 is currently broken due to a bug in jsii-pacmak <= 1.38.0 that packs all modules in parallel, regardless of dependencies between the modules. That breaks on building the alpha modules, since they rely on aws-cdk-lib, but often end up being packed first. A fix was created in jsii (aws/jsii#3045), but to unblock the build earlier, a patch was created to apply the fix within the CDK prior to the next jsii release (#16871). Unfortunately, our build "transform" step runs a `lerna` command that re-installs jsii-pacmak, removing the patch. Calling `yarn install` here again to re-install and re-apply the patch prior to packing.
The pack on v2 is currently broken due to a bug in jsii-pacmak <= 1.38.0 that packs all modules in parallel, regardless of dependencies between the modules. That breaks on building the alpha modules, since they rely on aws-cdk-lib, but often end up being packed first. A fix was created in jsii (aws/jsii#3045), but to unblock the build earlier, a patch was created to apply the fix within the CDK prior to the next jsii release (#16871). Unfortunately, our build "transform" step runs a `lerna` command that re-installs jsii-pacmak, removing the patch. Calling `yarn install` here again to re-install and re-apply the patch prior to packing. _Note: This will become obsolete once jsii-pacmak 1.39.0 is released_ ---- *By submitting this pull request, I confirm that my contribution is made under the terms of the Apache-2.0 license*
In #3045, the `OneByOneBuilder` was switched to build all packages in series (instead of all in parallel), because there would be race conditions in case of inter-package dependencies. This is correct, but leaves a bunch of possible parallelism on the table that is notably blowing up pack times for Python. Re-introduce a (limited) form of parallelism by retaining the sets of mutually independent packages, as toposorted, and doing those in parallel.
In #3045, the `OneByOneBuilder` was switched to build all packages in series (instead of all in parallel), because there would be race conditions in case of inter-package dependencies. This is correct, but leaves a bunch of possible parallelism on the table that is notably blowing up pack times for Python. Re-introduce a (limited) form of parallelism by retaining the sets of mutually independent packages, as toposorted, and doing those in parallel. Rename the class to `IndependentPackageBuilder` to more clearly describe the intent behind the class. --- By submitting this pull request, I confirm that my contribution is made under the terms of the [Apache 2.0 license]. [Apache 2.0 license]: https://www.apache.org/licenses/LICENSE-2.0
For Go, JS, and Python, the
OneByOneBuilder
is used to build the modulessequentially. The modules are first sorted topologically, then passed into the
builder to build one at a time. However, the package builds are kicked off
asynchronously, leading to parallel builds and potential build issues when a
local package depends on another.
By submitting this pull request, I confirm that my contribution is made under the terms of the Apache 2.0 license.