成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

關于單測技術選型,聊聊我的思考

開發 前端
其中 JUnit 不支持 Mock,因此基本不會只用 JUnit,而是結合其他有 Mock 功能的框架一起使用。從知名度及使用率來說,Mockito 和 Spock 使用較多,而 PowerMock、JMockit、TestableMock 使用較少。下面我們將主要對比 Mockito 和 Spock 兩種框架的差異。

對于單測來說,目前常用的單測框架有:

  • JUnit
  • Mockito
  • Spock
  • PowerMock
  • JMockit
  • TestableMock

其中 JUnit 不支持 Mock,因此基本不會只用 JUnit,而是結合其他有 Mock 功能的框架一起使用。從知名度及使用率來說,Mockito 和 Spock 使用較多,而 PowerMock、JMockit、TestableMock 使用較少。下面我們將主要對比 Mockito 和 Spock 兩種框架的差異。

Mockito

Mockito 是 Java 單元測試中的 Mock 框架,一般都是與 JUnit 一起使用。Mockito 功能強大,幾乎所有你能想到的功能都支持,并且由于發布時間較長,因此使用的人非常多。

  • 優點:功能強大、使用人數多、資料豐富。
  • 缺點:代碼不夠簡潔、沒有統一的單測結構、不支持靜態方法和私有方法 Mock。

更多信息詳見官網:https://site.mockito.org/

Spock

Spock 是一個企業級的測試規范框架,可用來測試 Java 和 Groovy 應用。Spock 最大的特色是其簡潔美觀的語言規范。Spock 兼容絕大多數 IDE、編譯工具和 CI 集成服務器。Spock 框架使用 Groovy 語言編寫,而 Groovy 語言則是 Java 語言的超集,絕大多數 Java 語言語法在 Groovy 中都支持。

  • 優點:單測結構統一、代碼簡潔、異常測試及參數測試支持更好。
  • 缺點:學習成本略高、不支持靜態方法和私有方法 Mock。

更多信息詳見官網:https://spockframework.org/

Mockito vs Spock

在 Spock vs JUnit 5 - the ultimate feature comparison 中詳細對比了 Mokito 與 Spock 的差異,他們在發展情況、學習曲線、工具支持等方面的比較如下圖所示。

圖片

從上圖可以看到,Mockito 框架在發展、學習曲線、工具支持、從 JUnit4 遷移幾方面比較有優勢。而 Spock 框架則在測試結構、異常測試、條件測試等方面比較有優勢。因此,選擇哪個測試框架完全基于實際情況。例如,如果你目前的情況是:

  1. Java 是唯一的語言。
  2. 想要更強的編譯時錯誤檢查。
  3. 更穩定、更主流的實現方式。

那么選擇 JUnit + Mockito 的方式是更好的選擇。但如果你目前的情況是:

  1. 希望單測跟簡單易讀
  2. 更簡潔的參數測試與異常測試

那么選擇 Spock 會是更好的選擇。

為啥選擇 Spock?

根據前面的分析,Mockito 的主要優勢在于比較穩定、主流,缺點在于不夠簡潔易讀。而 Spock 雖然使用人群沒有 Mockito 那么多,但國內也有一些大廠在使用 Spock,例如美團等(可參考:Spock 單元測試框架介紹以及在美團優選的實踐)。

我們重視寫單測,但是又不希望寫單測花費太多時間,畢竟業務才是第一位的。因此,我們希望單測代碼盡可能簡潔、可維護。 基于這個原因,我們選擇了 Spock 框架作為朝昔后端的單測框架解決方案。而 Spock 不支持 static 方法及 private 方法 Mock 的缺陷,則嘗試通過整合 PowerMock 或 TestableMock 來解決。

可維護性更強

在極客時間《程序員的測試課》中,有一節關于講了一個好的自動化測試長什么樣?在這里面,作者提到一個好的單測應該由 準備、執行、斷言、清理 4 個階段組成。

對于 Mockito 而言,它并沒有規定具體的代碼規范,因此只能依靠注釋來標注哪些代碼是準備階段的代碼,哪些是執行階段的代碼,哪些是斷言階段的代碼,如下代碼所示。

class SimpleCalculatorTest {
@Test
void shouldAddTwoNumbers() {
//given 準備
Calculator calculator = new Calculator();
//when 執行
int result = calculator.add(1, 2);
//then 斷言
assertEquals(3, result);
}
}

對于 Spock 而言,其通過 given-when-then 的結構,強制要求編寫者將不同階段的代碼放到不同的位置,從而增強了可讀性。同樣是用于測試計算器的加法函數的單測用例,使用 Spock 框架編寫的單測如下代碼所示。

