EvoSuite 自动生成代码接入指南

官方网站为:https://www.evosuite.org/

1、官网找到以下链接

2、maven 插件接入

引入org.evosuite.plugins插件

<!--evoSuite 插件-->
<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>

并且在属性中加入相应的变量:

<properties>
        <evosuiteVersion>1.0.6</evosuiteVersion>
</properties>

加入evosuite运行包

<dependency>
  <groupId>org.evosuite</groupId>
  <artifactId>evosuite-standalone-runtime</artifactId>
  <version>${evosuiteVersion}</version>
  <scope>test</scope>
</dependency>

使用EvoSuite的Java代理时,还需要配置surefire插件来运行EvoSuite测试的初始化监听器。当EvoSuite自动测试与手工编写的测试混合使用时。如下所示:

<plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-surefire-plugin</artifactId>
    <version>2.5</version>
    <configuration>
        <skipTests>true</skipTests>
        <properties>
            <property>
                <name>listener</name>
                <value>org.evosuite.runtime.InitializingListener</value>
            </property>
        </properties>
    </configuration>
</plugin>

如何使用EvoSuite Maven插件提供了以下目标:
1)“generate”->这是用来生成带有EvoSuite的测试用例的。将为所有子模块中的所有类生成测试。您需要确保代码已编译,例如“mvn compile”evosuite:generate”. 此目标为以下参数:“”memoryInMB“:EvoSuite允许分配的兆字节总量(默认值800)”cores“:EvoSuite可以使用的CPU内核总数(默认值1)*”timeInMinutesPerClass“:EvoSuite可以为每个类生成测试花费多少分钟(默认值2)

2)“info”->提供到目前为止生成的所有测试3)“导出”->默认情况下,EvoSuite在“.EvoSuite”文件夹中创建测试。通过使用“export”,生成的测试将被复制到另一个文件夹,该文件夹可以通过“targetFolder”选项设置(默认值为“src/test/java”)。注意:如果不将测试导出到带有“mvn”的“src/test/java”中evosuite:export,则像“mvn test”这样的命令将不会执行这些测试,因为它们的源代码不在构建路径上。您可以使用“build helper maven plugin”插件添加自定义源文件夹,例如:

<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>

运行使用:
1、如果等于,则不需要使用如果这样做,那么您将得到编译错误,因为每个测试将在类路径上出现两次)。注意:另一种方法是重写以指向customFolder等于“.evosuite/evosuitetests”,则不需要使用evosuite:export”.(如果这样做,那么您将得到编译错误,因为每个测试将在类路径上出现两次)。注意:另一种方法是重写“”以指向{customFolder}。
2、如果希望只在EvoSuite生成的测试上运行“mvn test”(例如,如果在Jenkins上有两个不同的配置/配置文件,一个只运行现有的手动测试,另一个只运行EvoSuite测试),这将非常有用。
3、“clean”->删除“.evosuite”文件夹中的所有数据,该文件夹用于存储迄今为止生成的所有最佳测试。
4、“prepare”->需要运行与现有测试混合的EvoSuite测试,例如“mvn”evosuite:prepare test”. 如前所述,最好只配置evosuite插件以始终运行它。

运行命令如下:

mvn -DmemoryInMB=2000 -Dcores=2 evosuite:generate evosuite:export  test

测试代码生成截图:


 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值