test runner 腳本使用與 xUnit 框架相同的測試套件(test suite)和測試用例概念。測試用例和命令按照它們在測試套件和測試用例中出現(xiàn)的順序依次執(zhí)行。在 清單 1 中:
* 第一列包含命令 或斷言。
* 第二列包含命令或斷言的目標(biāo)(target)。這里可以用多種受支持的組件定位符中的一種來指定目標(biāo)。通常使用的是組件的 ID 或名稱,但 XPath 和 DOM 定位符也是受支持的。
* 第三列包含用于為命令或斷言指定參數(shù)的值。例如,當(dāng)使用 type 命令時(shí),這一列可能是一個(gè)文本域所期望的值。
即使對于非技術(shù)人員來說,test runner 腳本也易于閱讀和編寫。當(dāng)在一個(gè)瀏覽器中打開 清單 1 中的例子時(shí),將得到類似這樣的一個(gè)表:
First command Target Value
Second command Target Value
接下來,我將描述如何使用命令和斷言編寫一個(gè)簡單但是完整的測試用例。
測試用例實(shí)例
執(zhí)行 清單 2 中的測試腳本時(shí),它將執(zhí)行以下操作:
1. 通過進(jìn)入 /change_address_form.html 打開變更地址頁面。
2. 在 ID 為 address_field 的文本框中輸入 Betelgeuse state prison。
3. 單擊名為 Submit 的輸入?yún)^(qū)。注意,這里使用 XPath 找到 Submit 按鈕,這導(dǎo)致表單數(shù)據(jù)被發(fā)送到服務(wù)器。
4. 驗(yàn)證頁面是否包含文本 Address change successful。
清單 2. 在測試用例中使用命令和斷言的例子
<table>
<tr>
<td>open</td>
<td>/change_address_form.html</td>
<td></td>
</tr>
<tr>
<td>type</td>
<td>address_field</td>
<td>Betelgeuse state prison</td>
</tr>
<tr>
<td>clickAndWait</td>
<td>//input[@name='Submit']</td>
<td></td>
</tr>
<tr>
<td>verifyTextPresent</td>
<td>Address change successful</td>
<td></td>
</tr>
</table>
測試套件
要達(dá)到對應(yīng)用程序的完全測試覆蓋,通常需要不止一個(gè)測試用例。這是 Selenium 使用測試套件的原因。測試套件用于將具有類似功能的一些測試用例編成一組,以便讓它們按順序運(yùn)行。
測試套件和測試用例一樣,都是用簡單的 HTML 表編寫的。Selenium 執(zhí)行的缺省測試套件的名稱是 TestSuite.html。清單 3 展示了一個(gè)測試套件,該套件像通常的用戶一樣測試應(yīng)用程序。注意,測試套件使用一個(gè)只包含一列的表,表中的每一行指向一個(gè)包含某個(gè)測試用例的文件。
清單 3. 測試套件示例
<table>
<tr>
<td>Test suite for the whole application</td>
</tr>
<tr>
<td><a href="test_main_page.html">Access main page</a></td>
</tr>
<tr>
<td><a href="test_login.html">Login to application</a></td>
</tr>
<tr>
<td><a href="test_address_change.html">Change address</a></td>
</tr>
<tr>
<td><a href="test_logout.html">Logout from application</a></td>
</tr>
</table>
接下來我將把目光轉(zhuǎn)移到 driven 測試腳本。
driven 模式
driven Selenium 腳本是用多種受支持的編程語言中的一種編寫的 —— 目前可用的有 Java、Ruby 和 Python 驅(qū)動(dòng)程序。這些腳本在瀏覽器之外的一個(gè)單獨(dú)的進(jìn)程中運(yùn)行。驅(qū)動(dòng)程序的任務(wù)是執(zhí)行測試腳本,并通過與運(yùn)行在瀏覽器中的 browser bot 進(jìn)行通信來驅(qū)動(dòng)瀏覽器。驅(qū)動(dòng)程序與 browser bot 之間的通信使用一種簡單的特定于 Selenium 的連接語言 Selenese。
driven 腳本比 test runner 腳本更強(qiáng)大、更靈活,可以將它們與 xUnit 框架集成。driven 腳本的缺點(diǎn)(與 test runner 腳本相比)是,這種腳本編寫和部署起來更復(fù)雜。這是因?yàn)轵?qū)動(dòng)程序必須執(zhí)行以下任務(wù):
* 啟動(dòng)服務(wù)器。
* 部署所測試的應(yīng)用程序(AUT)。
* 部署測試腳本。
* 啟動(dòng)瀏覽器。
* 發(fā)送命令到 browser bot。
* 驗(yàn)證 browser bot 執(zhí)行的命令的結(jié)果。
driven 腳本更依賴于應(yīng)用程序運(yùn)行時(shí)環(huán)境。例如,Java 驅(qū)動(dòng)程序使用一個(gè)嵌入式 Jetty 或 Tomcat 實(shí)例來部署所測試的應(yīng)用程序。目前,已經(jīng)有人在致力于將 Selenium 集成到 Ruby on Rails 中,但是在我撰寫本文之際,這個(gè)集成版本還沒有被發(fā)布。
清單 4 摘自一個(gè)使用 Ruby 驅(qū)動(dòng)程序的 driven 測試腳本。注意,我省略了用于啟動(dòng)服務(wù)器和瀏覽器的步驟,這個(gè)測試腳本代碼幾乎和 test runner 腳本一樣簡單。
清單 4. 使用 Ruby 驅(qū)動(dòng)程序的例子
puts selenium.open('/logout.html')
puts selenium.verify_location('/index.html')
現(xiàn)實(shí)中的需求
在接下來的兩節(jié)(現(xiàn)實(shí)中的需求 和 現(xiàn)實(shí)中的用例)中,我將描述如何在現(xiàn)實(shí)場景中使用 Selenium,并針對用 Ruby on Rails 和一點(diǎn)兒 Ajax 技術(shù)編寫的一個(gè)簡單的股票報(bào)價(jià)查看器應(yīng)用程序編寫 Selenium 測試用例。雖然這個(gè)應(yīng)用程序是用 Ruby on Rails 編寫的,但是也可以將這個(gè)例子應(yīng)用于任何 Web 應(yīng)用程序,因?yàn)闇y試腳本是按 test runner 模式以 HTML 編寫的。這個(gè)示例應(yīng)用程序是用 Ruby 1.8.3 和 Ruby on Rails 0.14.2 測試的,但是它也可能可以使用更舊的或更新的版本。
如果有 Linux,那么發(fā)行版中通常已經(jīng)包括了 Ruby。在命令提示符下運(yùn)行 ruby -v,檢查您所擁有的版本。對于大多數(shù)平臺,都可以在http://www.ruby-lang.org/上找到一個(gè) Ruby 發(fā)行版。
接下來的步驟是通過 RubyGems 打包系統(tǒng)安裝 Ruby on Rails。為此,只需執(zhí)行 gem install rails --include-dependencies。在某些平臺上,必須執(zhí)行一些額外的步驟,所以請?jiān)L問 Ruby on Rails 網(wǎng)站,以獲得更多細(xì)節(jié)。
在我撰寫本文之際,目前可用的 Selenium 版本是 0.6。我已經(jīng)將它集成在示例應(yīng)用程序中(見 下載 小節(jié)),我的做法是從http://selenium.thoughtworks.com/下載 Selenium Core 包,然后將名為 selenium 的文件夾復(fù)制到用于靜態(tài)內(nèi)容的文件夾。在 Ruby on Rails 應(yīng)用程序中,這個(gè)文件夾的名稱是 public。在 J2EE Web 應(yīng)用程序中,可以將 selenium 文件夾放在 Web 應(yīng)用程序的根目錄或 WAR 歸檔文件中。
后一步是下載示例應(yīng)用程序。從 下載 小節(jié)中獲得這個(gè)包。解壓應(yīng)用程序,并打開一個(gè)命令提示符。然后轉(zhuǎn)入應(yīng)用程序被解壓到的那個(gè)目錄。為了啟動(dòng)應(yīng)用程序,運(yùn)行 ruby script/server。應(yīng)該看到 Rails 成功啟動(dòng)了,如 圖 1 所示。