BeanCreationException для Flyway, настроенный для Postgres - PullRequest
0 голосов
/ 21 марта 2019

Когда я пытаюсь построить модуль хранилища, я получаю исключение BeanCreationException для конфигурации Flyway. Пробовал несколько способов, но не повезло. Может кто-нибудь помочь мне в этом?

Ошибка:

Ошибка запуска ApplicationContext. Для отображения отчета автоконфигурации перезапустите ваше приложение с включенной отладкой. 2019-03-21 06: 11: 15.404 ОШИБКА 13480 --- [main] o.s.boot.SpringApplication: сбой запуска приложения org.springframework.beans.factory.BeanCreationException: Ошибка при создании компонента с именем 'flyway', определенным в com.repository.TestConfig: создание экземпляра компонента с помощью метода фабрики завершилось неудачно; вложенным исключением является org.springframework.beans.BeanInstantiationException: не удалось создать экземпляр [org.flywaydb.core.Flyway]: фабричный метод 'flyway' вызвал исключение; вложенное исключение - org.springframework.beans.factory.BeanCreationException: ошибка создания бина с именем «dataSource»: сбой вызова метода init; Вложенное исключение - java.lang.IllegalStateException: не удалось заменить DataSource встроенной базой данных для тестов. Если вы хотите встроенную базу данных, пожалуйста, поместите поддерживаемую базу данных в путь к классам или настройте атрибут замены @ AutoconfigureTestDatabase.

TestConfig Класс:

@Configuration
@EnableJpaRepositories(basePackages = "com.repository")
@EntityScan(basePackages = {"com.insurance.*"})
@EnableTransactionManagement
@Slf4j
public class TestConfig {
@Bean
public DataSource dataSource() throws IOException {
    return embeddedPostgres().getPostgresDatabase();
}

@Bean
public EmbeddedPostgres embeddedPostgres() throws IOException {
    return EmbeddedPostgres.start();
}

@Bean
public HibernateExceptionTranslator hibernateExceptionTranslator() {
    return new HibernateExceptionTranslator();
}

@Bean
public PlatformTransactionManager transactionManager(EntityManagerFactory emf) {
    JpaTransactionManager transactionManager = new JpaTransactionManager();
    transactionManager.setEntityManagerFactory(emf);
    return transactionManager;
}

@Bean
public JdbcTemplate jdbcTemplate(DataSource dataSource) throws IOException {
    return new JdbcTemplate(dataSource);
}

@Bean
public Flyway flyway() throws IOException {
    Flyway flyway = new Flyway();
    flyway.setDataSource(dataSource());
    flyway.setLocations("db/migration");
    flyway.migrate();
    return flyway;
}
}

фрагмент pom.xml

    <dependency>
        <groupId>com.opentable.components</groupId>
        <artifactId>otj-pg-embedded</artifactId>
        <version>0.10.0</version>
        <scope>test</scope>
    </dependency>
    <dependency>
        <groupId>org.flywaydb</groupId>
        <artifactId>flyway-core</artifactId>
    </dependency>

Тестовый класс:

@RunWith(SpringRunner.class)
@DataJpaTest
@ContextConfiguration(classes = TestConfig.class)
public class InsuranceRepositoryTest {
---//Test methods 
}

1 Ответ

0 голосов
/ 22 марта 2019

Spring Boot пытается заменить обычную базу данных вашего приложения той, которая будет использоваться для тестирования.Однако вы уже сделали это в своей тестовой конфигурации, в которой используется встроенный Postgres.Вам нужно использовать @AutoConfigureTestDatabase, чтобы сказать Spring Boot не заменять вашу базу данных:

@AutoConfigureTestDatabase( replace = Replace.NONE
...