Neil Hartner created SUREFIRE-865:
-------------------------------------

             Summary: surefire 2.12 with parallel=methods does not execute 
junit 4.7+ tests in parallel
                 Key: SUREFIRE-865
                 URL: https://jira.codehaus.org/browse/SUREFIRE-865
             Project: Maven Surefire
          Issue Type: Bug
          Components: Junit 4.7+ (parallel) support
         Environment: Maven 2.2.1 and 3.0.4, JDK6, JUnit 4.10 
            Reporter: Neil Hartner
         Attachments: surefire-parallel-junit.zip

parallel=methods with junit does not appear to parallelize junit test execution 
in surefire 2.12 or 2.13-SNAPSHOT.  parallel=classes works with 2.12, but 
parallel=methods only works for me in earlier versions of surefire like 2.10 
and 2.11.  I saw an earlier bug related to TestSuite classes but my tests are 
not using @Test.  I have attached a very simple maven project that demonstrates 
this issue.  It has 2 test classes with 2 tests each where each test calls 
Thread.sleep() for 4-8 seconds.  Here are a few build commands to reproduce the 
bug:

First run: mvn test -Dsurefire-version=2.11 -Dparallel=methods
Notice that in 2.11 the tests execute in two threads and in parallel.  Total 
execution time on my box was 15s.

Then run: mvn test -Dsurefire-version=2.12 -Dparallel=methods
Notice that in 2.12 the tests execute in the same main thread.  Total execution 
time on my box was 26s.

Finally run: mvn test -Dsurefire-version=2.12 -Dparallel=classes
Notice that parallel=classes does correctly execute tests in two threads and in 
parallel.  Total execution time on my box was 17s.

---

Here is output from my machine when running these commands...

Run:  
mvn test -Dsurefire-version=2.11 -Dparallel=methods

OUTPUT:
Concurrency config is parallel='methods', perCoreThreadCount=true, 
threadCount=2, useUnlimitedThreads=false
Running com.overstock.BarTest
Fri May 11 11:26:34 MDT 2012: BarTest calling sleep(5) in thread pool-1-thread-2
Fri May 11 11:26:34 MDT 2012: BarTest calling sleep(4) in thread pool-1-thread-1
Tests run: 2, Failures: 0, Errors: 0, Skipped: 0, Time elapsed: 9.033 sec
Running com.overstock.FooTest
Fri May 11 11:26:39 MDT 2012: FooTest calling sleep(7) in thread pool-1-thread-3
Fri May 11 11:26:39 MDT 2012: FooTest calling sleep(8) in thread pool-1-thread-4
Tests run: 2, Failures: 0, Errors: 0, Skipped: 0, Time elapsed: 15.008 sec

Results :

Tests run: 4, Failures: 0, Errors: 0, Skipped: 0

[INFO] ------------------------------------------------------------------------
[INFO] BUILD SUCCESSFUL
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 15 seconds


Run:  
mvn test -Dsurefire-version=2.12 -Dparallel=methods

OUTPUT:
Concurrency config is parallel='methods', perCoreThreadCount=true, 
threadCount=2, useUnlimitedThreads=false
Running com.overstock.BarTest
Fri May 11 11:25:53 MDT 2012: BarTest calling sleep(4) in thread main
Fri May 11 11:25:58 MDT 2012: BarTest calling sleep(5) in thread main
Tests run: 2, Failures: 0, Errors: 0, Skipped: 0, Time elapsed: 9.017 sec
Running com.overstock.FooTest
Fri May 11 11:26:03 MDT 2012: FooTest calling sleep(7) in thread main
Fri May 11 11:26:10 MDT 2012: FooTest calling sleep(8) in thread main
Tests run: 2, Failures: 0, Errors: 0, Skipped: 0, Time elapsed: 15.003 sec

Results :

Tests run: 4, Failures: 0, Errors: 0, Skipped: 0

[INFO] ------------------------------------------------------------------------
[INFO] BUILD SUCCESSFUL
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 26 seconds


Run:
mvn test -Dsurefire-version=2.12 -Dparallel=classes

OUTPUT:
Concurrency config is parallel='classes', perCoreThreadCount=true, 
threadCount=2, useUnlimitedThreads=false
Running com.overstock.BarTest
Fri May 11 11:27:38 MDT 2012: BarTest calling sleep(4) in thread pool-1-thread-1
Fri May 11 11:27:42 MDT 2012: BarTest calling sleep(5) in thread pool-1-thread-1
Tests run: 2, Failures: 0, Errors: 0, Skipped: 0, Time elapsed: 9.016 sec
Running com.overstock.FooTest
Fri May 11 11:27:38 MDT 2012: FooTest calling sleep(7) in thread pool-1-thread-2
Fri May 11 11:27:45 MDT 2012: FooTest calling sleep(8) in thread pool-1-thread-2
Tests run: 2, Failures: 0, Errors: 0, Skipped: 0, Time elapsed: 15.016 sec

Results :

Tests run: 4, Failures: 0, Errors: 0, Skipped: 0

[INFO] ------------------------------------------------------------------------
[INFO] BUILD SUCCESSFUL
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 17 seconds

--
This message is automatically generated by JIRA.
If you think it was sent incorrectly, please contact your JIRA administrators: 
https://jira.codehaus.org/secure/ContactAdministrators!default.jspa
For more information on JIRA, see: http://www.atlassian.com/software/jira

        

Reply via email to