一文詳解e2e測(cè)試之cypress的使用
用e2e測(cè)試想要達(dá)到什么目的?
- 將被測(cè)試的單元放在特定環(huán)境下,選中并讓它發(fā)生交互,達(dá)到目標(biāo)結(jié)果。
- 在測(cè)試之前,為測(cè)試用例創(chuàng)造它需要的環(huán)境,并進(jìn)行測(cè)試,在測(cè)試結(jié)束后,將環(huán)境恢復(fù)原狀。
如何啟動(dòng)cypress測(cè)試?
- 在項(xiàng)目中安裝cypress 插件庫(kù)
- 在根目錄下可看見(jiàn)自動(dòng)生成的cypress文件夾以及cypress.config.ts,在cypress.config.ts中配置baseUrl等
- 編寫(xiě)測(cè)試:在cypress/e2e文件夾下編寫(xiě)測(cè)試用例
- 啟動(dòng)測(cè)試: 終端輸入 npx cypress open, 并選擇e2e,選擇瀏覽器,點(diǎn)擊需要測(cè)試的用例即可
了解目錄結(jié)構(gòu):
- e2e: 存放編寫(xiě)的測(cè)試用例
- support:cypress/support/index.js文件在每個(gè)規(guī)范文件之前運(yùn)行,比如有些動(dòng)作是適用于全局的,那么就可以放在這里。
- global.d.ts:存放編寫(xiě)測(cè)試用例中的typing,尤其是自定義的函數(shù)需要編寫(xiě)的ts都是存放在這里。
- fixtures:存放測(cè)試數(shù)據(jù)的地方,可以理解為放接口mock數(shù)據(jù)的地方
- plugins:存放插件,插件可以是自己編寫(xiě)的,也可以是第三方,插件是在項(xiàng)目加載之前、瀏覽器啟動(dòng)之前和測(cè)試執(zhí)行期間在Node中執(zhí)行用的。
- integration: 一般測(cè)試用例會(huì)寫(xiě)在integration下面,自帶官方示例測(cè)試用例文件。
- screenshot:當(dāng)測(cè)試發(fā)生錯(cuò)誤時(shí),cypress會(huì)自動(dòng)截圖并保存
- video:當(dāng)測(cè)試發(fā)生錯(cuò)誤時(shí),cypress會(huì)自動(dòng)錄屏并保存
- downloads: 存放測(cè)試過(guò)程中下載的文件
基礎(chǔ)概念
Cypress和cy的區(qū)別 cypress是一個(gè)全局對(duì)象,在整個(gè)測(cè)試的過(guò)程中會(huì)持續(xù)存在,當(dāng)你希望跟蹤整個(gè)程序未捕獲或者失敗事件時(shí),比較有用。(以下代碼是自定義的fail方法,可以在各個(gè)測(cè)試用例中使用)
Cypress.on('fail', (error, runnable) => {
throe error;
})
cy是單個(gè)測(cè)試的對(duì)象,它將綁定到每一個(gè)單獨(dú)測(cè)試中,并且,在完成這個(gè)測(cè)試后,自動(dòng)解綁和清理。
describe( )/context( ) 和 it( ) 對(duì)于一條可執(zhí)行的測(cè)試用例來(lái)說(shuō),describe()和it()是兩個(gè)必要的組成部分,describe()表示測(cè)試套件,context()是它的別名,可以直接用context()代替
鉤子函數(shù) - before() 運(yùn)行cypress時(shí),在開(kāi)始測(cè)試前都會(huì)調(diào)用這個(gè)鉤子函數(shù),在鉤子中,可以將接口代理到mock數(shù)據(jù) - after() 在所有用例跑完后運(yùn)行 - beforeEach() 每個(gè)用例開(kāi)始前都會(huì)運(yùn)行 - afterEach() 每個(gè)用例結(jié)束后運(yùn)行。有人會(huì)在這里寫(xiě)下以下代碼:
describe('loggout', () => {
beforeEach(() => {
cy.login();
})
afterEach(() => {
cy.logout();
})
})
這樣的行為可能是不必要的,原因是,當(dāng)測(cè)試用例跑完后,這些登錄狀態(tài)不僅在測(cè)試時(shí)被修改,而且會(huì)保存到程序的狀態(tài)中。意味著你測(cè)試完后退出登錄后,當(dāng)你運(yùn)行代碼時(shí),就會(huì)發(fā)現(xiàn)自己回到了登錄頁(yè)(cypress保存了你退出登錄的狀態(tài))。
使用場(chǎng)景:
如果你想要在不同的測(cè)試用例中共享同一個(gè)變量,你可以在before或beforeEach鉤子中定義這個(gè)變量,在隨后的用例中使用它。
在開(kāi)始測(cè)試前,準(zhǔn)備好測(cè)試環(huán)境(向后端發(fā)起請(qǐng)求,準(zhǔn)備好測(cè)試數(shù)據(jù),或者mock數(shù)據(jù))
以上就是一文詳解e2e測(cè)試之cypress的使用的詳細(xì)內(nèi)容,更多關(guān)于e2e測(cè)試cypress使用的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
js和jQuery以及easyui實(shí)現(xiàn)對(duì)下拉框的指定賦值方法
下面小編就為大家分享一篇js和jQuery以及easyui實(shí)現(xiàn)對(duì)下拉框的指定賦值方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-01-01
Javascript 使用function定義構(gòu)造函數(shù)
Javascript并不像Java、C#等語(yǔ)言那樣支持真正的類(lèi)。但是在js中可以定義偽類(lèi)。做到這一點(diǎn)的工具就是構(gòu)造函數(shù)和原型對(duì)象。首先介紹js中的構(gòu)造函數(shù)。2010-02-02
使用JavaScript腳本無(wú)法直接改變Asp.net中Checkbox控件的Enable屬性的解決方法
今天工作中遇到個(gè)小問(wèn)題,情況如下,當(dāng)我在后臺(tái)頁(yè)面中設(shè)置Checkbox的Enable的值為false時(shí),我在前端頁(yè)面中使用腳本(chk.disabled = false),無(wú)法改變disabled的值為false,下面看看小編是怎么解決此問(wèn)題的,需要的朋友一起了解了解吧2015-09-09
JS實(shí)現(xiàn)仿百度文庫(kù)評(píng)分功能
本文給大家分享基于js實(shí)現(xiàn)仿百度文庫(kù)評(píng)分功能,代碼簡(jiǎn)單易懂,非常不錯(cuò),具有參考借鑒價(jià)值,需要的的朋友參考下吧2017-01-01
JS運(yùn)算符優(yōu)先級(jí)與表達(dá)式示例詳解
這篇文章主要給大家介紹了關(guān)于JS運(yùn)算符優(yōu)先級(jí)與表達(dá)式的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09
javascript實(shí)現(xiàn)tab切換特效
這篇文章主要介紹了javascript實(shí)現(xiàn)tab切換特效,實(shí)現(xiàn)的方法很簡(jiǎn)單,特別適合初學(xué)者學(xué)習(xí)javascript實(shí)現(xiàn)tab切換特效,tab切換再也不是問(wèn)題,需要的朋友可以參考下2015-11-11
解析JavaScript中 querySelector 與 getElementById 方法的區(qū)別
這篇文章主要介紹了JavaScript中 querySelector 與 getElementById 方法的區(qū)別,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-10-10
uniapp?js修改數(shù)組某個(gè)下標(biāo)以外的所有值完整代碼
在UniApp開(kāi)發(fā)中,經(jīng)常需要對(duì)數(shù)組進(jìn)行操作,若要修改數(shù)組中特定下標(biāo)外的所有元素,可通過(guò)map方法或for循環(huán)實(shí)現(xiàn),map方法適用于生成新數(shù)組,for循環(huán)則直接修改原數(shù)組,根據(jù)項(xiàng)目需求選擇最佳方案,需要的朋友可以參考下2024-09-09