class SimpleCalculatorSpec extends Specification {
def "should add two numbers"() {
given: "create a calculater instance"
Calculator calculator = new Calculator()
when: "get calculating result via the calculater"
int result = calculator.add(1, 2)
then: "assert the result is right"
result == 3
}
}

可以看到,通過 given-when-then 結構的劃分,我們可以更加快速地弄清楚單測的內容,從而提高單測的可讀性,使得單測更加容易維護。

代碼更加簡潔

對于 Mockito 與 Spock 而言,它們之間的一個很大的差別是:Spock 的代碼更加簡潔。這個特性可以讓我們編寫比 Mockito 更少的代碼,從而實現同樣的功能。例如在 Mockito 中,我們 Mock 某個接口實現時,通常需要寫一長串的 give(...).return(...)? 代碼。而在進行斷言的時候,也需要寫比較長的 then(xx).should(xx).checkxx() 代碼,如下圖所示。

@Test
public void should_not_call_remote_service_if_found_in_cache() {
//given
given(cacheMock.getCachedOperator(CACHED_MOBILE_NUMBER)).willReturn(Optional.of(PLUS));
//when
service.checkOperator(CACHED_MOBILE_NUMBER);
//then
then(webserviceMock).should(never()).checkOperator(CACHED_MOBILE_NUMBER);
verify(webserviceMock, never()).checkOperator(CACHED_MOBILE_NUMBER);
}

但在 Spock 中的代碼就相對比較簡潔,如下所示代碼實現了上述 Mockito 代碼同樣的功能。

def "should not hit remote service if found in cache"() {
given:
cacheMock.getCachedOperator(CACHED_MOBILE_NUMBER) >> Optional.of(PLUS)
when:
service.checkOperator(CACHED_MOBILE_NUMBER)
then:
0 * webserviceMock.checkOperator(CACHED_MOBILE_NUMBER)
}

可以看到,Spock 沒有 given、willReturn 等關鍵詞,而是取而用 >> 等符號來實現,這樣代碼更加簡潔,閱讀起來也更加明了。

案例代碼對比:https://www.yuque.com/lugew/spock/wkxhvk

責任編輯:武曉燕 來源: 樹哥聊編程
相關推薦

2022-09-22 09:54:56

技術選型

2016-10-21 15:58:51

容器容器技術Docker

2022-06-08 13:25:51

數據

2022-05-27 11:46:48

技術能力思考

2020-09-25 07:40:39

技術開發選型

2019-05-30 14:30:42

技術管理架構

2021-03-10 09:33:51

技術研發管理

2023-03-31 13:53:00

低代碼平臺選型

2015-05-20 09:44:54

混合云云存儲合規

2022-03-18 08:57:17

前端數據流選型

2022-04-10 11:52:43

前端單測程序

2023-07-04 08:09:05

數據庫選型集中式

2025-03-14 08:00:59

TypeScript編譯器Go

2023-04-13 07:41:14

RoCE技術RDMA

2022-05-26 09:03:39

AOP編程

2021-12-08 10:54:09

汽車智能芯片

2022-08-01 07:38:29

代碼開發

2011-04-13 14:04:14

Java數組

2021-02-22 09:30:09

go開發環境桌面系統

2020-06-17 15:44:47

技術研發架構
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: www.精品国产| 国产精品久久久久久久久久久久久久 | 亚洲一级在线 | 91精品国产91久久久久久三级 | 久久精品免费 | 国产精品国产馆在线真实露脸 | 99久久精品国产一区二区三区 | 日日爱视频 | 成人久久18免费网站麻豆 | 亚洲国产成人精品久久 | 欧美男人天堂 | 亚洲高清av| 日日骚视频 | 亚洲成人一区二区三区 | 五月激情婷婷六月 | 亚洲一区二区免费 | 免费九九视频 | 欧美一级二级视频 | 在线观看日韩 | 久久久久一区二区三区 | 国产精品久久久久久久免费大片 | 欧美片网站免费 | 国产欧美精品一区二区 | 久久一区 | 日韩一区二区在线播放 | 久久国产精品72免费观看 | 粉嫩一区二区三区性色av | 99九九视频 | 中文精品视频 | 在线欧美视频 | 视频一区二区在线观看 | 国产做爰 | 中文字幕成人 | 懂色av色香蕉一区二区蜜桃 | 亚洲在线看| 91看片网址 | 欧美一区二 | 久久久成人免费视频 | 国产做a爱免费视频 | 亚洲日本视频 | 男人的天堂中文字幕 |