ant集成junit自动测试的build.xml标准模板

利用Ant集成Junit自动测试并生成测试报告,可以极大的提高测试的工作效率,其优势只要是测试用例的批量处理功能。前不久在网上看到很多关于Junit测试的文章,欣闻Ant支持Junit的集成,迫不及待的尝试了一番。

1.         ant的配置:

本案例采用apache-ant- 1.6.5 版本,下载ant后需要将Junit3.8.1拷贝到ANT_HOMElib目录下。Ant在执行过程TestCase过程中除了需要在classpath中可见,还需要在ant中可见,否则会报错。

2.         目录结构:

工作目录

|src|com|wallace|Calculator.java

                            |test|TestCalculator.java

|lib|junit.jar

|build

|report

3.         build.xml模板:

<?xml version="1.0" encoding="utf-8"?>

<project name="test" default="test" basedir=".">

 

       <!--配置基本属性-->

       <property name="src" value="src"/>

       <property name="build" value="build"/>

       <property name="lib" value="lib" />

       <property name="dist" value="dist"/>

       <property name="classpath" location="${build}"/>

      

       <!--配置测试报告的属性-->

       <property name="report"   value="report"/>

       <property name="report.xml"  value="${report}/junit/xml"/>

       <property name="report.html" value="${report}/junit/html"/>

 

       <!--配置运行时classpath-->

       <path id="classpath.run">

              <pathelement path="${classpath}"/>

              <fileset dir="${lib}">

                     <include name="*.jar"/>

              </fileset>

       </path>

 

  <!--配置测试时classpath-->

       <path id="classpath.test">

              <path refid="classpath.run"/>

              <path location="${dist}/lib/test-${DSTAMP}.jar"/>

       </path>

      

       <!--任务初始化-->

       <target name="init" >

              <tstamp/>

              <delete dir="${build}"/>

              <delete dir="${report}"/>

              <delete dir="${dist}"/>

              <mkdir dir="${build}"/>

       </target>

      

       <!--配置编译任务-->

       <target name="compile" depends="init">

              <javac srcdir="${src}" destdir="${build}">

              <classpath refid="classpath.run" />

              </javac>

       </target>

      

       <!--配置打包任务-->

       <target name="dist" depends="compile">

              <mkdir dir="${dist}/lib"/>

              <jar jarfile="${dist}/lib/test-${DSTAMP}.jar" basedir="${build}"/>

       </target>

      

       <!--配置运行任务-->

       <target name="run" depends="compile, dist">

         <java classname="com.test.TestCalculator">

             <classpath>

                     <path refid="classpath.run"/>

              </classpath>

         </java>

       </target>

      

       <!--配置JUnit测试,打印测试结果-->

       <target name="test" depends="compile, dist">

              <mkdir dir="${report.xml}"/>

              <mkdir dir="${report.html}"/>

              <junit printsummary="yes" haltonfailure="no">

                     <classpath refid="classpath.run"/>

                     <formatter type="xml"/>

                     <batchtest fork="yes" todir="${report.xml}">

                            <fileset dir="${src}" includes="**/Test*.java"/>

                     </batchtest>

              </junit>

              <junitreport todir="${report.html}">

                     <fileset dir="${report.xml}">

                            <include name="*.xml"/>

                     </fileset>

                     <report format="frames" todir="${report.html}"/>

              </junitreport>

       </target>

 

</project>

 
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
假设我们有一个类 `Calculator`,其中有两个方法 `add` 和 `subtract`,我们可以使用 AntJUnit 来编写针对这些方法的单元测试。 首先,我们需要创建一个名为 `CalculatorTest.java` 的测试类,并在其中编写测试方法。这个类和测试方法应该与被测试的类在同一个包中。下面是一个例子: ```java import org.junit.Test; import static org.junit.Assert.*; public class CalculatorTest { @Test public void testAdd() { Calculator calculator = new Calculator(); int result = calculator.add(3, 4); assertEquals(7, result); } @Test public void testSubtract() { Calculator calculator = new Calculator(); int result = calculator.subtract(7, 3); assertEquals(4, result); } } ``` 在这个例子中,我们使用了 JUnit 提供的 `@Test` 注解来标记测试方法。我们还使用了 `assertEquals` 方法来断言测试结果是否符合预期。 接下来,我们需要创建一个名为 `build.xml` 的 Ant 构建文件,并在其中添加一个 `junit` 任务来运行测试。下面是一个例子: ```xml <project name="Calculator" default="test"> <target name="compile"> <mkdir dir="build/classes"/> <javac srcdir="src" destdir="build/classes"/> </target> <target name="test" depends="compile"> <mkdir dir="build/test"/> <junit printsummary="yes" haltonfailure="yes"> <classpath> <pathelement location="build/classes"/> <pathelement location="lib/junit.jar"/> </classpath> <batchtest fork="yes" todir="build/test"> <fileset dir="src"> <include name="**/*Test.java"/> </fileset> </batchtest> </junit> </target> </project> ``` 在这个例子中,我们使用了 `junit` 任务来运行测试。我们还指定了 JUnit 库的位置,并将测试结果输出到了一个名为 `build/test` 的目录中。 最后,我们可以在命令行中运行 Ant 构建文件来执行测试: ``` $ ant test ``` 这将编译代码并运行测试,输出测试结果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值