如何使用springboot和liquibase在内存数据库中为IntegrationTest设置

时间:2019-02-24 08:19:47

标签: java spring spring-boot liquibase

使用liquibase和springboot,创建​​了数据库更改日志,并能够使用maven-liquibase-plugin(mvn liquibase:update)成功运行它。我正在编写集成测试,其中需要以编程方式创建liquibase更改。

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(classes = DummyApplication.class)
@ActiveProfiles("test")
public class TestDummyService
{
    @Autowired
    private SpringLiquibase springLiquibase;
    ...

    @Test
    public void testDummyRequest()
    {
    try {
        Connection connection = springLiquibase.getDataSource().getConnection();
        Database database = DatabaseFactory.getInstance().findCorrectDatabaseImplementation(new JdbcConnection(connection));
        Liquibase liquibase = new liquibase.Liquibase("liquibase/changelog/db-changelog-master.xml", new ClassLoaderResourceAccessor(), database);
        liquibase.update(new Contexts(springLiquibase.getContexts()), new LabelExpression(springLiquibase.getLabels()));
    } catch (LiquibaseException | SQLException e) {
        e.printStackTrace();
    }
}

在进行上述测试时获得以下例外

  
    

java.lang.IllegalStateException:无法加载ApplicationContext         在org.springframework.test.context.cache.DefaultCacheAwareContextLoaderDelegate.loadContext(DefaultCacheAwareContextLoaderDelegate.java:125)

         

原因:org.springframework.beans.factory.BeanCreationException:         创建在类路径资源[org / springframework / boot / autoconfigure / liquibase / LiquibaseAutoConfiguration $ LiquibaseConfiguration.class]中定义的名称为'liquibase'的bean时出错:         通过工厂方法实例化Bean失败;嵌套的异常是org.springframework.beans.BeanInstantiationException:         无法实例化[liquibase.integration.spring.SpringLiquibase]:         工厂方法“ liquibase”抛出异常;嵌套的异常是java.lang.NoSuchMethodError:liquibase.integration.spring.SpringLiquibase.setLiquibaseSchema(Ljava / lang / String;)V

         

由以下原因引起:java.lang.NoSuchMethodError:liquibase.integration.spring.SpringLiquibase.setLiquibaseSchema(Ljava / lang / String;)

  

下面是 application-test.property 文件。

  #NOTE : spring.liquibase is the working one .

  liquibase.changeLog=classpath:liquibase/changelog/db-changelog-master.xml
  liquibase.enabled=true
  liquibase.url=jdbc:h2:mem:cpass;DB_CLOSE_DELAY=-1
  liquibase.user=root
  liquibase.password=
  spring.liquibase.dropFirst=true
  hibernate.dialect=org.hibernate.dialect.MySQL5Dialect
  jdbc.driverClassName=org.h2.Driver
  spring.liquibase.enabled=true
  spring.liquibase.change-log=classpath:liquibase/changelog/db-changelog-master.xml
  #spring.liquibase.driver=com.mysql.jdbc.Driver
  spring.liquibase.url=jdbc:mysql://localhost:3306/dummy
  spring.liquibase.user=root
  spring.liquibase.password=

** pom.xml:**

    <dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-data-jpa</artifactId>
        <version>2.1.3.RELEASE</version>
    </dependency>

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-data-rest</artifactId>
        <version>2.1.3.RELEASE</version>
    </dependency>

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
        <version>2.1.3.RELEASE</version>
        <exclusions>
            <exclusion>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-logging</artifactId>
            </exclusion>
        </exclusions>
    </dependency>

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-tomcat</artifactId>
        <version>2.1.3.RELEASE</version>
    </dependency>

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <version>2.1.3.RELEASE</version>
        <scope>test</scope>
    </dependency>

    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <version>8.0.15</version>
    </dependency>

    <dependency>
        <groupId>com.h2database</groupId>
        <artifactId>h2</artifactId>
        <scope>test</scope>
    </dependency>

    <dependency>
        <groupId>org.liquibase</groupId>
        <artifactId>liquibase-core</artifactId>
        <version>3.4.2</version>
    </dependency>
</dependencies>

<build>
    <plugins>
        <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
            <version>2.1.3.RELEASE</version>
        </plugin>

        <plugin>
            <groupId>org.liquibase</groupId>
            <artifactId>liquibase-maven-plugin</artifactId>
            <version>3.4.2</version>
            <configuration>
                <propertyFile>liquibase/liquibase.properties</propertyFile>
                <changeLogFile>liquibase/changelog/db-changelog-master.xml</changeLogFile>
            </configuration>
        </plugin>
    </plugins>
</build>

测试类中是否缺少任何Im或任何示例项目URL也很有帮助。我是springboot和liquibase的新手。

1 个答案:

答案 0 :(得分:2)

Spring Boot 2.1.3依赖于Liquibase 3.6.3,但是您已经在pom.xml中指定了3.4.2。

话虽如此,Spring Boot的Liquibase自动配置将完成您在单元测试中编写的所有内容,因为您已经创建了激活自动配置的属性。您可以删除测试方法中的所有代码,而只需@Autowire将DataSource插入测试类。 Spring将为您应用Liquibase更改日志。

最后一件事:如果可以的话,最好在pom.xml中添加一个<parent>,这意味着您不需要指定每个依赖项的单独版本(包括Liquibase)。 Spring Boot具有很多依赖性,并且在升级时需要进行大量工作以使版本保持同步。这也可以防止您出现NoSuchMethodError。

相关问题