1. 程式人生 > >自動的自動化:EvoSuite 自動生成JUnit的測試用例

自動的自動化:EvoSuite 自動生成JUnit的測試用例

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檔案。

外掛的引入如下:

  1. <pluginManagement>

  2. <plugins>

  3.   <plugin>

  4.      <groupId>org.evosuite.plugins</groupId>

  5.      <artifactId>evosuite-maven-plugin</artifactId>

  6.      <version>${evosuiteVersion}</version>

  7.      <executions><execution>

  8.         <goals> <goal> prepare </goal> </goals>

  9.         <phase> process-test-classes </phase>

  10.      </execution></executions>

  11.  </plugin>

  12. </plugins>

  13. </pluginManagement>

引入依賴:

  1. <dependency>

  2.  <groupId>org.evosuite</groupId>

  3.  <artifactId>evosuite-standalone-runtime</artifactId>

  4.  <version>${evosuiteVersion}</version>

  5.  <scope>test</scope>

  6. </dependency>

設定版本的變數(最新版可以在http://www.evosuite.org/downloads/查詢):

  1. <properties>

  2.   <evosuiteVersion>1.0.6</evosuiteVersion>

  3. </properties>

由於EvoSuite是生成的JUnit的檔案,因此需要引入Junit的依賴。

  1. <dependency>

  2.  <groupId>junit</groupId>

  3.  <artifactId>junit</artifactId>

  4.  <version>4.12</version>

  5.  <scope>test</scope>

  6. </dependency>

EvoSuite的使用

EvoSuite的外掛將會對對應的子模組的所有的類進行測試用例生成分析,再分析前需要保證對應程式碼是build過的。通過外掛選取或者mvn compile evosuite:generate 開始分析。

預設情況下會在模組目錄下生成.evosuite目錄,目錄裡面是測試用例,如果想要修改那麼可以通過如下外掛進行配置

  1. <plugin>

  2.    <groupId>org.codehaus.mojo</groupId>

  3.    <artifactId>build-helper-maven-plugin</artifactId>

  4.    <version>1.8</version>

  5.   <executions>

  6.     <execution>

  7.       <id>add-test-source</id>

  8.       <phase>generate-test-sources</phase>

  9.       <goals>

  10.         <goal>add-test-source</goal>

  11.       </goals>

  12.       <configuration>

  13.          <sources>

  14.            <source>${customFolder}</source>

  15.          </sources>

  16.       </configuration>

  17.    </execution>

  18.  </executions>

  19. </plugin>

特別提醒:如果上面的變數${customFolder}是.evosuite/evosuite-tests,那麼不需要再次執行evosuite:export

詳情參見官方文件:http://www.evosuite.org/documentation/

關注測者,關注測試