Skip to content

Commit

Permalink
Adds an implementation note about @VirtualThreadUnit limitations
Browse files Browse the repository at this point in the history
  • Loading branch information
SpaceFox committed Feb 13, 2024
1 parent b70ea45 commit 9a72e36
Showing 1 changed file with 16 additions and 1 deletion.
Original file line number Diff line number Diff line change
Expand Up @@ -11,9 +11,24 @@

/**
* Extends the test case to detect pinned carrier thread.
* <br/>
* <br/>
* <b>Implementation notes:</b> current implementation uses JFR under the hood, with two consequences:
* <ol>
* <li>This test won’t work on JVM without JFR support, e.g. OpenJ9.</li>
* <li>Each test that uses this annotation is several seconds longer than versions without it.</li>
* </ol>
* This annotation uses JFR recording to detect pinning and analyze when a specific event is fired.
* Unfortunately, to ensure no events are missed, the test must ensure the JFR recording is on and off.
* It fires a mock event and wait until it read it.
* Due to JFR recording API limitations, it takes a lot of time to do these loops as there are many file reads.
* This adds several seconds to start and to stop to each test with pinned carrier thread detection enabled; and this
* additional work is mandatory to avoid missing event.
* <br/>
* This behaviour is not part of API and may change in future version.
*/
@Target(ElementType.TYPE)
@Retention(RetentionPolicy.RUNTIME)
@ExtendWith(VirtualThreadExtension.class)
public @interface VirtualThreadUnit {
}
}

0 comments on commit 9a72e36

Please sign in to comment.