Можно ли протестировать JPA с помощью MockMvc?

Я пытаюсь протестировать приложение для отдыха с помощью весеннего теста.

У меня есть два объекта (User, UserInfo) (ассоциация «один к одному», которая предполагает, что и источник, и цель имеют одни и те же значения первичного ключа.)

Это мой тестовый сценарий. (в тестовом коде)

  1. Вставьте временного пользователя в базу данных с помощью JPA
  2. Контроллер запросов с использованием MockMvc.
  3. Утвердить с ожидаемым и фактическим.
  4. Откат временного пользователя.

Этот тестовый пример провален. возможно, в другую среду выполнения (поток) ??

@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


person OKIHOUSE    schedule 05.02.2016    source источник
comment
Да, такой тест возможен. что вы получаете ? исключение ? у вас нет утверждения в вашем тестовом примере   -  person Jérémie B    schedule 05.02.2016
comment
Я бы сказал, что не совсем, потому что, если вы используете автономный mockmvc, реального контекста Spring нет (нет источника данных и т. д.), а если вы используете другой (тот, что с контекстом), вы обычно не получаете доступ к репозиторию/ слой данных. Но можно использовать макеты с автономным mockmvc и использовать фиксированную БД (в памяти, предопределенные данные) с другим. См. также stackoverflow.com/questions/32223490/   -  person    schedule 05.02.2016
comment
Jérémie B прав, такой тест работает, просто сделайте его и не забудьте аннотацию @Transactional в своем тесте.   -  person Ralph    schedule 05.02.2016


Ответы (1)


Я бы создал базу данных в памяти, а не издевался, вы можете проверить все по-настоящему. Hibernate создаст для вас базу данных.

Пример конфига ниже

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:jdbc="http://www.springframework.org/schema/jdbc"
    xmlns:jpa="http://www.springframework.org/schema/data/jpa" xmlns:tx="http://www.springframework.org/schema/tx" xmlns:context="http://www.springframework.org/schema/context"
    xmlns:cache="http://www.springframework.org/schema/cache"
    xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
    http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd
    http://www.springframework.org/schema/jdbc http://www.springframework.org/schema/jdbc/spring-jdbc.xsd
    http://www.springframework.org/schema/data/jpa http://www.springframework.org/schema/data/jpa/spring-jpa.xsd
    http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd
    http://www.springframework.org/schema/cache http://www.springframework.org/schema/cache/spring-cache.xsd">

    <context:component-scan base-package="net.isban" />
    <tx:annotation-driven />
    <jpa:repositories base-package="net.isban" />

    <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
        <property name="driverClassName" value="org.h2.Driver" />
        <property name="url" value="jdbc:h2:mem:test;DB_CLOSE_DELAY=-1" />
        <property name="username" value="sa" />
        <property name="password" value="" />
    </bean>

    <bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
        <property name="dataSource" ref="dataSource" />
        <property name="packagesToScan" value="net.isban.example.entity" />
        <property name="jpaVendorAdapter">
            <bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter" />
        </property>
        <property name="jpaProperties">
            <props>
                <prop key="hibernate.hbm2ddl.auto">create</prop>
                <prop key="hibernate.dialect">org.hibernate.dialect.H2Dialect</prop>
            </props>
        </property>
    </bean>

    <bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager">
        <property name="entityManagerFactory" ref="entityManagerFactory" />
    </bean>

</beans>
person Essex Boy    schedule 05.02.2016