首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在命令行上运行目标的所有绑定实例

在命令行上运行目标的所有绑定实例
EN

Stack Overflow用户
提问于 2010-01-23 06:04:02
回答 2查看 194关注 0票数 3

我将一些SQL命令绑定到pre-integration-test阶段,它们的工作是创建一个“测试”数据库,并将应用程序指向该数据库。

有时,我只想“重建”我的测试数据库,而不需要生命周期中的所有其他东西。例如,如果我的测试灾难性地失败了,并且搞砸了测试数据库,我可能不得不重新构建它几次,直到我找出问题所在。

下面是我的POM:

代码语言:javascript
复制
<profile>
    <id>test-setup-teardown</id>
       <activation>
           <activeByDefault>true</activeByDefault>
       </activation>
       <build>
           <plugins>
               <plugin>
                    <groupId>org.codehaus.mojo</groupId>
                    <artifactId>sql-maven-plugin</artifactId>
                    <version>1.3</version>

                    <dependencies>
                        <dependency>
                            <groupId>${database-dependency-groupId}</groupId>
                            <artifactId>${database-dependency-artifactId}</artifactId>
                            <version>${database-dependency-version}</version>
                        </dependency>
                    </dependencies>

                    <configuration>
                        <url>${test-database-admin-url}</url>
                        <username>${test-database-admin-username}</username>
                        <password>${test-database-admin-password}</password>
                        <driver>${database-driver}</driver>
                        <autocommit>true</autocommit>
                    </configuration>

                    <executions>
                        <execution>
                            <id>test-database-pre-setup</id>
                            <phase>pre-integration-test</phase>
                            <goals>
                                <goal>execute</goal>
                            </goals>
                            <configuration>
                                <sqlCommand>${test-database-teardown}</sqlCommand>
                                <onError>continue</onError>
                            </configuration>
                        </execution>

                        <execution>
                            <id>test-database-setup</id>
                            <phase>pre-integration-test</phase>
                            <goals>
                                <goal>execute</goal>
                            </goals>
                            <configuration>
                                <sqlCommand>${test-database-setup}</sqlCommand>
                            </configuration>
                        </execution>

                        <execution>
                            <id>test-database-schema</id>
                            <phase>pre-integration-test</phase>
                            <goals>
                                <goal>execute</goal>
                            </goals>
                            <configuration>
                                <url>${test-database-url}</url>
                                <username>${database-user}</username>
                                <password>${database-password}</password>
                                <srcFiles>
                                    <srcFile>${basedir}/metadata/build/database/${database-engine}/appx.sql</srcFile>
                                </srcFiles>
                            </configuration>
                        </execution>

                        <execution>
                            <id>test-database-teardown</id>
                            <phase>post-integration-test</phase>
                            <goals>
                                <goal>execute</goal>
                            </goals>
                            <configuration>
                                <sqlCommand>${test-database-teardown}</sqlCommand>
                            </configuration>
                        </execution>
                    </executions>
                </plugin>
            </plugins>
        </build>
    </profile>

如何运行此配置文件的所有执行?像mvn sql:execute这样的工具只运行其中的一次执行(我想是最后一次)。

我已经尝试将绑定阶段设置为一个属性,然后允许用户指定另一个配置文件,该配置文件将默认设置从pre-integration-test更改为validate,但是我向某人解释了为什么要这样执行重建:

代码语言:javascript
复制
mvn validate -Pforce-rebuild,test-setup-teardown

简单地强调了一个事实,即非玩具项目在POM中具有很多魔力。请给我带路!

也许一个好的解决方案是从命令行按id运行执行?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2010-01-23 21:50:37

也许一个好的解决方案是从命令行按id运行执行?

这是不可能的。执行是为了绑定到生命周期。

而且调用sql:execute并在命令行上传递所有参数似乎不是一个可行的选择(这可以在批处理脚本中完成,但是srcFiles可选参数无论如何都会有问题)。

因此,在我看来,“不那么糟糕”的选项是在另一个概要文件中复制(叹息) sql-maven-plugin设置,例如rebuild,以便在validate阶段绑定所需的执行,并在此概要文件中将validate目标声明为默认目标。这将允许键入类似如下的内容:

代码语言:javascript
复制
mvn -Prebuild

也许一些优化可以避免重复(通过像您一样将执行阶段可变),但这对我来说意味着更多的黑魔法(这可能不是我们想要的)。

票数 1
EN

Stack Overflow用户

发布于 2010-01-23 06:09:22

“预集成-测试”是一个可以直接调用的阶段。

代码语言:javascript
复制
mvn -Ptest-setup-teardown pre-integration-test

这仍然会经历编译、复制资源、单元测试等生命周期。您可以尝试将-DskipTests=true添加到命令中(不确定这是否也会跳过集成测试阶段):

代码语言:javascript
复制
mvn -Ptest-setup-teardown pre-integration-test -DskipTests=true
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/2120880

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档