Skip to content
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

Provide mechanism for managing resources across engines and executions #2816

Open
marcphilipp opened this issue Jan 28, 2022 · 15 comments · May be fixed by #4281
Open

Provide mechanism for managing resources across engines and executions #2816

marcphilipp opened this issue Jan 28, 2022 · 15 comments · May be fixed by #4281

Comments

@marcphilipp
Copy link
Member

The Platform should provide an extensible mechanism (ServiceLoader?) so that user code can create "closeable resources" that are injected as part of the context received by TestEngine implementations.

This feature is analogous to the ExtensionContext.Store concept from Jupiter but takes it to the Platform level. Moreover, it allows to reuse the same resource across multiple executions in a LauncherSession. We should advocate that resources stored in such a key-value store be immutable until their destruction. If such resources implement AutoCloseable they will get closed immediately before the LauncherSession they belong to is closed.

@stale
Copy link

stale bot commented Jan 28, 2023

This issue has been automatically marked as stale because it has not had recent activity. Given the limited bandwidth of the team, it will be automatically closed if no further activity occurs. Thank you for your contribution.

@stale stale bot added the status: stale label Jan 28, 2023
@stale
Copy link

stale bot commented Feb 18, 2023

This issue has been automatically closed due to inactivity. If you have a good use case for this feature, please feel free to reopen the issue.

@PinkFloyded
Copy link

Hi @marcphilipp, if there is interest in this feature, I can take a stab at implementing this. Though I'm pretty new to the Junit codebase and would have to familiarize myself first.

@terencenmnpan
Copy link

Hi @marcphilipp, if there is interest in this feature, I can take a stab at implementing this. Though I'm pretty new to the Junit codebase and would have to familiarize myself first.

I have interest, I'm interested in making an attempt at a change based on this for the cucumber jvm project.

@marcphilipp
Copy link
Member Author

@PinkFloyded @terencenmnpan Thanks for offering! Has either of you already put some thought into where/how you'd envision the Launcher API to change? I think starting on this will require a core team decision first but a concrete proposal would speed things up.

@YongGoose
Copy link
Contributor

@marcphilipp @terencenmnpan @PinkFloyded

any updates?

@marcphilipp
Copy link
Member Author

@YongGoose No, there are no updates. Are you interested in writing up a (short) proposal for discussion?

@YongGoose
Copy link
Contributor

@YongGoose No, there are no updates. Are you interested in writing up a (short) proposal for discussion?

Yes, I'm interested in writing up a proposal. However, it will take me a few days to conduct a thorough analysis and put together a detailed proposal.

@marcphilipp
Copy link
Member Author

Sure, no worries! 👍

@YongGoose
Copy link
Contributor

@marcphilipp
I apologize for the delay in preparing the proposal.🥲
I’m still working through some thoughts and plan to start writing it after completing the following two tasks.

I could work on the proposal at the same time, but I’ve decided to focus on the current tasks first to ensure the best quality for the project.

@marcphilipp
Copy link
Member Author

One idea I had in the meantime would be to build upon #3064. We could create both a session-level and request-level instance of NamespacedHierarchicalStore. The former could be exposed to registered LauncherSessionListeners via LauncherSession.getStore(). The latter would be created in the Launcher for every LauncherDiscoveryRequest and use the session-level store as its parent. It would then be exposed to test engines via EngineDiscoveryRequest and to TestExecutionListeners via TestPlan. JUnit Jupiter (and other engines) would then use the request-level store as parent when creating the store for JupiterEngineExtensionContext.

@marcphilipp marcphilipp changed the title Provide mechanism for managing engine-level resources Provide mechanism for managing resources across engines and executions Nov 29, 2024
YongGoose added a commit to YongGoose/junit5 that referenced this issue Dec 22, 2024
@YongGoose
Copy link
Contributor

YongGoose commented Dec 22, 2024

@marcphilipp

The comment was truly awesome 👍🏻 #2816 (comment)

While writing the proposal, I initially considered a single-instance structure similar to TestNG's IAttributes.
However, I decided to retain the hierarchical structure, as it seems to be more effective for managing data.

So instead of completing the proposal, I implemented the comment within my personal workspace.

