欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Springboot Mybatis-Plus數(shù)據(jù)庫單元測試實戰(zhàn)(三種方式)

 更新時間:2020年12月23日 10:49:40   作者:CuteXiaoKe  
這篇文章主要介紹了Springboot Mybatis-Plus數(shù)據(jù)庫單元測試實戰(zhàn)(三種方式),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

  單元測試長久以來是熱門話題,本文不會討論需不需要寫單測,可以看看參考資料1,我個人認為寫好單測應(yīng)該是每個優(yōu)秀開發(fā)者必備的技能,關(guān)于寫單測的好處在這里我就不展開討論了,快速進入本文著重討論的話題,如何寫好數(shù)據(jù)庫單測。

  為什么要寫數(shù)據(jù)庫單測? 相信大家是不是有這樣類似的經(jīng)歷,在寫完復(fù)雜的sql語句后,自信滿滿的提測,發(fā)現(xiàn)很大一部分Bug都是因為sql語句出現(xiàn)問題了,要么少寫逗號,要么漏了字段,悔不當初哇,為啥寫完不多測測呢!

  沒關(guān)系!這就教你如何寫數(shù)據(jù)庫單測,讓你輕松告別數(shù)據(jù)庫相關(guān)bug。

1. 數(shù)據(jù)庫樣例和環(huán)境

  我們以用戶表為例開啟本次教程:

用戶表

圖1.1 用戶表ER圖

  引入mybatis-plus插件后,mapper類如下:

@Mapper
public interface UserMapper extends BaseMapper<UserDO> {
}

  整體環(huán)境:

  • spring boot: 1.5.18.RELEASE
  • mybatis: 3.5.1
  • mybatis plus:3.4.0(此時最新版本,我們會用到最新版本的特性)

  在這里我們直接測試的是mybatis plus提供的一些CRUD,當然這些CRUD一般都不會錯,實際項目中我們只需對自定義的SQL進行單元測試即可。

2. 方式一:啟動整個環(huán)境

  這種方式應(yīng)該是日常環(huán)境使用最多的,利用SpringBoot自1.4.0版本開始引入的@SpringBootTest注解可以啟動我們單元測試所需要的所有環(huán)境,當然,如果你項目中運用了其他分布式服務(wù),他同樣也會啟動這些服務(wù)。單測代碼如下:

@RunWith(SpringRunner.class)
@SpringBootTest
public class UserMapperTest {

  @Autowired
  private UserMapper userMapper;

  @Test
  public void testCurd() {
    UserDO userDO = new UserDO();
    userDO.setId(7777L);
    userDO.setGmtModified(new Date());
    userDO.setGmtCreate(new Date());
    userDO.setRealName("ke");
    userDO.setUserName("ni");
    userMapper.insert(userDO);

    UserDO select = userMapper.selectById(1);
    System.out.println(select);
  }
}

@SpringBootTest注解可以設(shè)置需要啟動加載的類,按需加載

3. 方式二:只啟動數(shù)據(jù)庫環(huán)境+遠程數(shù)據(jù)庫

  在參考資料2中,最新的mybatis-plus發(fā)布版本(3.4.0)中引入了test starter,如圖:

Mybatis-plus3.4.0新特性

圖3.1 Mybatis-plus3.4.0引入test模塊

  模塊引入了新的注解@MybatisPlusTest,這個注解可以幫助我們只啟動特定特定的模塊,直接上單測代碼:

@RunWith(SpringRunner.class)
@MybatisPlusTest
@AutoConfigureTestDatabase(replace = AutoConfigureTestDatabase.Replace.NONE)
public class UserMapperTest {

  @Autowired
  private UserMapper userMapper;


  @Test
  public void testCurd() {
    UserDO userDO = new UserDO();
    userDO.setId(7777L);
    userDO.setGmtModified(new Date());
    userDO.setGmtCreate(new Date());
    userDO.setRealName("ke");
    userDO.setUserName("ni");
    userMapper.insert(userDO);

    UserDO select = userMapper.selectById(1);
    System.out.println(select);
  }
}

  是不是很輕松?不過我們要注意如下幾點關(guān)鍵點:

  • @AutoConfigureTestDatabase(replace = AutoConfigureTestDatabase.Replace.NONE)的作用是使用自定義的數(shù)據(jù)源,而非使用自動配置的嵌入式內(nèi)存數(shù)據(jù)源
  • 如果你在項目正在使用類似于druid的連接池,在test模塊的時候需要在application配置文件里面直接使用jdbc數(shù)據(jù)源即可,因為@MybatisPlusTest注解不會啟動連接池框架,典型的配置文件application.yml如下:
