0

如何配置我的 Mavenpom.xml和/或sql-maven-plugin以便我在我的依赖项中指定的单元测试相关 DB 执行在构建我的项目lib.example.jdbc时不会被执行?pom.xmlcom.example.project目前,当我mvn clean installpom.xmlfor上运行时,com.example.project我发现我的 SQL 数据库中有在lib.example.jdbc. 一个明显的解决方法是mysql.database在每个pom.xml文件中使用不同的属性,但我觉得更大的问题是库的(依赖)数据库执行正在主项目的测试阶段运行。我无法想象这是正确的,因为他们自己的测试和数据库执行可能有数百个pom.xml依赖项,这些依赖项在构建最终项目时不应该运行。

更新:Spring 注释是我在回答中发现的罪魁祸首,因此我更新了问题标签以反映这一点。

pom.xml以下是来自的相关示例lib.example.jdbc

...
<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>

这是来自的相关pom.xml示例com.example.project

<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>
4

1 回答 1

1

经过进一步调查,问题似乎不在于 .sql-maven-plugin而在于 Spring 注释 (@Sql) 在com.example.projectlib.example.jdbc. lib.example.jdbc这是给我带来问题的类级别注释。我将代码从 my 移到了我的块中,schema.sql并且在测试时不再执行。data.sqlpom.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 {
        ...
    }
}
于 2017-11-30T01:10:47.517 回答