The work has been divided into several steps:

  1. Designing a class to manage context at the platform level (YongGoose@5bfe6ad)
  2. Adding a session-level store to LauncherSession (YongGoose@7992634)
  3. Adding a request-level store to Launcher
  4. Exposing the request-level store in EngineDiscoveryRequest and TestPlan
  5. Utilizing the request-level store in JupiterEngineExtensionContext

If my implementation approach is suitable, I am willing to contribute.

However, if the JUnit team has already decided to handle the implementation,
I would like to participate (even if just a little 😁), in the discussions on the design direction and contribute to the project in any way I can.

@marcphilipp
Copy link
Member Author

1. Designing a class to manage context at the platform level (YongGoose@5bfe6ad)

I think we only need a copy of Jupiter's Namespace class

If my implementation approach is suitable, I am willing to contribute.

However, if the JUnit team has already decided to handle the implementation, I would like to participate (even if just a little 😁), in the discussions on the design direction and contribute to the project in any way I can.

Nobody from the team has already started on this so it's yours for the taking. However, may I kindly suggest we finish your other PRs first? 😅

I think the steps you're proposing sound good! 👍

We'll also have to think about how a Jupiter extension (or equivalent extension of another test engine) could store something in the session- or request-level store. We'll probably have to add NamespacedHierarchicalStore.getParent() : Optional<NamespacedHierarchicalStore<N>> for that and methods like getSessionLevelStore() : Store and getRequestLevelStore(): Store to ExtensionContext.

@YongGoose
Copy link
Contributor

Nobody from the team has already started on this so it's yours for the taking. However, may I kindly suggest we finish your other PRs first? 😅

Sounds great!

Once I finish this PR, I'll follow your suggestions to design and implement it accordingly!

YongGoose added a commit to YongGoose/junit5 that referenced this issue Jan 6, 2025
YongGoose added a commit to YongGoose/junit5 that referenced this issue Jan 6, 2025
YongGoose added a commit to YongGoose/junit5 that referenced this issue Jan 18, 2025
YongGoose added a commit to YongGoose/junit5 that referenced this issue Jan 19, 2025
@YongGoose
Copy link
Contributor

@marcphilipp

While working on this issue, I created a Draft PR to ask questions along with the code if needed❕

I’m doing my best to understand and implement the issue, but there might be areas where I fall short.
If there are any mistakes or areas for improvement, I’d greatly appreciate your feedback! 🙂

YongGoose added a commit to YongGoose/junit5 that referenced this issue Jan 27, 2025
YongGoose added a commit to YongGoose/junit5 that referenced this issue Jan 27, 2025
YongGoose added a commit to YongGoose/junit5 that referenced this issue Jan 27, 2025
YongGoose added a commit to YongGoose/junit5 that referenced this issue Jan 27, 2025
YongGoose added a commit to YongGoose/junit5 that referenced this issue Jan 27, 2025
YongGoose added a commit to YongGoose/junit5 that referenced this issue Jan 27, 2025
YongGoose added a commit to YongGoose/junit5 that referenced this issue Jan 27, 2025
YongGoose added a commit to YongGoose/junit5 that referenced this issue Jan 27, 2025
YongGoose added a commit to YongGoose/junit5 that referenced this issue Jan 27, 2025
YongGoose added a commit to YongGoose/junit5 that referenced this issue Jan 27, 2025
YongGoose added a commit to YongGoose/junit5 that referenced this issue Jan 27, 2025
YongGoose added a commit to YongGoose/junit5 that referenced this issue Jan 27, 2025
YongGoose added a commit to YongGoose/junit5 that referenced this issue Jan 27, 2025
YongGoose added a commit to YongGoose/junit5 that referenced this issue Jan 27, 2025
YongGoose added a commit to YongGoose/junit5 that referenced this issue Jan 27, 2025
YongGoose added a commit to YongGoose/junit5 that referenced this issue Jan 27, 2025
YongGoose added a commit to YongGoose/junit5 that referenced this issue Jan 27, 2025
YongGoose added a commit to YongGoose/junit5 that referenced this issue Jan 27, 2025
YongGoose added a commit to YongGoose/junit5 that referenced this issue Jan 27, 2025
YongGoose added a commit to YongGoose/junit5 that referenced this issue Jan 27, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment