Robot Framework官方教程(四)創(chuàng)建測(cè)試套件

Robot Framework官方教程(一)入門(mén)
Robot Framework官方教程(二)測(cè)試數(shù)據(jù)語(yǔ)法
Robot Framework官方教程(三)創(chuàng)建測(cè)試用例
Robot Framework官方教程(四)創(chuàng)建測(cè)試套件
Robot Framework官方教程(五)使用測(cè)試庫(kù)
Robot Framework官方教程(六)變量
Robot Framework官方教程(七)創(chuàng)建用戶(hù)關(guān)鍵字
Robot Framework官方教程(八) 資源和變量文件
Robot Framework官方教程(九) 執(zhí)行測(cè)試用例
Robot Framework官方教程(十)擴(kuò)展RobotFramework框架

Robot Framework測(cè)試用例是在測(cè)試用例文件中創(chuàng)建的,可以將其組織到目錄中。這些文件和目錄組成了分層測(cè)試套件結(jié)構(gòu)。

2.3.1測(cè)試用例文件

Robot Framework測(cè)試用例使用測(cè)試用例文件中的測(cè)試用例表創(chuàng)建的。這樣的文件會(huì)自動(dòng)從它包含的所有測(cè)試用例中創(chuàng)建一個(gè)測(cè)試套件??梢杂卸嗌贉y(cè)試用例沒(méi)有上限,但建議少于10個(gè),除非使用數(shù)據(jù)驅(qū)動(dòng)方法,其中一個(gè)測(cè)試用例只包含一個(gè)高級(jí)關(guān)鍵字。

設(shè)置表中的以下設(shè)置可用于自定義測(cè)試套件:

注意

所有設(shè)置名稱(chēng)都可以選擇在末尾包含冒號(hào),例如Documentation: 。這可以使設(shè)置更容易閱讀,尤其是在使用純文本格式時(shí)。這是Robot Framework 2.5.5中的一項(xiàng)新功能。

2.3.2測(cè)試套件目錄

測(cè)試用例文件可以組織到目錄中,這些目錄可以創(chuàng)建更高級(jí)別的測(cè)試套件。從目錄創(chuàng)建的測(cè)試套件不能直接包含任何測(cè)試用例,但它包含其他帶有測(cè)試用例的測(cè)試套件。然后可以將這些目錄放入其他目錄中,從而創(chuàng)建更高級(jí)別的套件。結(jié)構(gòu)沒(méi)有限制,因此可以根據(jù)需要組織測(cè)試用例。

執(zhí)行測(cè)試目錄時(shí),它包含的文件和目錄將按遞歸方式處理,如下所示:

  • 名稱(chēng)以點(diǎn)(.)或下劃線(_)開(kāi)頭的文件和目錄將被忽略。
  • 名稱(chēng)為CVS的目錄將被忽略(區(qū)分大小寫(xiě))。
  • 不在以下已識(shí)別的擴(kuò)展名(.html, .xhtml,.htm,.tsv,.txt,.rst或.rest)的文件將被忽略(不區(qū)分大小寫(xiě))。
  • 其他文件和目錄都將被處理。

如果處理的文件或目錄不包含任何測(cè)試用例,則會(huì)以靜默方式忽略它(將消息寫(xiě)入syslog)并繼續(xù)處理。

警告無(wú)效文件

通常,使用寫(xiě)入syslog的消息將忽略沒(méi)有有效測(cè)試用例表的文件。從Robot Framework 2.5.5開(kāi)始,可以使用命令行選項(xiàng)--warnonskippedfiles,它將消息轉(zhuǎn)換為測(cè)試執(zhí)行錯(cuò)誤中顯示的警告。

初始化文件

從目錄創(chuàng)建的測(cè)試套件可以具有與從測(cè)試用例文件創(chuàng)建的套件類(lèi)似的設(shè)置。因?yàn)槟夸洷旧聿荒馨欠N信息,所以必須將其放入特殊的測(cè)試套件初始化文件中。初始化文件與測(cè)試用例文件具有相同的結(jié)構(gòu)和語(yǔ)法,但它們不能包含測(cè)試用例表,并且不是所有設(shè)置項(xiàng)都支持。

初始化文件名必須始終為__init__.ext格式,其中擴(kuò)展名必須與支持的文件格式之一匹配(例如,__init__.html__init__.txt。該名稱(chēng)格式來(lái)自Python,以這種方式命名文件表示該目錄是一個(gè)模塊。

初始化文件的主要用途是與測(cè)試用例文件類(lèi)似,可以指定與測(cè)試套件相關(guān)的設(shè)置,但也可以設(shè)置一些與測(cè)試用例相關(guān)的設(shè)置。初始化文件中創(chuàng)建或?qū)氲淖兞亢完P(guān)鍵字在子測(cè)試套件中不可用**,但是可以使用資源文件共享資源。

如何在初始化文件中使用設(shè)置:

  • Documentation, Metadata, Suite Setup, Suite Teardown

    這些特定于測(cè)試套件的設(shè)置與測(cè)試用例文件中的工作方式相同。

  • Force Tags

    指定的標(biāo)記無(wú)條件地設(shè)置為此目錄直接或遞歸包含的所有測(cè)試用例文件中的所有測(cè)試用例。

  • Test Setup, Test Teardown, Test Timeout

    將test setup/teardown或test timeout的默認(rèn)值設(shè)置為此目錄包含的所有測(cè)試用例??梢栽谳^低級(jí)別覆蓋。Robot Framework 2.7中添加了對(duì)初始化文件中定義測(cè)試超時(shí)的支持。

  • Default Tags, Test Template

    初始化文件不支持。

    Setting Value Value
    Documentation Example suite
    Suite Setup Do Something ${MESSAGE}
    Force Tags example
    Library SomeLibrary
    Variable Value Value
    ${MESSAGE} Hello, world!
    Keyword Action Argument Argument
    Do Something [Arguments] ${arg}
    Some Keyword ${arg}
    Another Keyword

2.3.3測(cè)試套件名稱(chēng)和文檔

測(cè)試套件名稱(chēng)由文件或目錄名構(gòu)成。創(chuàng)建套件名稱(chēng)好處是可以忽略文件的擴(kuò)展名,下劃線使用空格替換,完全小寫(xiě)的名稱(chēng)將轉(zhuǎn)為標(biāo)題格式。例如,some_tests.html變?yōu)?code>Some Tests, My_test_directory變?yōu)?code>My test directory。

注意

在Robot Framework 2.5中,創(chuàng)建測(cè)試套件名稱(chēng)的規(guī)則略有不同。

文件或目錄名稱(chēng)可以包含用于控制套件執(zhí)行順序的前綴。前綴通過(guò)兩個(gè)下劃線與基本名稱(chēng)分隔,并且在構(gòu)造實(shí)際測(cè)試套件名稱(chēng)時(shí),前綴和下劃線都將被刪除。例如,文件 01__some_tests.txt02__more_tests.txt分別創(chuàng)建測(cè)試套件Some TestsMore Tests,前者在后者之前執(zhí)行。

使用 “設(shè)置”表中的“Documentation”設(shè)置測(cè)試套件的文檔。它可以在測(cè)試用例文件中使用,也可以在更高級(jí)別的套件中用于測(cè)試套件初始化文件。測(cè)試套件文檔用法和之前創(chuàng)建測(cè)試用例章節(jié)中的用法一樣。

Setting Value Value Value
Documentation An example test suite documentation with some formatting.
... See test documentation for more documentation examples.

在測(cè)試執(zhí)行中,可以覆蓋頂級(jí)測(cè)試套件的名稱(chēng)和文檔。這可以分別使用命令行選項(xiàng)--name--doc來(lái)完成,如設(shè)置元數(shù)據(jù)一節(jié)中所述。

2.3.4測(cè)試套件元數(shù)據(jù)

測(cè)試套件還可以包含除文檔之外的其他元數(shù)據(jù)。此元數(shù)據(jù)使用“Metadata”設(shè)置。以這種方式設(shè)置的元數(shù)據(jù)顯示在測(cè)試報(bào)告和日志中。

對(duì)元數(shù)據(jù)的名稱(chēng)和值參見(jiàn)下表。該值的處理方式與文檔類(lèi)似,這意味著它可以拆分為多個(gè)單元格(用空格連接在一起)或分成幾行(用換行連接在一起),簡(jiǎn)單的HTML格式化,甚至可以使用變量。

Setting Value Value Value Value
Metadata Version 2.0
Metadata More Info For more information about *Robot Framework* see http://robotframework.org
Metadata Executed At ${HOST}

對(duì)于頂級(jí)測(cè)試套件,也可以使用--metadata命令行選項(xiàng)設(shè)置元數(shù)據(jù) 。這在“ 設(shè)置元數(shù)據(jù)”一節(jié)中有更詳細(xì)的討論。

2.3.5套件設(shè)置和拆卸

測(cè)試用例和測(cè)試套件都可以進(jìn)行設(shè)置和拆卸。在運(yùn)行任何套件或子測(cè)試套件的測(cè)試用例之前執(zhí)行套件設(shè)置,并在它們之后執(zhí)行測(cè)試拆卸。所有測(cè)試套件都可以進(jìn)行設(shè)置和拆卸; 對(duì)于從目錄創(chuàng)建的套件,必須在測(cè)試套件初始化文件中指定它們。

與測(cè)試用例類(lèi)似,套件設(shè)置和拆解是一個(gè)可以帶參數(shù)的關(guān)鍵字。它們分別在設(shè)置表中使用Suite Setup和Suite Teardown設(shè)置進(jìn)行定義 。它們也有類(lèi)似的同義詞,Suite Precondition和Suite Postcondition,作為測(cè)試用例設(shè)置和拆解。關(guān)鍵字名稱(chēng)和可能的參數(shù)位于設(shè)置名稱(chēng)后面的列中。

如果套件設(shè)置失敗,則會(huì)立即為其中的所有測(cè)試用例及其子測(cè)試套件分配一個(gè)失敗狀態(tài),并且它們實(shí)際上并未執(zhí)行。這使得套件設(shè)置非常適合檢查在運(yùn)行測(cè)試用例之前必須滿(mǎn)足的前提條件。

在執(zhí)行完所有測(cè)試用例后,套件拆卸通常用于清理。即使同一套件的設(shè)置失敗,也會(huì)執(zhí)行它。如果套件拆卸失敗,則套件中的所有測(cè)試用例都標(biāo)記為失敗,無(wú)論其原始執(zhí)行狀態(tài)如何。從Robot Framework 2.5開(kāi)始,即使其中一個(gè)關(guān)鍵字失敗,也會(huì)執(zhí)行套件拆解中的所有關(guān)鍵字。

作為設(shè)置或拆卸執(zhí)行的關(guān)鍵字的名稱(chēng)可以是變量。通過(guò)從命令行提供關(guān)鍵字名稱(chēng)作為變量,這有助于在不同環(huán)境中進(jìn)行不同的設(shè)置或拆卸。

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

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

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