Skip to content

Commit e1b85f3

Browse files
srowenpwendell
authored andcommitted
SPARK-2955 [BUILD] Test code fails to compile with "mvn compile" without "install"
(This is the corrected follow-up to https://issues.apache.org/jira/browse/SPARK-2903) Right now, `mvn compile test-compile` fails to compile Spark. (Don't worry; `mvn package` works, so this is not major.) The issue stems from test code in some modules depending on test code in other modules. That is perfectly fine and supported by Maven. It takes extra work to get this to work with scalatest, and this has been attempted: https://github.com/apache/spark/blob/master/sql/catalyst/pom.xml#L86 This formulation is not quite enough, since the SQL Core module's tests fail to compile for lack of finding test classes in SQL Catalyst, and likewise for most Streaming integration modules depending on core Streaming test code. Example: ``` [error] /Users/srowen/Documents/spark/sql/core/src/test/scala/org/apache/spark/sql/QueryTest.scala:23: not found: type PlanTest [error] class QueryTest extends PlanTest { [error] ^ [error] /Users/srowen/Documents/spark/sql/core/src/test/scala/org/apache/spark/sql/CachedTableSuite.scala:28: package org.apache.spark.sql.test is not a value [error] test("SPARK-1669: cacheTable should be idempotent") { [error] ^ ... ``` The issue I believe is that generation of a `test-jar` is bound here to the `compile` phase, but the test classes are not being compiled in this phase. It should bind to the `test-compile` phase. It works when executing `mvn package` or `mvn install` since test-jar artifacts are actually generated available through normal Maven mechanisms as each module is built. They are then found normally, regardless of scalatest configuration. It would be nice for a simple `mvn compile test-compile` to work since the test code is perfectly compilable given the Maven declarations. On the plus side, this change is low-risk as it only affects tests. yhuai made the original scalatest change and has glanced at this and thinks it makes sense. Author: Sean Owen <[email protected]> Closes #1879 from srowen/SPARK-2955 and squashes the following commits: ad8242f [Sean Owen] Generate test-jar on test-compile for modules whose tests are needed by others' tests
1 parent 500f84e commit e1b85f3

File tree

2 files changed

+18
-18
lines changed

2 files changed

+18
-18
lines changed

sql/catalyst/pom.xml

Lines changed: 14 additions & 14 deletions
Original file line numberDiff line numberDiff line change
@@ -77,28 +77,28 @@
7777
<!--
7878
This plugin forces the generation of jar containing catalyst test classes,
7979
so that the tests classes of external modules can use them. The two execution profiles
80-
are necessary - first one for 'mvn package', second one for 'mvn compile'. Ideally,
80+
are necessary - first one for 'mvn package', second one for 'mvn test-compile'. Ideally,
8181
'mvn compile' should not compile test classes and therefore should not need this.
8282
However, an open Maven bug (http://jira.codehaus.org/browse/MNG-3559)
8383
causes the compilation to fail if catalyst test-jar is not generated. Hence, the
84-
second execution profile for 'mvn compile'.
84+
second execution profile for 'mvn test-compile'.
8585
-->
8686
<plugin>
8787
<groupId>org.apache.maven.plugins</groupId>
8888
<artifactId>maven-jar-plugin</artifactId>
8989
<executions>
90-
<execution>
91-
<goals>
92-
<goal>test-jar</goal>
93-
</goals>
94-
</execution>
95-
<execution>
96-
<id>test-jar-on-compile</id>
97-
<phase>compile</phase>
98-
<goals>
99-
<goal>test-jar</goal>
100-
</goals>
101-
</execution>
90+
<execution>
91+
<goals>
92+
<goal>test-jar</goal>
93+
</goals>
94+
</execution>
95+
<execution>
96+
<id>test-jar-on-test-compile</id>
97+
<phase>test-compile</phase>
98+
<goals>
99+
<goal>test-jar</goal>
100+
</goals>
101+
</execution>
102102
</executions>
103103
</plugin>
104104
</plugins>

streaming/pom.xml

Lines changed: 4 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -81,11 +81,11 @@
8181
<!--
8282
This plugin forces the generation of jar containing streaming test classes,
8383
so that the tests classes of external modules can use them. The two execution profiles
84-
are necessary - first one for 'mvn package', second one for 'mvn compile'. Ideally,
84+
are necessary - first one for 'mvn package', second one for 'mvn test-compile'. Ideally,
8585
'mvn compile' should not compile test classes and therefore should not need this.
8686
However, an open Maven bug (http://jira.codehaus.org/browse/MNG-3559)
8787
causes the compilation to fail if streaming test-jar is not generated. Hence, the
88-
second execution profile for 'mvn compile'.
88+
second execution profile for 'mvn test-compile'.
8989
-->
9090
<plugin>
9191
<groupId>org.apache.maven.plugins</groupId>
@@ -97,8 +97,8 @@
9797
</goals>
9898
</execution>
9999
<execution>
100-
<id>test-jar-on-compile</id>
101-
<phase>compile</phase>
100+
<id>test-jar-on-test-compile</id>
101+
<phase>test-compile</phase>
102102
<goals>
103103
<goal>test-jar</goal>
104104
</goals>

0 commit comments

Comments
 (0)