Maven 项目从依赖项运行 sql-maven-plugin 执行
Maven project runs sql-maven-plugin executions from dependency
如何配置我的 Maven pom.xml
and/or sql-maven-plugin
以便单元测试相关的数据库执行我在我的依赖项中指定,lib.example.jdbc
,在构建我的项目 com.example.project
的 pom.xml
时不被执行? 当前当我 运行 mvn clean install
在 pom.xml
对于 com.example.project
,我发现我的 SQL 数据库中有在 lib.example.jdbc
中创建的表。一个明显的解决方法是在每个 pom.xml
文件中为 mysql.database
使用不同的属性,但我觉得更大的问题是库的(依赖性)数据库执行在 运行 的测试阶段主要项目。我无法想象这是正确的,因为一个人可以拥有数百个 pom.xml
依赖项以及他们自己的测试和数据库执行,而在构建最终项目时不应该 运行。
更新:Spring 注释是我在回答中发现的罪魁祸首,因此我更新了问题标签以反映这一点。
这是来自 lib.example.jdbc
的 pom.xml
的相关示例:
...
<groupId>lib.example</groupId>
<artifactId>jdbc</artifactId>
<version>1.0.0</version>
<packaging>jar</packaging>
...
<properties>
...
<mysql.port>3306</mysql.port>
<mysql.database>testDb</mysql.database>
<mysql.user>root</mysql.user>
<mysql.pass>password</mysql.pass>
</properties>
...
<build>
...
<plugins>
...
<plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>sql-maven-plugin</artifactId>
<version>1.5</version>
<dependencies>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.44</version>
</dependency>
</dependencies>
<configuration>
<driver>com.mysql.jdbc.Driver</driver>
<url>jdbc:mysql://${mysql.host}:${mysql.port}/${mysql.database}?useSSL=false</url>
<username>${mysql.user}</username>
<password>${mysql.pass}</password>
<settingsKey>sensibleKey</settingsKey>
<!--all executions are ignored if -Dmaven.test.skip=true-->
<skip>${maven.test.skip}</skip>
</configuration>
<executions>
<execution>
<id>create-db</id>
<phase>process-test-resources</phase>
<goals>
<goal>execute</goal>
</goals>
<configuration>
<url>jdbc:mysql://${mysql.host}:${mysql.port}?useSSL=false</url>
<autocommit>true</autocommit>
<sqlCommand>create database if not exists `${mysql.database}`</sqlCommand>
</configuration>
</execution>
</executions>
</plugin>
</plugins>
</build>
这里是 com.example.project
的 pom.xml
中的相关示例:
<groupId>com.example</groupId>
<artifactId>project</artifactId>
<version>0.0.1</version>
...
<properties>
...
<mysql.port>3306</mysql.port>
<mysql.database>testDb</mysql.database>
<mysql.user>root</mysql.user>
<mysql.pass>password</mysql.pass>
</properties>
...
<dependencies>
...
<dependency>
<groupId>lib.example</groupId>
<artifactId>jdbc</artifactId>
<version>1.0.0</version>
</dependency>
...
</dependencies>
...
<build>
<finalName>${project.artifactId}</finalName>
<plugins>
...
<plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>sql-maven-plugin</artifactId>
<version>1.5</version>
<dependencies>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.44</version>
</dependency>
</dependencies>
<configuration>
<driver>com.mysql.jdbc.Driver</driver>
<url>jdbc:mysql://${mysql.host}:${mysql.port}?useSSL=false</url>
<username>${mysql.user}</username>
<password>${mysql.pass}</password>
<settingsKey>sensibleKey</settingsKey>
<!--all executions are ignored if -Dmaven.test.skip=true-->
<skip>${maven.test.skip}</skip>
</configuration>
<executions>
<execution>
<id>drop-db-before-test-if-any</id>
<phase>process-test-resources</phase>
<goals>
<goal>execute</goal>
</goals>
<configuration>
<url>jdbc:mysql://${mysql.host}:${mysql.port}?useSSL=false</url>
<autocommit>true</autocommit>
<sqlCommand>drop database if exists `${mysql.database}`</sqlCommand>
<sqlCommand>create database `${mysql.database}`</sqlCommand>
</configuration>
</execution>
</executions>
</plugin>
</plugins>
</build>
经过进一步调查,问题似乎不在于 sql-maven-plugin
,而在于在 运行 时执行 Spring 注释 (@Sql) 的方式com.example.project
从 lib.example.jdbc
中的测试范围配置进行测试。这是 lib.example.jdbc
中的 class 级别注释,它给我带来了问题。我将代码从我的 schema.sql
和 data.sql
移动到我的 pom.xml
<sqlCommand>
块中,并且在测试 com.example.project
.
时不再执行它
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(classes = {TestConfig.class})
@Sql(executionPhase = Sql.ExecutionPhase.BEFORE_TEST_METHOD, scripts = {"classpath:schema.sql","classpath:data.sql"})
public class DataDaoTest {
...
@Test
public void testRetrieval() throws Exception {
...
}
}
如何配置我的 Maven pom.xml
and/or sql-maven-plugin
以便单元测试相关的数据库执行我在我的依赖项中指定,lib.example.jdbc
,在构建我的项目 com.example.project
的 pom.xml
时不被执行? 当前当我 运行 mvn clean install
在 pom.xml
对于 com.example.project
,我发现我的 SQL 数据库中有在 lib.example.jdbc
中创建的表。一个明显的解决方法是在每个 pom.xml
文件中为 mysql.database
使用不同的属性,但我觉得更大的问题是库的(依赖性)数据库执行在 运行 的测试阶段主要项目。我无法想象这是正确的,因为一个人可以拥有数百个 pom.xml
依赖项以及他们自己的测试和数据库执行,而在构建最终项目时不应该 运行。
更新:Spring 注释是我在回答中发现的罪魁祸首,因此我更新了问题标签以反映这一点。
这是来自 lib.example.jdbc
的 pom.xml
的相关示例:
...
<groupId>lib.example</groupId>
<artifactId>jdbc</artifactId>
<version>1.0.0</version>
<packaging>jar</packaging>
...
<properties>
...
<mysql.port>3306</mysql.port>
<mysql.database>testDb</mysql.database>
<mysql.user>root</mysql.user>
<mysql.pass>password</mysql.pass>
</properties>
...
<build>
...
<plugins>
...
<plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>sql-maven-plugin</artifactId>
<version>1.5</version>
<dependencies>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.44</version>
</dependency>
</dependencies>
<configuration>
<driver>com.mysql.jdbc.Driver</driver>
<url>jdbc:mysql://${mysql.host}:${mysql.port}/${mysql.database}?useSSL=false</url>
<username>${mysql.user}</username>
<password>${mysql.pass}</password>
<settingsKey>sensibleKey</settingsKey>
<!--all executions are ignored if -Dmaven.test.skip=true-->
<skip>${maven.test.skip}</skip>
</configuration>
<executions>
<execution>
<id>create-db</id>
<phase>process-test-resources</phase>
<goals>
<goal>execute</goal>
</goals>
<configuration>
<url>jdbc:mysql://${mysql.host}:${mysql.port}?useSSL=false</url>
<autocommit>true</autocommit>
<sqlCommand>create database if not exists `${mysql.database}`</sqlCommand>
</configuration>
</execution>
</executions>
</plugin>
</plugins>
</build>
这里是 com.example.project
的 pom.xml
中的相关示例:
<groupId>com.example</groupId>
<artifactId>project</artifactId>
<version>0.0.1</version>
...
<properties>
...
<mysql.port>3306</mysql.port>
<mysql.database>testDb</mysql.database>
<mysql.user>root</mysql.user>
<mysql.pass>password</mysql.pass>
</properties>
...
<dependencies>
...
<dependency>
<groupId>lib.example</groupId>
<artifactId>jdbc</artifactId>
<version>1.0.0</version>
</dependency>
...
</dependencies>
...
<build>
<finalName>${project.artifactId}</finalName>
<plugins>
...
<plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>sql-maven-plugin</artifactId>
<version>1.5</version>
<dependencies>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.44</version>
</dependency>
</dependencies>
<configuration>
<driver>com.mysql.jdbc.Driver</driver>
<url>jdbc:mysql://${mysql.host}:${mysql.port}?useSSL=false</url>
<username>${mysql.user}</username>
<password>${mysql.pass}</password>
<settingsKey>sensibleKey</settingsKey>
<!--all executions are ignored if -Dmaven.test.skip=true-->
<skip>${maven.test.skip}</skip>
</configuration>
<executions>
<execution>
<id>drop-db-before-test-if-any</id>
<phase>process-test-resources</phase>
<goals>
<goal>execute</goal>
</goals>
<configuration>
<url>jdbc:mysql://${mysql.host}:${mysql.port}?useSSL=false</url>
<autocommit>true</autocommit>
<sqlCommand>drop database if exists `${mysql.database}`</sqlCommand>
<sqlCommand>create database `${mysql.database}`</sqlCommand>
</configuration>
</execution>
</executions>
</plugin>
</plugins>
</build>
经过进一步调查,问题似乎不在于 sql-maven-plugin
,而在于在 运行 时执行 Spring 注释 (@Sql) 的方式com.example.project
从 lib.example.jdbc
中的测试范围配置进行测试。这是 lib.example.jdbc
中的 class 级别注释,它给我带来了问题。我将代码从我的 schema.sql
和 data.sql
移动到我的 pom.xml
<sqlCommand>
块中,并且在测试 com.example.project
.
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(classes = {TestConfig.class})
@Sql(executionPhase = Sql.ExecutionPhase.BEFORE_TEST_METHOD, scripts = {"classpath:schema.sql","classpath:data.sql"})
public class DataDaoTest {
...
@Test
public void testRetrieval() throws Exception {
...
}
}