我正在尝试使用弹簧测试测试休息应用程序。
我有两个实体(用户,用户信息)(一对一关联,假设源和目标共享相同的主键值。)
这是我的测试场景。(在测试代码中)
- 使用 JPA 将临时用户插入数据库
- 请求控制器使用 MockMvc 执行。
- 断言与预期和实际。
- 回滚临时用户。
这个测试用例失败了。也许到另一个执行环境(线程)??
@Test
public void test() throws Exception {
// create temporary user for test.
User user = new User();
user.setType(Type.User);
UserInfo userInfo = new UserInfo();
userInfo.setEmail("temporary_user@test.com");
userInfo.setUser(user);
user.setUserInfo(userInfo);
// persist
userRepository.save(user);
// request post
mockMvc.perform(
post("/user")
.param("email", "temporary_user@test.com")
.contentType(MediaType.APPLICATION_JSON_UTF8_VALUE))
.andExpect(status().isOk())
.andExpect(jsonPath("$.email", userInfo.getEmail()));
}
是否有可能的测试场景?
关于其他解决方案或如何让我的解决方案发挥作用的任何帮助?
这是一个示例代码。
https://gist.github.com/okihouse/f5e2fe8fa4c17d6a6be9
解决了
我解决了这个异常。
异常点
我用了hikariCP。观看示例代码。
@Configuration @EnableAutoConfiguration @EnableTransactionManagement public class JdbcConfig implements TransactionManagementConfigurer { @Autowired private JdbcVO jdbcVO; @Bean public JdbcTemplate jdbcTemplate(){ return new JdbcTemplate(dataSource()); } @Bean public DataSource dataSource(){ final HikariDataSource dataSource = new HikariDataSource(); dataSource.setDriverClassName(jdbcVO.getDriver()); dataSource.setJdbcUrl(jdbcVO.getUrl()); dataSource.setUsername(jdbcVO.getUsername()); dataSource.setPassword(jdbcVO.getPassword()); return dataSource; } @Bean public PlatformTransactionManager transactionManager(){ return new DataSourceTransactionManager(dataSource()); } @Override public PlatformTransactionManager annotationDrivenTransactionManager() { return transactionManager(); }
}
当我使用手动数据源配置时发生错误。
所以,我在application.yml中更新数据源配置
spring:
jpa:
database: mysql
hibernate:
naming-strategy: org.hibernate.cfg.ImprovedNamingStrategy
#ddl-auto: create
properties:
hibernate.format_sql: true
show-sql: true
datasource:
type: com.zaxxer.hikari.HikariDataSource
driver-class-name: com.mysql.jdbc.Driver
url: jdbc:mysql://localhost:3306/test
username: test
password: test
最后,我分享了这段代码。 https://github.com/okihouse/spring-jpa-test