spring:
 datasource:
  url: jdbc:mysql://xxx.xxx.1.110:3306/test?allowMultiQueries=true&useUnicode=true&characterEncoding=UTF-8
  username: root
  password: 123456

4. 方式三:只啟動數(shù)據(jù)庫環(huán)境+本地數(shù)據(jù)庫

  在方式二的基礎(chǔ)上,進行如下步驟:

  • 我們?nèi)サ?code>@AutoConfigureTestDatabas注解,直接啟動測試嵌入式數(shù)據(jù)庫即可,在這里我們選用H2內(nèi)存數(shù)據(jù)庫,首先在pom中引入H2 database maven依賴;
  • 然后后在test環(huán)境下引入sechema.sql文件,這個文件是用來初始化數(shù)據(jù)庫的,核心是創(chuàng)建表格語句;
  • 最后去掉這個頁面以后寫法和方式二一樣,在這里就不給出

注意: sechema.sql文件要符合嵌入式數(shù)據(jù)庫的語法,在本例中為h2數(shù)據(jù)庫,如果你正在使用mysql數(shù)據(jù)庫,則需要把mysql的數(shù)據(jù)庫語法轉(zhuǎn)換為h2的數(shù)據(jù)庫語法。

5. @MybatisPlusTest注解原理

  如果你之前使用過MyBatis-Spring-Boot-Starter-Test中的@MybatisTest(參考資料3)的話,你會發(fā)現(xiàn)@MybatisPlusTest注解原理與之類似,都是限制spring boot的自動配置(參考資料4),只需要加載特定的配置即可。我們來看一下注解源碼:

