Я пытаюсь протестировать приложение для отдыха с помощью весеннего теста.
У меня есть два объекта (User, UserInfo) (ассоциация «один к одному», которая предполагает, что и источник, и цель имеют одни и те же значения первичного ключа.)
Это мой тестовый сценарий. (в тестовом коде)
- Вставьте временного пользователя в базу данных с помощью 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("[email protected]");
userInfo.setUser(user);
user.setUserInfo(userInfo);
// persist
userRepository.save(user);
// request post
mockMvc.perform(
post("/user")
.param("email", "[email protected]")
.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