[iOS單元測試系列]單元測試編碼規(guī)范

編寫單元測試與編寫工程代碼略有不同。我們需要準(zhǔn)備數(shù)據(jù),mock對象,調(diào)用工程Api,驗證結(jié)果。而且一般測試代碼都會比工程代碼要大。就像Real-World Testing with XCTest一文中提到“目前為止,我們的編碼庫已經(jīng)縱橫 190 個文件和 18,000 行代碼,達(dá)到了 544 kB。我們測試部分的代碼現(xiàn)在差不多有1,200 kB,大概有被測試代碼的兩倍”。那么應(yīng)該如何定義單元測試代碼編寫規(guī)范,使得代碼更整潔,可讀性更高呢?

為了工程代碼的保密,文中的代碼在命名的時候在不影響理解的情況下都做了改動

1.Given-When-Then分段

每個case其實都可以分為三步走,1.mock對象,準(zhǔn)備測試數(shù)據(jù)。2.調(diào)用目標(biāo)API 3.驗證輸出和行為。所以我們可以用如下方式將3步分別放入Given-When-Then三個分段中。(為了保密,代碼做了改動)


- (void)testNeedToShowRowWhenTypeIsAll{

//given

_sut.collectionType = 1;

NSIndexPath *path1 = [NSIndexPath indexPathForRow:1 inSection:1];

//when

BOOL needToShow1 = [_sut needToShowRow:path1];

//then

assertThatBool(needToShow1,isTrue());

}

這樣我們一眼掃過去就可以清晰的看出一個case大體上都在干什么。

2.一個Case只測試一種情況

可能我們調(diào)用的一個API內(nèi)部有一個if...else...。我建議if一個case,else一個case。分兩個不同的case來作測試.這樣每個case就很清晰自己在測試什么東西。而如果全部雜糅在一個case中,可讀性會降低不少,而且case體積也會變得相對大很多,因為你要Given-When-Then兩次。更不建議在case中寫for循環(huán)驗證。有人說我的測試目標(biāo)函數(shù)中有很多if...else...,那么我覺得你應(yīng)該重構(gòu)下你的設(shè)計了。

所以,我們的結(jié)論是一個Case只測試一種情況,不同情況用When標(biāo)明:


- (void)testNeedToShowRowWhenTypeIsAll{

...

}

- (void)testNeedToShowRowWhenTypeIsOnSell{

...

}

3.用_sut來標(biāo)明被測試類

一個測試文件只有一個被測試類。但是當(dāng)我們的測試文件越來越多的時候,當(dāng)我們看一個測試case的時候需要看懂這個case才明白我們的被測試類是誰?;蛘呶覀円部梢钥礈y試文件名(XXXXXXTest.m)才知道我們的被測試類是誰,但是這樣卻不是很直觀。所以不管我們在那個測試文件中,測試的類是誰,叫什么名字,我們都以為一個局部變量名_sut來定義我們的被測試類。這樣我們一眼就能知道我們被測試類是誰。

_sut就是System Under Test的縮寫。


@implementation JHSCollectionDataSourceTest {

JHSCollectionDataSource *_sut;

}

- (void)testNeedToShowHeaderWhenTypeIsAll{

//given

_sut.collectionType = 1;

//when

BOOL needToShow1 = [_sut needToShowHeader:1];

//then

assertThatBool(needToShow1,isTrue());

}

4.用Category暴露私有函數(shù)和屬性

我們的測試case中調(diào)用的方法可能會改變一個私有的屬性,調(diào)用一個私有的方法。怎么去優(yōu)雅的驗證這種行為呢,我們可以在測試文件的開頭用一個名字為UnitTest的category來暴露出我們的私有方法和屬性(屬性暴露的是屬性對應(yīng)的getter和setter方法)。


@interface JHSTestDataSource (UnitTest)

- (NSInteger)getSellGroupCount;

- (BOOL)needShowHeader:(NSInteger)section;

@end

總結(jié)

enjoy it!

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 136,578評論 19 139
  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 179,094評論 25 709
  • 1.Given-When-Then分段每個case其實都可以分為三步走,1.mock對象,準(zhǔn)備測試數(shù)據(jù)。2.調(diào)用目...
    清風(fēng)沐沐閱讀 585評論 0 0
  • 姓名:母光艷 公司:寧波貞觀電器 第235期,利他二組 【日精進(jìn)打卡第74天】 【知-學(xué)習(xí)】 誦讀《六項精進(jìn)》大綱...
    母光焱閱讀 239評論 0 0
  • 今天早上6:40送女兒去學(xué)校,因為走的是一條新開通的路,還沒有安裝路燈,所以路上比較黑,但即使這樣,我的車開的近光...
    云是雨的衣閱讀 291評論 3 0

友情鏈接更多精彩內(nèi)容