首页 > Java > java教程 > 正文

如何在Spring Boot 3.x中集成和使用嵌入式MongoDB进行测试

聖光之護
发布: 2025-11-25 18:51:01
原创
630人浏览过

如何在Spring Boot 3.x中集成和使用嵌入式MongoDB进行测试

本文详细介绍了在spring boot 3.x项目中集成和使用嵌入式mongodb进行测试的关键步骤。主要聚焦于解决从spring boot 2.x升级时遇到的兼容性问题,通过更新flapdoodle嵌入式mongodb依赖的artifactid和调整application.properties中mongodb版本配置的命名空间,确保开发人员能够顺利地在spring boot 3.x环境中进行数据层测试。

在Spring Boot 3.x中配置嵌入式MongoDB进行测试

随着Spring Boot 3.x的发布,其底层依赖和架构进行了重大升级,这导致一些在Spring Boot 2.x中正常工作的配置可能不再兼容。对于使用Flapdoodle嵌入式MongoDB进行测试的开发者而言,从Spring Boot 2.x迁移到3.x时,会发现原有的配置可能导致连接失败,出现DataAccessResourceFailureException,提示“Connection refused”。这通常是因为嵌入式MongoDB的集成方式发生了变化。本教程将详细指导您如何适配这些变化,使嵌入式MongoDB在Spring Boot 3.x项目中正常工作。

1. 理解兼容性问题

Spring Boot 3.x与Flapdoodle嵌入式MongoDB的早期版本存在兼容性问题。Flapdoodle项目为了更好地支持Spring Boot 3.x,发布了专门的集成模块。这意味着您需要更新项目的Maven或Gradle依赖,以引入针对Spring Boot 3.x优化的新模块。此外,配置嵌入式MongoDB版本的方式也从Spring Boot的命名空间迁移到了Flapdoodle自身的命名空间。

2. 更新Maven依赖

首先,您需要修改项目的pom.xml文件,将原有的Flapdoodle嵌入式MongoDB依赖更新为针对Spring Boot 3.x的版本。

旧依赖(适用于Spring Boot 2.x):

<dependency>
    <groupId>de.flapdoodle.embed</groupId>
    <artifactId>de.flapdoodle.embed.mongo</artifactId>
    <version>3.5.3</version>
    <scope>test</scope>
</dependency>
登录后复制

新依赖(适用于Spring Boot 3.x):

请注意,artifactId已更改为de.flapdoodle.embed.mongo.spring30x,并且版本号也应更新到最新。您可以在Maven中央仓库查找de.flapdoodle.embed.mongo.spring30x的最新版本。

<dependency>
    <groupId>de.flapdoodle.embed</groupId>
    <artifactId>de.flapdoodle.embed.mongo.spring30x</artifactId>
    <version>4.5.2</version> <!-- 请检查并使用最新稳定版本 -->
    <scope>test</scope>
</dependency>
登录后复制

完整pom.xml示例(仅展示相关部分):

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>3.0.0</version> <!-- 确保这里是Spring Boot 3.x版本 -->
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.example</groupId>
    <artifactId>your-project</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>your-project</name>
    <description>Demo project for Spring Boot</description>

    <properties>
        <java.version>17</java.version>
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-mongodb</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>

        <!-- Spring Boot 3.x 兼容的嵌入式MongoDB依赖 -->
        <dependency>
            <groupId>de.flapdoodle.embed</groupId>
            <artifactId>de.flapdoodle.embed.mongo.spring30x</artifactId>
            <version>4.5.2</version> <!-- 请替换为最新稳定版本 -->
            <scope>test</scope>
        </dependency>
        <!-- 其他依赖... -->
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
                <configuration>
                    <excludes>
                        <exclude>
                            <groupId>org.projectlombok</groupId>
                            <artifactId>lombok</artifactId>
                        </exclude>
                    </excludes>
                </configuration>
            </plugin>
        </plugins>
    </build>

</project>
登录后复制

3. 调整MongoDB版本配置

除了依赖的更改,您还需要更新application.properties或application.yml文件中配置嵌入式MongoDB版本的方式。在Spring Boot 3.x中,此配置已从Spring的命名空间迁移到Flapdoodle自己的命名空间。

旧配置(适用于Spring Boot 2.x):

Clipfly
Clipfly

一站式AI视频生成和编辑平台,提供多种AI视频处理、AI图像处理工具。

Clipfly 129
查看详情 Clipfly
spring.data.mongodb.database=test
spring.data.mongodb.port=27017
spring.mongodb.embedded.version=4.0.2
登录后复制

新配置(适用于Spring Boot 3.x):

将spring.mongodb.embedded.version更改为de.flapdoodle.mongodb.embedded.version。

spring.data.mongodb.database=test
spring.data.mongodb.port=27017
de.flapdoodle.mongodb.embedded.version=4.0.2
登录后复制

注意事项:

  • spring.data.mongodb.database和spring.data.mongodb.port通常不需要更改,它们是Spring Data MongoDB的通用配置。
  • de.flapdoodle.mongodb.embedded.version指定了您希望嵌入式MongoDB使用的MongoDB服务器版本。请确保此版本是Flapdoodle支持的有效版本。

4. 编写或验证测试类

完成上述依赖和配置的更改后,您的Spring Boot 3.x项目应该能够成功启动并连接到嵌入式MongoDB实例。您可以使用@DataMongoTest注解来编写数据层测试。

示例测试类:

import com.mongodb.BasicDBObjectBuilder;
import com.mongodb.DBObject;
import org.junit.jupiter.api.DisplayName;
import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.extension.ExtendWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.autoconfigure.data.mongo.DataMongoTest;
import org.springframework.data.mongodb.core.MongoTemplate;
import org.springframework.test.context.junit.jupiter.SpringExtension;

import static org.assertj.core.api.Assertions.assertThat;

@DataMongoTest
@ExtendWith(SpringExtension.class)
public class MongoDbSpringIntegrationTest {

  @DisplayName("given object to save"
      + " when save object using MongoDB template"
      + " then object is saved")
  @Test
  public void test(@Autowired MongoTemplate mongoTemplate) {
    // given
    DBObject objectToSave = BasicDBObjectBuilder.start()
        .add("key", "value")
        .get();

    // when
    mongoTemplate.save(objectToSave, "collection");

    // then
    assertThat(mongoTemplate.findAll(DBObject.class, "collection")).extracting("key")
        .containsOnly("value");
  }
}
登录后复制

这个测试类利用@DataMongoTest注解,它会自动配置一个嵌入式MongoDB实例(如果存在兼容的依赖和配置),并提供一个MongoTemplate bean供测试使用。通过注入MongoTemplate,您可以像操作真实MongoDB一样进行数据操作和断言。

总结

在Spring Boot 3.x项目中集成嵌入式MongoDB进行测试,关键在于更新Flapdoodle的专用Spring Boot 3.x兼容依赖,并调整application.properties中嵌入式MongoDB版本配置的命名空间。通过遵循本教程的步骤,您可以顺利地从Spring Boot 2.x迁移,并在新的Spring Boot 3.x环境中继续享受嵌入式MongoDB带来的便利,从而提高数据层测试的效率和可靠性。务必定期检查Flapdoodle嵌入式MongoDB项目的官方文档或Maven中央仓库,以获取最新的依赖版本和最佳实践。

以上就是如何在Spring Boot 3.x中集成和使用嵌入式MongoDB进行测试的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号