You are viewing a plain text version of this content. The canonical link for it is here.
Posted to surefire-commits@maven.apache.org by kr...@apache.org on 2010/12/29 14:41:45 UTC
svn commit: r1053634 - in
/maven/surefire/trunk/surefire-integration-tests/src/test:
java/org/apache/maven/surefire/its/
resources/testng-parallel-with-annotations/
resources/testng-parallel-with-annotations/src/
resources/testng-parallel-with-annotati...
Author: krosenvold
Date: Wed Dec 29 13:41:45 2010
New Revision: 1053634
URL: http://svn.apache.org/viewvc?rev=1053634&view=rev
Log:
[SUREFIRE-546] Test case for @Test(threadPoolSize)
Patch applied with modifications
Added:
maven/surefire/trunk/surefire-integration-tests/src/test/java/org/apache/maven/surefire/its/TestNgParallelWithAnnotations.java (with props)
maven/surefire/trunk/surefire-integration-tests/src/test/resources/testng-parallel-with-annotations/
maven/surefire/trunk/surefire-integration-tests/src/test/resources/testng-parallel-with-annotations/pom.xml (with props)
maven/surefire/trunk/surefire-integration-tests/src/test/resources/testng-parallel-with-annotations/src/
maven/surefire/trunk/surefire-integration-tests/src/test/resources/testng-parallel-with-annotations/src/test/
maven/surefire/trunk/surefire-integration-tests/src/test/resources/testng-parallel-with-annotations/src/test/java/
maven/surefire/trunk/surefire-integration-tests/src/test/resources/testng-parallel-with-annotations/src/test/java/testng/
maven/surefire/trunk/surefire-integration-tests/src/test/resources/testng-parallel-with-annotations/src/test/java/testng/paralellwithannotations/
maven/surefire/trunk/surefire-integration-tests/src/test/resources/testng-parallel-with-annotations/src/test/java/testng/paralellwithannotations/TestNGParallelTest.java (with props)
Added: maven/surefire/trunk/surefire-integration-tests/src/test/java/org/apache/maven/surefire/its/TestNgParallelWithAnnotations.java
URL: http://svn.apache.org/viewvc/maven/surefire/trunk/surefire-integration-tests/src/test/java/org/apache/maven/surefire/its/TestNgParallelWithAnnotations.java?rev=1053634&view=auto
==============================================================================
--- maven/surefire/trunk/surefire-integration-tests/src/test/java/org/apache/maven/surefire/its/TestNgParallelWithAnnotations.java (added)
+++ maven/surefire/trunk/surefire-integration-tests/src/test/java/org/apache/maven/surefire/its/TestNgParallelWithAnnotations.java Wed Dec 29 13:41:45 2010
@@ -0,0 +1,43 @@
+package org.apache.maven.surefire.its;
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one
+ * or more contributor license agreements. See the NOTICE file
+ * distributed with this work for additional information
+ * regarding copyright ownership. The ASF licenses this file
+ * to you under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance
+ * with the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing,
+ * software distributed under the License is distributed on an
+ * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+ * KIND, either express or implied. See the License for the
+ * specific language governing permissions and limitations
+ * under the License.
+ */
+
+
+/**
+ * Test that TestNG's @Test(threadPoolSize = n, invocationCount=n) causes tests to be run in parallel.
+ *
+ * @author <a href="mailto:spam.haikal@gmail.com">Haikal Saadh</a>
+ *
+ */
+public class TestNgParallelWithAnnotations
+ extends SurefireVerifierTestClass
+{
+ public TestNgParallelWithAnnotations()
+ {
+ super( "/testng-parallel-with-annotations" );
+ }
+
+ public void testTestNgGroupThreadParallel ()
+ throws Exception
+ {
+ executeTest();
+ verifyErrorFreeLog();
+ assertTestSuiteResults( 3, 0, 0, 0 );
+ }
+}
Propchange: maven/surefire/trunk/surefire-integration-tests/src/test/java/org/apache/maven/surefire/its/TestNgParallelWithAnnotations.java
------------------------------------------------------------------------------
svn:eol-style = native
Added: maven/surefire/trunk/surefire-integration-tests/src/test/resources/testng-parallel-with-annotations/pom.xml
URL: http://svn.apache.org/viewvc/maven/surefire/trunk/surefire-integration-tests/src/test/resources/testng-parallel-with-annotations/pom.xml?rev=1053634&view=auto
==============================================================================
--- maven/surefire/trunk/surefire-integration-tests/src/test/resources/testng-parallel-with-annotations/pom.xml (added)
+++ maven/surefire/trunk/surefire-integration-tests/src/test/resources/testng-parallel-with-annotations/pom.xml Wed Dec 29 13:41:45 2010
@@ -0,0 +1,46 @@
+<?xml version="1.0" encoding="UTF-8"?>
+ <!--
+ ~ Licensed to the Apache Software Foundation (ASF) under one ~ or more contributor license agreements. See the NOTICE file ~
+ distributed with this work for additional information ~ regarding copyright ownership. The ASF licenses this file ~ to you under
+ the Apache License, Version 2.0 (the ~ "License"); you may not use this file except in compliance ~ with the License. You may
+ obtain a copy of the License at ~ ~ http://www.apache.org/licenses/LICENSE-2.0 ~ ~ Unless required by applicable law or agreed
+ to in writing, ~ software distributed under the License is distributed on an ~ "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS
+ OF ANY ~ KIND, either express or implied. See the License for the ~ specific language governing permissions and limitations ~
+ under the License.
+ -->
+
+<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
+ xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
+ <modelVersion>4.0.0</modelVersion>
+
+ <groupId>org.apache.maven.plugins.surefire</groupId>
+ <artifactId>testng-group-thread-parallel</artifactId>
+ <version>1.0-SNAPSHOT</version>
+ <name>TestNG group/parallel thread tests, with parallel settings set by @Test(threadPoolSize)</name>
+ <dependencies>
+ <dependency>
+ <groupId>org.testng</groupId>
+ <artifactId>testng</artifactId>
+ <version>5.8</version>
+ <classifier>jdk15</classifier>
+ <scope>test</scope>
+ </dependency>
+ </dependencies>
+ <build>
+ <plugins>
+ <plugin>
+ <groupId>org.apache.maven.plugins</groupId>
+ <artifactId>maven-surefire-plugin</artifactId>
+ <version>${surefire.version}</version>
+ </plugin>
+ <plugin>
+ <groupId>org.apache.maven.plugins</groupId>
+ <artifactId>maven-compiler-plugin</artifactId>
+ <configuration>
+ <source>1.5</source>
+ <target>1.5</target>
+ </configuration>
+ </plugin>
+ </plugins>
+ </build>
+</project>
Propchange: maven/surefire/trunk/surefire-integration-tests/src/test/resources/testng-parallel-with-annotations/pom.xml
------------------------------------------------------------------------------
svn:eol-style = native
Added: maven/surefire/trunk/surefire-integration-tests/src/test/resources/testng-parallel-with-annotations/src/test/java/testng/paralellwithannotations/TestNGParallelTest.java
URL: http://svn.apache.org/viewvc/maven/surefire/trunk/surefire-integration-tests/src/test/resources/testng-parallel-with-annotations/src/test/java/testng/paralellwithannotations/TestNGParallelTest.java?rev=1053634&view=auto
==============================================================================
--- maven/surefire/trunk/surefire-integration-tests/src/test/resources/testng-parallel-with-annotations/src/test/java/testng/paralellwithannotations/TestNGParallelTest.java (added)
+++ maven/surefire/trunk/surefire-integration-tests/src/test/resources/testng-parallel-with-annotations/src/test/java/testng/paralellwithannotations/TestNGParallelTest.java Wed Dec 29 13:41:45 2010
@@ -0,0 +1,42 @@
+package testng.paralellwithannotations;
+
+import static org.testng.Assert.*;
+import org.testng.annotations.AfterSuite;
+import org.testng.annotations.BeforeSuite;
+import org.testng.annotations.Test;
+import java.util.Date;
+
+/**
+ * Test that parallel tests actually run and complete within the expected time.
+ */
+public class TestNGParallelTest{
+
+ static int testCount = 0;
+ static long startTime;
+
+ @BeforeSuite(alwaysRun = true)
+ public void startClock(){
+ startTime = new Date().getTime();
+ }
+
+ @AfterSuite(alwaysRun = true)
+ public void checkTestResults(){
+ long runtime = new Date().getTime() - startTime;
+ System.out.println("Runtime was: " + runtime);
+ assertTrue( testCount == 3, "Expected test to be run 3 times, but was " + testCount);
+ // Note, this can be < 1000 on Windows.
+ assertTrue( runtime < 1400, "Runtime was " + runtime + ". It should be a little over 1000ms");
+ }
+
+ @Test(threadPoolSize = 2, invocationCount=3)
+ public void incrementTestCountAndSleepForOneSecond() throws InterruptedException {
+ incrementTestCount();
+ Thread.sleep(500);
+ System.out.println("Ran test");
+ }
+
+ private synchronized void incrementTestCount() {
+ testCount++;
+ }
+
+}
Propchange: maven/surefire/trunk/surefire-integration-tests/src/test/resources/testng-parallel-with-annotations/src/test/java/testng/paralellwithannotations/TestNGParallelTest.java
------------------------------------------------------------------------------
svn:eol-style = native