@Target({ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Inherited
@BootstrapWith(MybatisPlusTestContextBootstrapper.class)
@ExtendWith({SpringExtension.class})
@OverrideAutoConfiguration(
  enabled = false
)
@TypeExcludeFilters({MybatisPlusTypeExcludeFilter.class})
@Transactional
@AutoConfigureCache
@AutoConfigureMybatisPlus
@AutoConfigureTestDatabase
@ImportAutoConfiguration
public @interface MybatisPlusTest {
  String[] properties() default {};

  boolean useDefaultFilters() default true;

  Filter[] includeFilters() default {};

  Filter[] excludeFilters() default {};

  @AliasFor(
    annotation = ImportAutoConfiguration.class,
    attribute = "exclude"
  )
  Class<?>[] excludeAutoConfiguration() default {};
}

@OverrideAutoConfiguration(enabled = false)是關(guān)鍵,它關(guān)閉了自動配置,而一般在spring boot項目中enable是開啟的;

@AutoConfigureMybatisPlus注解是自定義注解,這個注解定義了加載所有所需的加載類,在spring.factories里面聲明了要自動配置的類:

# AutoConfigureMybatis auto-configuration imports
com.baomidou.mybatisplus.test.autoconfigure.AutoConfigureMybatisPlus=\
org.springframework.boot.autoconfigure.flyway.FlywayAutoConfiguration,\
org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration,\
org.springframework.boot.autoconfigure.jdbc.DataSourceTransactionManagerAutoConfiguration,\
org.springframework.boot.autoconfigure.jdbc.JdbcTemplateAutoConfiguration,\
org.springframework.boot.autoconfigure.liquibase.LiquibaseAutoConfiguration,\
org.springframework.boot.autoconfigure.transaction.TransactionAutoConfiguration,\
com.baomidou.mybatisplus.autoconfigure.MybatisPlusLanguageDriverAutoConfiguration,\
com.baomidou.mybatisplus.autoconfigure.MybatisPlusAutoConfiguration

@AutoConfigureTestDatabase注解表明使用的是內(nèi)存數(shù)據(jù)庫而不是真實數(shù)據(jù)庫

  有了這些限制和規(guī)定以后,mybatis-plus在測試環(huán)境內(nèi)就可以自動加載所需要的的配置了,這樣就去除了非必要資源的加載。

6. 總結(jié)

三種數(shù)據(jù)庫單測總結(jié)

圖6.1 三種數(shù)據(jù)庫單測總結(jié)

  如果你正在使用mysql數(shù)據(jù)庫,我推薦使用方式二。如果你能解決mysq語法轉(zhuǎn)h2的問題,推薦使用方式三,這樣在離線的情況也可以進行單測,不需要連接遠程數(shù)據(jù)庫。

PS:如果你有好的工具來完成mysql轉(zhuǎn)換h2的話可以在評論區(qū)里面推薦一下,我這邊找了好久,包括自定義寫轉(zhuǎn)換、一些專業(yè)工具等,感覺對navicat導(dǎo)出的語句作轉(zhuǎn)換不是很好好用。

7.參考資料

[1] 你真的需要單元測試嗎?
[2] Mybatis-Plus發(fā)布版本
[3] MyBatis-Spring-Boot-Starter-Test
[4] SpringBoot四大神器之a(chǎn)uto-configuration

到此這篇關(guān)于Springboot Mybatis-Plus數(shù)據(jù)庫單元測試實戰(zhàn)(三種方式)的文章就介紹到這了,更多相關(guān)Springboot Mybatis-Plus單元測試內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 完美解決Java中的線程安全問題

    完美解決Java中的線程安全問題

    下面小編就為大家?guī)硪黄昝澜鉀QJava中的線程安全問題。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-08-08
  • SpringBoot實現(xiàn)國密SM4加密解密的使用示例

    SpringBoot實現(xiàn)國密SM4加密解密的使用示例

    在商用密碼體系中,SM4主要用于數(shù)據(jù)加密,本文就來介紹一下SpringBoot實現(xiàn)國密SM4加密解密的使用示例,具有一定的參考價值,感興趣的可以了解一下
    2023-10-10
  • 根據(jù)ID填充文本框的實例代碼

    根據(jù)ID填充文本框的實例代碼

    這篇文章介紹了根據(jù)ID填充文本框的小例子,有需要的朋友可以參考一下
    2013-07-07
  • springboot2.0?@Slf4j?log?彩色日志配置輸出到文件

    springboot2.0?@Slf4j?log?彩色日志配置輸出到文件

    這篇文章主要介紹了springboot2.0 @Slf4j log日志配置輸出到文件(彩色日志),解決方式是使用了springboot原生自帶的一個log框架,結(jié)合實例代碼給大家講解的非常詳細,需要的朋友可以參考下
    2023-08-08
  • javaSE中數(shù)組的概念與使用詳細教程

    javaSE中數(shù)組的概念與使用詳細教程

    這篇文章主要給大家介紹了關(guān)于javaSE中數(shù)組的概念與使用的相關(guān)資料,數(shù)組在內(nèi)存中是一段連續(xù)的空間,空間的編號都是從0開始的,依次遞增,該編號稱為數(shù)組的下標,需要的朋友可以參考下
    2023-08-08
  • java編寫冒泡排序的完整示例

    java編寫冒泡排序的完整示例

    這篇文章主要給大家介紹了關(guān)于java編寫冒泡排序的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-12-12
  • 一篇文章帶你搞定 springsecurity基于數(shù)據(jù)庫的認證(springsecurity整合mybatis)

    一篇文章帶你搞定 springsecurity基于數(shù)據(jù)庫的認證(springsecurity整合mybatis)

    這篇文章主要介紹了一篇文章帶你搞定 springsecurity基于數(shù)據(jù)庫的認證(springsecurity整合mybatis),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-10-10
  • 詳解java中命令行模式的實現(xiàn)

    詳解java中命令行模式的實現(xiàn)

    命令模式是一種行為設(shè)計模式,它允許您將請求封裝為對象,以便您可以將其參數(shù)化、隊列化、記錄和撤銷,本文主要為大家介紹一下java實現(xiàn)命令模式的示例代碼,需要的可以參考下
    2023-09-09
  • 為何找不到Java 7中的警告

    為何找不到Java 7中的警告

    在本篇文章和里小編給大家整理的是關(guān)于Java 7中的警告的相關(guān)知識點內(nèi)容,有需要的朋友們可以參考下。
    2019-11-11
  • js實現(xiàn)拖拽拼圖游戲

    js實現(xiàn)拖拽拼圖游戲

    這篇文章主要為大家詳細介紹了js實現(xiàn)拖拽拼圖游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-09-09

最新評論