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