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