我有一个Maven POM文件,当我提供并行执行选项时,我在日志中看不到任何并行执行的迹象。 XML调试让我疯狂。有什么想法吗?
<?xml version="1.0" encoding="UTF-8"?>
<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/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>com.xxx.xxxx.testing.ranger</groupId>
<artifactId>ranger-parent</artifactId>
<relativePath>../parent/pom.xml</relativePath>
<version>1.0.0</version>
</parent>
<artifactId>ranger-api-tests</artifactId>
<name>Ranger API Tests</name>
<description>Ranger API integration tests. Depends on the Ranger test framework project.</description>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<test.groups />
<surefire.and.failsafe.report.dir>C:/Users/xxx/Documents/Projects/LearnCubeAPIIT/tests/target</surefire.and.failsafe.report.dir>
</properties>
<dependencies>
<!-- Granite Testing framework -->
<dependency>
<groupId>com.xxx.xxxx.testing.ranger</groupId>
<artifactId>ranger-api-it-framework</artifactId>
<version>1.0.0</version>
</dependency>
<dependency>
<groupId>commons-lang</groupId>
<artifactId>commons-lang</artifactId>
<version>2.4</version>
</dependency>
<dependency>
<groupId>commons-httpclient</groupId>
<artifactId>commons-httpclient</artifactId>
<version>3.1</version>
</dependency>
<dependency>
<groupId>org.apache.maven.surefire</groupId>
<artifactId>surefire-junit47</artifactId>
<version>2.16</version>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.11</version>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-failsafe-plugin</artifactId>
<version>2.16</version>
<configuration>
<parallel>classes</parallel>
<threadCount>4</threadCount>
<reportsDirectory>${project.build.directory}/surefire-reports</reportsDirectory>
<groups>${test.groups}</groups>
</configuration>
<executions>
<execution>
<goals>
<goal>integration-test</goal>
<goal>verify</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
<reporting>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-surefire-report-plugin</artifactId>
<version>2.16</version>
<configuration>
<reportsDirectory>${project.build.directory}/surefire-reports</reportsDirectory>
</configuration>
<reportSets>
<reportSet>
<id>integration-tests</id>
<reports>
<report>failsafe-report-only</report>
<report>report-only</report>
</reports>
</reportSet>
</reportSets>
</plugin>
</plugins>
</reporting>
</project>
运行日志 - http://pastebin.com/WkCDwYzJ
问题 - 当并行执行选项传递给failsafe插件时,日志应该如何确认是否正在进行并行执行测试?
更新
我注意到当我为maven设置debug选项来执行时,我注意到parallelExecution被设置为false
[DEBUG] Populating class realm plugin>org.apache.maven.plugins:maven-surefire-plugin:2.12.4--1057774753
[DEBUG] Included: org.apache.maven.plugins:maven-surefire-plugin:jar:2.12.4
[DEBUG] Included: org.apache.maven.surefire:surefire-booter:jar:2.12.4
[DEBUG] Included: org.apache.maven.surefire:surefire-api:jar:2.12.4
[DEBUG] Included: org.apache.maven.surefire:maven-surefire-common:jar:2.12.4
[DEBUG] Included: org.apache.commons:commons-lang3:jar:3.1
[DEBUG] Included: org.apache.maven.shared:maven-common-artifact-filters:jar:1.3
[DEBUG] Included: org.codehaus.plexus:plexus-utils:jar:3.0.8
[DEBUG] Included: org.apache.maven.reporting:maven-reporting-api:jar:2.0.9
[DEBUG] Included: org.apache.maven.plugin-tools:maven-plugin-annotations:jar:3.1
[DEBUG] Excluded: org.apache.maven:maven-plugin-api:jar:2.0.9
[DEBUG] Excluded: org.apache.maven:maven-artifact:jar:2.0.9
[DEBUG] Excluded: org.apache.maven:maven-project:jar:2.0.9
[DEBUG] Excluded: org.apache.maven:maven-settings:jar:2.0.9
[DEBUG] Excluded: org.apache.maven:maven-profile:jar:2.0.9
[DEBUG] Excluded: org.apache.maven:maven-model:jar:2.0.9
[DEBUG] Excluded: org.apache.maven:maven-artifact-manager:jar:2.0.9
[DEBUG] Excluded: org.apache.maven:maven-plugin-registry:jar:2.0.9
[DEBUG] Excluded: org.codehaus.plexus:plexus-container-default:jar:1.0-alpha-9-stable-1
[DEBUG] Excluded: junit:junit:jar:3.8.1
[DEBUG] Excluded: org.apache.maven:maven-core:jar:2.0.9
[DEBUG] Excluded: org.apache.maven:maven-plugin-parameter-documenter:jar:2.0.9
[DEBUG] Excluded: org.apache.maven:maven-repository-metadata:jar:2.0.9
[DEBUG] Excluded: org.apache.maven:maven-error-diagnostics:jar:2.0.9
[DEBUG] Excluded: org.apache.maven:maven-plugin-descriptor:jar:2.0.9
[DEBUG] Excluded: org.apache.maven:maven-monitor:jar:2.0.9
[DEBUG] Excluded: classworlds:classworlds:jar:1.1
[DEBUG] Excluded: org.apache.maven:maven-toolchain:jar:2.0.9
[DEBUG] Configuring mojo org.apache.maven.plugins:maven-surefire-plugin:2.12.4:test from plugin realm ClassRealm[plugin>org.apache.maven.plugins:maven-surefire-plugin:2.12.4--1057774753, parent: sun.misc.Launcher$AppClassLoader@7987aeca]
[DEBUG] Configuring mojo 'org.apache.maven.plugins:maven-surefire-plugin:2.12.4:test' with basic configurator -->
[DEBUG] (s) basedir = /Users/nallagun/Git/testing/Ranger/tests
[DEBUG] (s) childDelegation = false
[DEBUG] (s) classesDirectory = /Users/nallagun/Git/testing/Ranger/tests/target/classes
[DEBUG] (s) disableXmlReport = false
[DEBUG] (s) enableAssertions = true
[DEBUG] (s) forkMode = once
[DEBUG] (s) junitArtifactName = junit:junit
[DEBUG] (s) localRepository = id: local
url: file:///Users/nallagun/.m2/repository/
layout: none
[DEBUG] (s) parallel = classes
[DEBUG] (f) parallelMavenExecution = false
[DEBUG] (s) perCoreThreadCount = true
任何想法为什么会发生这种情况?
由于
答案 0 :(得分:5)
首先,确保您强制使用特定的jUnit提供程序,因为已知旧版本(&lt; 4.7)具有并发执行的issues。
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-failsafe-plugin</artifactId>
<version>2.16</version>
<dependencies>
<dependency>
<groupId>org.apache.maven.surefire</groupId>
<artifactId>surefire-junit47</artifactId>
<version>2.16</version>
</dependency>
</dependencies>
</plugin>
您可以使用forkCount
作为并发执行选项而不是parallel
。我发现它更灵活,并且由于每个测试都在自己的JVM中运行,因此您可能会遇到较少的并发问题,这可能会使您的测试结果不确定。这些配置适用于maven-surefire-plugin
和maven-failsafe-plugin
。
<forkCount>8</forkCount>
<reuseForks>true</reuseForks>
您可以合并forkCount
和parallel
,但forkCount
,reuseForks
等不同的可能组合会使事情变得更复杂。请注意docs:
当使用reuseForks = true且forkCount值大于1时,请测试 类被逐个移交给分叉进程。从而, parallel = classes不会改变任何东西。但是,你可以使用 parallel =方法:类在forkCount并发中执行 进程中,每个进程都可以使用threadCount线程 并行执行一个类的方法。
我不确定报告是否会告诉您测试是否以并发模式运行,但我知道它们正在运行的方式是使用top
或htop
(在Linux或OS X上) )。这是我的测试运行的截图。您可以看到多个JVM运行测试并消耗CPU。我的测试也以这种方式运行得更快。