有成功就有失敗。登錄驗(yàn)證不光要驗(yàn)證成功的test case,也要覆蓋各種失敗的情況:比如用戶名/密碼輸入錯(cuò)誤,按鈕出問(wèn)題,跳轉(zhuǎn)界面不正確等等。因?yàn)橛脩裘?密碼輸入錯(cuò)誤比較常見(jiàn),這次我們就用它舉例作為登錄模塊的第二個(gè)test case。
打開(kāi)RIDE,加載之前的項(xiàng)目,并在Tests –> Login模塊里創(chuàng)建第二個(gè)test case TCLOG-2:
我把里邊內(nèi)容也寫(xiě)上了一部分。很好理解,登錄失敗和登陸成功一樣,也需要在運(yùn)行前后關(guān)閉其它瀏覽器,所以同樣把Setup和Teardown步驟寫(xiě)好。還有一點(diǎn)一樣的是,程序運(yùn)行起來(lái)也需要從文件里讀取數(shù)據(jù),只不過(guò)是錯(cuò)誤的數(shù)據(jù)罷了。經(jīng)過(guò)分析,無(wú)非有以下幾種可能的錯(cuò)誤:
1) 員工代號(hào)沒(méi)填;
2) 密碼沒(méi)填;
3) 員工代號(hào)不存在;
4) 密碼和員工代號(hào)不匹配。
我們就以第4種情況為例準(zhǔn)備數(shù)據(jù)寫(xiě)test case,選一個(gè)合法的員工代號(hào),但錯(cuò)誤的密碼。在Test_Data ->Login下新建一個(gè)文件叫TCLOG-2.xls,還是用1001號(hào)員工,他的正確密碼是123。我們隨便寫(xiě)個(gè)錯(cuò)誤密碼,比如“321”:
然后仿照TCLOG-1,把讀取數(shù)據(jù)的部分寫(xiě)進(jìn)前兩行,注意把文件名改成TCLOG-2.xls:
Test case主體寫(xiě)完了,該寫(xiě)函數(shù)了。先打開(kāi)登錄成功的函數(shù)Login to hrsystem復(fù)習(xí)一下 – 打開(kāi)瀏覽器,輸入員工代號(hào)密碼種種,我們會(huì)發(fā)現(xiàn)對(duì)于登錄失敗用戶也得執(zhí)行這些操作,我們完全可以復(fù)制粘貼,唯一不同的是最后驗(yàn)證方式不一樣。對(duì)于登錄成功會(huì)出現(xiàn)導(dǎo)航欄Home按鈕,登錄失敗會(huì)出現(xiàn)警告“usercode or password is incorrect”:
所以我們只要驗(yàn)證是否會(huì)出現(xiàn)紅色警告即可。出現(xiàn)警告就是pass,沒(méi)有警告就是fail。右鍵點(diǎn)擊Pages里的Login.html資源文件新建一個(gè)叫Invalid login to hrsystem的Keyword,代表登錄失敗的函數(shù),然后復(fù)制粘貼Login to hrsystem中的前幾步。還有,別忘了把員工代號(hào)和密碼參數(shù)放到Arguments域中:
我們既可以檢查網(wǎng)頁(yè)包不包含該警告在網(wǎng)頁(yè)上的位置,用page contains element即可,以前在登錄成功的例子中用的就是這種。當(dāng)然也可以檢查該警告的內(nèi)容是不是目標(biāo)字符串“usercode or password is incorrect”。我們這次用第二種方法,先把這個(gè)目標(biāo)字符串聲明成一個(gè)變量:右鍵ObjRepository -> Login.html -> New Scalar,輸入變量${tLoginErrorMsg},值是“usercode or password is incorrect”:
運(yùn)行測(cè)試時(shí)從警告的xpath取出字符串。如果和這個(gè)目標(biāo)值相同就pass,不同就fail:
回到函數(shù)Invalid login to hrsystem,在最后加上如圖所示的兩句話:
第7行代表的是從變量${locLoginErrMsg}中取出值,然后賦給變量${tcurrentErrMsg},第二列“Get Text”表示從哪個(gè)變量取。${tcurrentErrMsg}不需要在ObjRepository –> Login.html里創(chuàng)建,因?yàn)樗皇莻€(gè)本地變量,作用域只限于當(dāng)前函數(shù)中,不需要在別的函數(shù)中引用,用完就完了。第8行的關(guān)鍵字Should be Equal As Strings接受兩個(gè)字符串作為參數(shù),目的是比較兩個(gè)字符串是否相等,也就是把第7步從警告xpath里取出的值與目標(biāo)字符串${tLoginErrorMsg}進(jìn)行比較。
函數(shù)修改完畢,回到TCLOG-2,把函數(shù)寫(xiě)到test case中:?
運(yùn)行測(cè)試,因?yàn)閺膞path得到的字符串和目標(biāo)字符串相等,測(cè)試通過(guò)。這就是驗(yàn)證登錄失敗的test case,在實(shí)際項(xiàng)目中與登錄成功的驗(yàn)證同等重要。剛才也說(shuō)了,兩個(gè)函數(shù)Login to hrsystem和InvalidLogin to hrsystem前幾步都是相同的,寫(xiě)兩遍太累,與我懶人氣質(zhì)不符。寫(xiě)程序時(shí)我們的目標(biāo)是能省就省,能不重復(fù)絕不重復(fù)。繼續(xù)優(yōu)化,我們可以把操作和驗(yàn)證分開(kāi),在一個(gè)keyword里只寫(xiě)操作,而用另外兩個(gè)分別寫(xiě)登陸成功和登錄失敗的驗(yàn)證。
打開(kāi)Invalid Login to hrsystem,把前幾步都刪除,然后把Login to hrsystem和它所需要的員工代號(hào)密碼兩個(gè)參數(shù)寫(xiě)到第一行,如下圖:
在Pages -> Login.html中新建一個(gè)叫Valid Login to hrsystem的keyword,這個(gè)函數(shù)是專門用來(lái)驗(yàn)證登錄成功的。和Invalid Login to hrsystem一樣修改:
Login to hrsystem函數(shù)只保留操作步驟,把驗(yàn)證部分刪除:
你看,這么一改,操作步驟用Login to hrsystem,驗(yàn)證分別用另外兩個(gè),彼此互不干擾。最后,回到TCLOG-1修改相應(yīng)函數(shù)名,TCLOG-2不需要:
同時(shí)運(yùn)行兩個(gè)test cases,測(cè)試通過(guò):
這篇文章的源代碼在[Test5](https://github.com/cslm/cslm.robotframework/tree/master/Test5)中。