5

这些测试应该在构建 jar 文件之后运行。他们应该测试它是否完全运行,以及它是否在给定某些输入文件的情况下产生正确的控制台输出。

您能否指出一些针对控制台应用程序进行此类测试的示例?这些测试是否必须用 Java 编写才能与 Maven 一起使用?

有一个类似的问题(基于测试控制台的应用程序/程序 - Java),但我需要的是黑盒测试,而不是单元测试。它没有提到Maven。


更新:

事实证明,这很容易做到。我的第一个问题是在这里看到这么多定义后对集成测试的误解(什么是单元测试、集成测试、冒烟测试、回归测试?单元测试、功能测试、验收测试和集成测试有什么区别?);什么是单元测试和集成测试,以及我应该了解哪些其他类型的测试?究竟什么是集成测试?)。第二个问题是我不打算用 Java 编写这些测试,但最终我不得不学习如何使用java.lang.Runtime.

首先,我已将此添加到我的pom.xml中:

<plugin>
    <artifactId>maven-failsafe-plugin</artifactId>
    <version>2.6</version>
    <executions>
        <execution>
            <goals>
                <goal>integration-test</goal>
                <goal>verify</goal>
            </goals>
        </execution>
    </executions>
</plugin>

然后我在src/test/java创建了一个*IT.java文件:

public class MyAppIT {

    @Test
    public void test() throws IOException {
        Runtime runtime = Runtime.getRuntime();
        String cmd = "java -cp target/myapp.jar my.app.Main";
        Process process = runtime.exec(cmd);
        InputStreamReader isr = new InputStreamReader(process.getErrorStream());
        BufferedReader br = new BufferedReader(isr);
        Boolean containsUsage = false;
        String line;
        while ((line = br.readLine()) != null) {
            if (line.contains("Usage")) {
                containsUsage = true;
            }
        }
        assertTrue(containsUsage);
    }
}

现在我使用mvn verify而不是mvn package

Results :

Tests run: 1, Failures: 0, Errors: 0, Skipped: 0
4

2 回答 2

3

看来您想要集成测试。

在许多情况下,应用程序是由持续集成 (CI) 系统构建的,例如 Hudson、Travis 等。此 CI 在每次提交源代码后编译并运行单元测试。编译成功后,将触发集成测试项目。

集成测试驻留在单独的 Maven 源项目中。您将像在 src/test/java 中的普通单元测试一样创建集成测试类。当然,您不会孤立地测试单个类-即单元测试-您为集成测试设置系统(连接正确的组件)并执行所需的测试“冒烟测试”。

因此,在您的情况下,您可以为集成测试创建另一个项目,并在构建应用程序后执行此项目。您可以创建一个 maven parent-pom 并使用子模块来避免手动集成测试构建。

测试类需要是 java 并且位于 src/test/java 中,它们看起来像普通的单元测试并且由 maven 运行。当然,您可以在该测试中启动一个非 java 程序并断言结果。

控制台应用程序有一个“ main ”方法,所以我会在测试中调用 main 方法。否则你必须运行一个shell命令或其他东西。(通过 java.lang.Runtime)

测试控制台应用程序没有专长。除非您想测试用户界面 - 用户界面的自动化测试并不容易而且更加困难,请澄清这是否是您的重点。

于 2012-12-28T12:32:50.713 回答
1

我建议将maven-invoker-pluginexec-maven-plugin结合使用。Invoker 创建一个子项目并运行它,其中 exec 插件启动您的 JAR。然后调用者验证它的输出。

例如,看一下s3auth-relay项目pom.xml中的这个。该模块本身产生一个 JAR 控制台应用程序,它是一个 HTTP 守护程序。这是配置的一部分。它启动控制台应用程序并检查它是否正常关闭。为了防止 JAR 作为守护进程启动,我们使用了一个可选标志。pom.xmlmaven-invoker-plugin-d

该示例没有显示测试 JAR 输出的能力,但可以使用maven-invoker-plugin.

于 2012-12-28T14:49:25.823 回答