基本概念
测试过程中,如果有验证码的参与,可以通过引入外部jar包或者内部控制验证码的生成和验证。
Maven的职责之一就是自动运行单元测试,它通过maven-surefire-plugin与Junit、TestNG等单元测试框架集成,并且能够自动生成丰富的结果报告。
当对应的测试代码编写完毕,只需要在项目目录下执行 mvn test 命令,就会得到对应的输出报告。如Maven和Junit结合使用,报告中执行的测试类和Junit的报告信息Failures、Errors、Skipped,Failures表示要测试的结果与预期不一致的个数,Errors表示测试代码或者产品代码发生的未预期的错误个数,Skipped表示那些被标记忽略的测试方法个数。
maven-surefire-plugin
Maven所做的只是在构建执行到特定生命周期的时候,通过插件来执行Junit和TestNG的测试用例,这个插件就是maven-surefire-plugin,它是在default生命周期的test阶段与test目标相绑定了。
在默认情况下,maven-surefire-plugin的test目标会自动执行测试源码路径(src/test/java)下所有符合一组测试命名模式的测试类,命名模式有/Test.java、/Test.java、*/TestCase.java。
如果需要跳过测试阶段可以通过mvn的命令$ mvn package -DskipTests或者在POM文件中配置maven-surefire-plugin属性即可。
maven-surefire-plugin提供了test参数让Maven用户能够在命令行指定要执行的测试类,示例代码如下:
$ mvn test -Dtest = RandomTest
表示测试的时候只执行RandomTest测试类,-Dtest后面的值可以是*表示相匹配的测试类执行,也可以用户“,”隔开表示匹配执行多个测试类
test参数的值必需匹配一个或者多个测试类,如果maven-surefire-plugin找不到任何匹配的测试类,就会报错导致构建失败,当然这种情况也是可以通过Maven命令杜绝的,让其即使没有任何测试也不要报错。
默认的测试类命名模式不满足用户的需求时,也可以在POM文件中配置maven-surefire-plugin属性来排除或者增加一些命令模式。
测试报告
默认情况下,maven-surefire-plugin会在项目的target/surefire-reports目录下生成两种格式的错误报告:简单文本格式、与Junit兼容的XML格式。
XML格式的测试报告主要是为了支持工具的解析,如Eclipse的Junit插件就可以直接打开这样的XML格式的错误报告,作为一种Java测试报告的事实标准,一些其它工具也能够使用它们。
测试覆盖率是衡量项目测试代码质量的一个重要的参考指标,Maven有插件和外部工具集成,用户可以使用简单的命令与Maven生成测试覆盖率报告。
重用测试代码,可以将经常使用的测试代码进行打包,根据生成jar的不同,在POM文件中进行配置,可将测试生成的jar包加入default声明周期当中执行。
文章仅供参考,代码并不是全正确,只需要知道在对应的情况,可以做对应的处理,代码是变化的,我相信原理不变