Compilation warnings and a perf question
    Dmitry Vyazelenko 
    vyazelenko at protonmail.com
       
    Mon Jun 21 14:02:25 UTC 2021
    
    
  
Hi All,
I came across a couple of issues with jcstress:
- Warnings when generating and compiling code.
  * The annotation processor:
  ```
  warning: No processor claimed any of these annotations: org.openjdk.jcstress.annotations.Actor,org.openjdk.jcstress.annotations.Arbiter,org.openjdk.jcstress.annotations.Outcome,org.openjdk.jcstress.annotations.Outcome.Outcomes,org.openjdk.jcstress.annotations.State
  ```
  * Generated code:
  ```
  warning: [rawtypes] found raw type: CounterThread
        for (CounterThread t : threads) {
             ^
  missing type arguments for generic class CounterThread<R>
  where R is a type-variable:
    R extends Object declared in class CounterThread
  ```
  Both could be silenced with `-Xlint:-processing,-rawtypes`.
- Generation of the HTML report takes forever when a test has lots of unique outcomes and a wildcard matcher is used.
The following test takes 6 minutes to complete when the test is executed without special command line options.
```
import java.util.concurrent.atomic.AtomicLong;
@JCStressTest
@Outcome(id = ".*, true", expect = Expect.ACCEPTABLE, desc = "Boring")
@State
public class WildcardResultsTest
{
    private final AtomicLong counter = new AtomicLong(System.currentTimeMillis());
    @Actor
    public void actor1(JJZ_Result result)
    {
        result.r1 = counter.getAndIncrement();
    }
    @Actor
    public void actor2(JJZ_Result result)
    {
        result.r2 = counter.getAndIncrement();
    }
    @Arbiter
    public void arbiter(JJZ_Result result)
    {
        result.r3 = result.r1 != result.r2;
    }
}
```
It takes about 5 seconds for the harness to print the `HTML report generated at ...` line but the test does not terminate until six minutes later.
Attached is the CPU profile taken with an async-profiler. As can be seen from the profile 96% of time is taken by the `org.openjdk.jcstress.infra.grading.HTMLReportPrinter#emitTestReport` method.
Regards,
Dmitry
Sent with ProtonMail Secure Email.
    
    
More information about the jcstress-dev
mailing list