-
Notifications
You must be signed in to change notification settings - Fork 8.3k
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
[RFC] Bazel #92758
[RFC] Bazel #92758
Conversation
Pinging @elastic/kibana-operations (Team:Operations) |
Signed-off-by: Tyler Smalley <[email protected]>
88cf085
to
c0fc1d5
Compare
Signed-off-by: Tyler Smalley <[email protected]>
Co-authored-by: Jonathan Budzenski <[email protected]>
Co-authored-by: Jonathan Budzenski <[email protected]>
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.
Overall looks great, just a little note about running bazel and package builds in "parallel" via kbn/pm
Co-authored-by: Spencer <[email protected]>
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.
Aside from my above comment on a typo I've found, LGTM
Signed-off-by: Tyler Smalley <[email protected]>
|
||
In this phase, we will be migrating each of the 135 plugins over to being built and unit tested using Bazel. During this time, the legacy systems will stay in place and run in parallel with Bazel. Once all plugins have been migrated, we can decommission the legacy systems. | ||
|
||
The `BUILD.bazel` files will look similar to that of packages, there will be a target for `web`, `server`, and `jest`. Just like packages, as the Jest unit tests are migrated, they will need to be removed from the root `jest.config.js` file as described in the Unit Testing section. |
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.
Does it mean we are going to have different configuration files for every Environnement? tsconfig.server.js
, tsconfig.web.js
, tsconfig.jest.js
, etc.
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.
It only means we will have rules to build web and server separately as we currently have plugins who use different compilers for each target. The configuration part is up to us. Regarding jest
target it will rely on the previous builds for web and server but it just means we will have a target to run tests all at once for a given package \cc @tylersmalley
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.
Ideally, we only have a single tsconfig.js
file so we can use its output as the source of multiple targets. However, if we find we need or want separate configurations for different actions we do have that flexibility.
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.
Questions:
- Will we integrate FTR with this? If so, what new things will we be able to do with e2e tests?
- Can we have nested Bazel packages? If so, are there any caveats to be aware of with this and JavaScript?
- How will we integrate the output of Bazel's webpack build with the Kibana server? For instance, right now we have the optimizer_mixin which exposes the routes for webpack outputs and will wait for this process to complete before attempting to serve these files. How will we do this when Bazel is building these webpack outputs?
|
||
The `BUILD.bazel` files will look similar to that of packages, there will be a target for `web`, `server`, and `jest`. Just like packages, as the Jest unit tests are migrated, they will need to be removed from the root `jest.config.js` file as described in the Unit Testing section. | ||
|
||
Plugins are built in a sandbox, so they will no longer be able to use relative imports from one another. For Typescript, relative imports will be replaced with a path reference to the `bazel/bin`. |
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.
Can we add an example of what this would look like in code? I think how these imports work is an important aspect of how well this tool will fit into our repo. It may also impact how we consider implementing #71566 and enforce encapsulation between plugins & domains.
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 agree that we should elaborate on this change and discuss it with a wider audience. A dedicated e-mail to kibana-contributors@ would be great.
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.
Started #94034 to attempt to get a consensus on this. Will pass it around to a few folks before blasting kibana-contributors.
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.
Thanks, @tylersmalley.
Co-authored-by: Josh Dover <[email protected]>
Co-authored-by: Josh Dover <[email protected]>
Signed-off-by: Tyler Smalley <[email protected]>
This is something I have been giving thought to, but there are no concrete plans yet. Conceptually, we could entirely replace the FTR runner with Bazel to run Elasticsearch, Kibana, and the tests. There is an old video of Dropbox discussing this https://www.youtube.com/watch?v=muvU1DYrY0w
None that I am aware of. - @mistic?
I think this is an important part that should be included in the RFC, will work on adding it now and will ping you when it's complete. |
On Bazel language there is nested packages all over the place. But probably you are thinking about other cases. Can you give a concrete example to see if we can spot any caveats? At my first thoughts I think there won't be any special ones. \cc @joshdover |
Signed-off-by: Tyler Smalley <[email protected]>
Co-authored-by: Spencer <[email protected]>
@joshdover, added a note regarding the handling updates in development: https://github.com/elastic/kibana/pull/92758/files#diff-d3251298ab06494dfe78a21d16139be95192295555d9a3115799a81a30415478R79 |
Building TypeScript reference definitions and using `@babel/register` will be negated by using the TypeScript compiler directly instead of using Babel. Currently, we use Babel for code generation and `tsc` for type check and type declaration output. Additionally, the TypeScript implementation in [rules_nodejs](https://bazelbuild.github.io/rules_nodejs/TypeScript.html) for Bazel handles incremental builds, resulting in faster re-builds. | ||
|
||
In addition to the benefits of building code, there are also benefits regarding running unit tests. Developers currently need to understand what unit tests to run to validate changes or rely on waiting for CI, which has a long feedback loop. Since Bazel knows the dependency tree, it will only run unit tests for a package or plugin modified or dependent on those modifications. This optimization helps developers and will significantly reduce the amount of work CI needs to do. On CI, unit tests take 35 minutes to complete, where the average single Jest project takes just twenty seconds. | ||
|
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.
Unit tests are our least problem. We can use the migration to bazel as an opportunity to finally start functional tests separation by domain structure. @elastic/kibana-operations Do you anticipate any problems with this? We can use Core as a guinea pig.
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 see no problem with this, and I plan to work towards moving functional tests to have a plugin owner where they will reside. There are a lot of benefits to this, including clear ownership for functional tests to assist with tooling and how we report failures. In addition, it would help get us on a path to reducing the number of functional tests we run by default on a pull request. Bazel provides the ability to query the action graph to understand what packages are affected by a change. We can use this, and additional configuration on the plugins to determine which functional tests should be run by default while allowing the PR to request additional tests to be run.
|
||
Developers currently use `yarn test:jest` to efficiently run tests in a given directory without remembering the command or path. This command will continue to work as it does today, but will begin running tests through Bazel for packages or plugins which have been migrated. | ||
|
||
CI will have an additional job to run `bazel test //…:jest`. This will run unit tests for any package or plugin modified or dependent on modifications since the last successful CI run on that branch. |
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.
Can you explain "dependent on modifications"
Core (as well as other plugins) maintains many mocks that are used by other plugin's unit tests. Would a change in a mock result in unit tests being run for all the tests that import that mock?
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.
As it currently stands, yes. The mocks are inputs into the test actions, and if those change the downstream tests will be re-run.
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.
There are ways to combat this by isolating the mocks with a separate filegroup which would be consumed by the downstream projects.
I'm curious if we can support a nested structure like this:
|
@joshdover, absolutely. We have discussed breaking out portions of plugins that have very little churn. If there is a large portion of code within a plugin that doesn't frequently change, it might make sense to add a BUILD.bazel file within that portion to create those assets separately. This would decrease the scope and in-turn the time it would take to build the plugin. Lots of options. |
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.
Super excited about this and looking forward to all the improvements. Thanks for taking the time to write all this out so we can clearly document our decisions!
Seeing no pending feedback, I am going to merge the RFC. If any questions come up, don't hesitate to reach out. |
Request for comment for migrating Kibana to Bazel. Requests close March 9th, 2021
Rendered: https://github.com/tylersmalley/kibana/blob/rfc-bazel/rfcs/text/0015_bazel.md
#10908