maven test 执行测试用例,操作的是h2数据库,第二次执行提示表已存在

这个问题通常发生在使用H2内存数据库进行单元测试时。每次运行测试时,H2数据库都应该重新创建,但看起来在你的情况下,数据库状态在测试之间被保留了。让我们来解决这个问题:

  1. 检查数据库配置

首先,确保你的测试配置使用的是内存数据库。在你的测试资源目录下的 application.propertiesapplication.yml 文件中,数据库URL应该类似于:

spring.datasource.url=jdbc:h2:mem:testdb;DB_CLOSE_DELAY=-1;DB_CLOSE_ON_EXIT=FALSE

DB_CLOSE_DELAY=-1 确保数据库在最后一个连接关闭后不会立即关闭。

  1. 使用 @Transactional 注解

在你的测试类上添加 @Transactional 注解。这将使每个测试方法在事务中运行,并在测试结束时回滚事务:

@RunWith(SpringRunner.class)
@SpringBootTest
@Transactional
public class YourTestClass {
    // ...
}
  1. 手动清理数据库

在每个测试方法之前或之后清理数据库。你可以使用 @Before@After 注解:

@Before
public void setUp() {
    // 执行清理脚本
    jdbcTemplate.execute("DROP ALL OBJECTS");
}
  1. 使用 @DirtiesContext

如果你希望在每次测试运行后重新创建应用上下文,可以使用 @DirtiesContext 注解:

  1. 使用唯一的数据库名称

为每次测试运行使用唯一的数据库名称:

spring.datasource.url=jdbc:h2:mem:testdb_${random.uuid};DB_CLOSE_DELAY=-1;DB_CLOSE_ON_EXIT=FALSE

这将为每次测试运行创建一个新的内存数据库。

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是一个简单的Java语言编写接口自动化测试脚本示例: 假设我们要测试一个获取用户信息的接口,接口地址为:https://example.com/api/userinfo,请求方式为GET,返回值格式为JSON,其中需要传入参数token。 1. 确认测试框架和工具:我们选择使用TestNG作为测试框架,使用RestAssured作为接口测试工具。 2. 编写测试用例:我们编写一个简单的测试用例,验证接口返回的JSON中是否包含用户的姓名。测试用例可以使用Excel或JSON等格式进行管理,这里我们使用TestNG的@DataProvider注解来传递测试数据。 ```java public class ApiTest { @Test(dataProvider = "getUserInfoData") public void testGetUserInfo(String token) { Response response = given().param("token", token).when().get("https://example.com/api/userinfo"); String responseBody = response.getBody().asString(); assertTrue(responseBody.contains("name"), "Response body does not contain user name."); } @DataProvider(name = "getUserInfoData") public Object[][] getUserInfoData() { return new Object[][]{{"test_token_1"}, {"test_token_2"}}; } } ``` 3. 执行测试用例:我们可以使用Maven命令行或集成开发环境(IDE)等方式执行测试脚本。这里我们使用Maven命令行执行测试脚本。 ```bash mvn test ``` 4. 分析测试结果:测试执行完成后,我们可以在控制台中查看测试结果,也可以使用测试报告工具生成测试报告。 以上是一个简单的Java语言编写接口自动化测试脚本示例,具体实现方式可以根据实际情况做出调整。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值