测试技术手册:自动化EvoSuite 生成JUnit的测试用例

发表于:2019-3-28 11:44

字体: | 上一篇 | 下一篇 | 我要投稿

 作者:测者陈磊    来源:掘金

  EvoSuite简介
  EvoSuite是由Sheffield等大学联合开发的一种开源工具,用于自动生成测试用例集,生成的测试用例均符合Junit的标准,可直接在Junit中运行。得到了Google和Yourkit的支持。
  intelliJ IDEA插件
  打开IDE,进入setting(mac版本是Preferences),选择plugins,点击Browse repositories,搜索EvoSuite Plugin,然后选择Install plugin。
  Maven 插件引入
  当前支持Maven3.1以上版本。 Maven工程可以通过引入EvoSuite的Maven插件来生成新的测试用例。使用Maven插件有如下好处:
  1、可以和Jenkins结合,方便快速的运行EvoSuite
  2、测试用例生成在pom.xml文件约定好的工程目录下
  3、通过Maven的依赖引入EvoSuite,无需单独下载独立的jar文件。
  插件的引入如下:
   <pluginManagement><plugins>   <plugin>      <groupId>org.evosuite.plugins</groupId>      <artifactId>evosuite-maven-plugin</artifactId>      <version>${evosuiteVersion}</version>      <executions><execution>         <goals> <goal> prepare </goal> </goals>         <phase> process-test-classes </phase>      </execution></executions>  </plugin></plugins></pluginManagement>
  引入依赖:
   <dependency>  <groupId>org.evosuite</groupId>  <artifactId>evosuite-standalone-runtime</artifactId>  <version>${evosuiteVersion}</version>  <scope>test</scope></dependency>
  设定版本的变量(最新版可以在http://www.evosuite.org/downloads/查询):
 <properties>   <evosuiteVersion>1.0.6</evosuiteVersion></properties>
  由于EvoSuite是生成的JUnit的文件,因此需要引入Junit的依赖。
 <dependency>  <groupId>junit</groupId>  <artifactId>junit</artifactId>  <version>4.12</version>  <scope>test</scope></dependency>
  EvoSuite的使用
  EvoSuite的插件将会对对应的子模块的所有的类进行测试用例生成分析,再分析前需要保证对应代码是build过的。通过插件选取或者mvn compile evosuite:generate 开始分析。
  默认情况下会在模块目录下生成.evosuite目录,目录里面是测试用例,如果想要修改那么可以通过如下插件进行配置
   <plugin>    <groupId>org.codehaus.mojo</groupId>    <artifactId>build-helper-maven-plugin</artifactId>    <version>1.8</version>   <executions>     <execution>       <id>add-test-source</id>       <phase>generate-test-sources</phase>       <goals>         <goal>add-test-source</goal>       </goals>       <configuration>          <sources>            <source>${customFolder}</source>          </sources>       </configuration>    </execution>  </executions></plugin>
  特别提醒:如果上面的变量${customFolder}是.evosuite/evosuite-tests,那么不需要再次执行evosuite:export

     上文内容不用于商业目的,如涉及知识产权问题,请权利人联系博为峰小编(021-64471599-8017),我们将立即处理。
《2023软件测试行业现状调查报告》独家发布~

关注51Testing

联系我们

快捷面板 站点地图 联系我们 广告服务 关于我们 站长统计 发展历程

法律顾问:上海兰迪律师事务所 项棋律师
版权所有 上海博为峰软件技术股份有限公司 Copyright©51testing.com 2003-2024
投诉及意见反馈:webmaster@51testing.com; 业务联系:service@51testing.com 021-64471599-8017

沪ICP备05003035号

沪公网安备 31010102002173号