-
Notifications
You must be signed in to change notification settings - Fork 323
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
More reliable shutdown of the EnsoContext to save resources #6468
Conversation
@@ -331,6 +331,10 @@ class RuntimeServerTest | |||
val Some(Api.Response(_, Api.InitializedNotification())) = context.receive | |||
} | |||
|
|||
override protected def afterEach(): Unit = { | |||
context.executionContext.context.close() |
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.
This helps the "engine threads", but the test should also stop Akka, @4e6. Dmitry, if you know how to do that feel free to directly commit to this 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.
We're not using Akka in runtime*
projects. Only in the language-server
and project-manager
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 was wrong, in fact, runtime tests are using Akka.
@JaroslavTulach do you have any estimate of how much resources can occupy the test Context? I'm just curious. |
I am using VisualVM to Monitor the started |
Not bad 🤔 |
@@ -129,6 +129,11 @@ class RuntimeExecutionEnvironmentTest | |||
val Some(Api.Response(_, Api.InitializedNotification())) = context.receive | |||
} | |||
|
|||
override protected def afterEach(): Unit = { | |||
context.executionContext.context.close() |
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.
When I added all these afterEach
cleanups, running the whole sbt runtime-with-instruments/test
started to randomly fail. Turned out I had to also f71557d - e.g. wait for the shutdown
of the EnsoContext
threads.
* develop: (34 commits) Continued Execution Context work and some little fixes (#6506) IDE's logging to a file (#6478) Fix application config (#6513) Cloud/desktop mode switcher (#6448) Fix doubled named arguments bug (#6422) Reimplement `enso_project` as a proper builtin (#6352) Fix layer ordering between dropdown and breadcrumbs backgrounds. (#6483) Multiflavor layers (#6477) DataflowAnalysis preserves dependencies order (#6493) Implement `create_database_table` for Database Table (#6467) Limit Dead Letter logging (#6482) More reliable shutdown of the EnsoContext to save resources (#6468) Make execution mode `live` default for CLI (#6496) Finishing Vector Editor (#6470) Proper handling of multiple list views. (#6461) Fix disappearing cached shapes (#6458) Add Execution Context control to Text.write (#6459) Change defaults for `Connection.tables` and ensure that `Connection.query` recognizes all available tables (#6443) Introducing @BuiltinMethod.needsFrame and InlineableNode (#6442) Hide profile button behind a feature flag (#6430) ...
* develop: Fix cut-off in text visualisations (#6421) Infer correct synthetic name for nested modules (#6525) Delete unused websocket dependency (#6535) Run typecheck and eslint on `./run lint` (#6314) Force pending saves if client closes abruptly (#6514) Continued Execution Context work and some little fixes (#6506) IDE's logging to a file (#6478) Fix application config (#6513) Cloud/desktop mode switcher (#6448) Fix doubled named arguments bug (#6422) Reimplement `enso_project` as a proper builtin (#6352) Fix layer ordering between dropdown and breadcrumbs backgrounds. (#6483) Multiflavor layers (#6477) DataflowAnalysis preserves dependencies order (#6493) Implement `create_database_table` for Database Table (#6467) Limit Dead Letter logging (#6482) More reliable shutdown of the EnsoContext to save resources (#6468) Make execution mode `live` default for CLI (#6496)
Pull Request Description
There is 572 threads during
RuntimeServerTest
execution create. They stay around because the context isn't closed after each test finishes. AddingafterEach
cleanup sequence toruntime-with-instruments
tests. Improving robustness of overallEnsoContext
shutdown.Checklist
Please ensure that the following checklist has been satisfied before submitting the PR: