Awaitility同步異步工具實(shí)戰(zhàn)示例詳解
引言
在編寫測(cè)試用例的時(shí)候遇到有異步或者隊(duì)列處理的時(shí)候經(jīng)常會(huì)用到 Thread.sleep() 等待來進(jìn)行測(cè)試。例如:DLedger 測(cè)試選舉的過程。當(dāng)DLedger Leader下線。此時(shí)DLedger會(huì)重新發(fā)起選舉,這個(gè)選舉的過程是需要一定時(shí)間。很多時(shí)候在測(cè)試代碼中就會(huì)使用 Thread.sleep 。
由于選舉需要的時(shí)間多少不確定所以sleep時(shí)間就會(huì)設(shè)置為開發(fā)者經(jīng)驗(yàn)的最大值。這樣會(huì)造成測(cè)試代碼會(huì)變得很慢。 當(dāng)然開發(fā)者可以通過自己輪詢來實(shí)現(xiàn)減少時(shí)間的消耗。
下面介紹一個(gè)處理這個(gè)一類問題的工具:awaitility
1. awaitility入門
Maven:
<dependency> <groupId>org.awaitility</groupId> <artifactId>awaitility</artifactId> <version>xxxx</version> <scope>test</scope> </dependency>
文章編寫的時(shí)候版本為:4.2.0
1.1 靜態(tài)導(dǎo)入
為了有效地使用Awaitility,建議從Awaitility框架中靜態(tài)地導(dǎo)入以下方法:
org.awaitility.Awaitility.*
在使用的時(shí)候需要搭配Java的時(shí)間相關(guān)的類以及Junit相關(guān)類:
java.time.Duration.*
java.util.concurrent.TimeUnit.*
org.junit.Assert.*
1.2 簡(jiǎn)單例子
例子1:
await().until(newUserIsAdded());
等待直到執(zhí)行newUserIsAdded()返回true. 這個(gè)是沒有返回值的。
例子2:
await().atMost(5, SECONDS).until(newUserWasAdded());
最多等待5秒,等待直到執(zhí)行newUserIsAdded()返回true. 這個(gè)是沒有返回值的。
例子3:
await().until( userRepositorySize(), equalTo(1) );
等待直到執(zhí)行userRepositorySize()返回方法對(duì)應(yīng)的值. 這個(gè)是有返回值
更多的例子可以參照官網(wǎng) 使用例子
2. awaitility在RocketMQ中的實(shí)戰(zhàn)
在RocketMQ的test cases 中有一些使用了 Thread.sleep,接下來我們看看如何使用awaitility進(jìn)行優(yōu)化,減少測(cè)試用例的執(zhí)行時(shí)間。以ControllerManagerTest測(cè)試用例為例子來解決,在代碼中可以看到有這樣的代碼:
上圖框出來的代碼主要的作用是什么呢?等待Broker的Master過期,但是過期的時(shí)間我們根據(jù)設(shè)置的心跳的過期時(shí)間來預(yù)估時(shí)間。所以這里填寫的是6秒當(dāng)然你也可以填寫10秒或者更長(zhǎng)。
解決之前的執(zhí)行時(shí)間:
使用awaitility對(duì)代碼進(jìn)行改造重構(gòu):
重構(gòu)后的代碼,如上圖的紅線框出來部分。當(dāng)然我這里還對(duì)其他的進(jìn)行處理。
有興趣的可以關(guān)注一下RocketMQ的這個(gè)ISSUE:github.com/apache/rock…
使用awaitility重構(gòu)后的執(zhí)行時(shí)間:
時(shí)間有明顯的下降。相比之前的下降了5秒左右。
3. 總結(jié)
- 在測(cè)試過程中引入awaitility能夠很大程度上方便測(cè)試,無需要每次都憑經(jīng)驗(yàn)去預(yù)估時(shí)間。并且很多時(shí)候這個(gè)Thread.sleep的時(shí)間不是很好估算。減少了單元測(cè)試執(zhí)行的時(shí)間。特別是像RocketMQ這樣大型的項(xiàng)目單元測(cè)試很多。并且很多都是去測(cè)試分布式的,如果使用Thread.sleep會(huì)導(dǎo)致整個(gè)單元測(cè)試的時(shí)間很長(zhǎng)。
- 無需自己去實(shí)現(xiàn)輪詢來減少單元測(cè)試的時(shí)間。
以上就是Awaitility同步異步工具實(shí)戰(zhàn)示例詳解的詳細(xì)內(nèi)容,更多關(guān)于Awaitility同步異步工具實(shí)的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Java如何正確處理下載文件時(shí)HTTP頭的編碼問題
這篇文章主要介紹了Java如何正確處理下載文件時(shí)HTTP頭的編碼問題,2023-07-07
通常HTTP消息包括客戶機(jī)向服務(wù)器的請(qǐng)求消息和服務(wù)器向客戶機(jī)的響應(yīng)消息,今天來講解下正確處理下載文件時(shí)HTTP頭的編碼問題,需要的朋友可以參考下spring cloud-給Eureka Server加上安全的用戶認(rèn)證詳解
這篇文章主要介紹了spring cloud-給Eureka Server加上安全的用戶認(rèn)證詳解,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-01-01Java 使用POI生成帶聯(lián)動(dòng)下拉框的excel表格實(shí)例代碼
本文通過實(shí)例代碼給大家分享Java 使用POI生成帶聯(lián)動(dòng)下拉框的excel表格,代碼簡(jiǎn)單易懂,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友參考下吧2017-09-09一個(gè)簡(jiǎn)陋的java圖書管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了一個(gè)簡(jiǎn)陋的java圖書管理系統(tǒng),簡(jiǎn)單的實(shí)現(xiàn)功能測(cè)試,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-07-07eclipse配置tomcat10的詳細(xì)步驟總結(jié)
今天給大家?guī)淼氖顷P(guān)于Java的相關(guān)知識(shí),文章圍繞著eclipse配置tomcat10的詳細(xì)步驟展開,文中有非常詳細(xì)的介紹及圖文示例,需要的朋友可以參考下2021-06-06Java利用Redis實(shí)現(xiàn)高并發(fā)計(jì)數(shù)器的示例代碼
這篇文章主要介紹了Java利用Redis實(shí)現(xiàn)高并發(fā)計(jì)數(shù)器的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-02-02Java實(shí)現(xiàn)自定義LinkedList類的示例代碼
LinkedList類跟ArrayList類不同,它通過指針以及結(jié)點(diǎn)的操作對(duì)鏈表進(jìn)行增刪改查。本文就來和大家分享下Java如何為實(shí)現(xiàn)自定義LinkedList類,需要的可以參考一下2022-08-08