欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

一文詳解e2e測試之cypress的使用

 更新時間:2023年04月24日 14:48:25   作者:今天比昨天更好哦  
這篇文章主要介紹了e2e測試之cypress的使用方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

用e2e測試想要達(dá)到什么目的?

  • 將被測試的單元放在特定環(huán)境下,選中并讓它發(fā)生交互,達(dá)到目標(biāo)結(jié)果。
  • 在測試之前,為測試用例創(chuàng)造它需要的環(huán)境,并進(jìn)行測試,在測試結(jié)束后,將環(huán)境恢復(fù)原狀。

如何啟動cypress測試?

  • 在項(xiàng)目中安裝cypress 插件庫
  • 在根目錄下可看見自動生成的cypress文件夾以及cypress.config.ts,在cypress.config.ts中配置baseUrl等
  • 編寫測試:在cypress/e2e文件夾下編寫測試用例
  • 啟動測試: 終端輸入 npx cypress open, 并選擇e2e,選擇瀏覽器,點(diǎn)擊需要測試的用例即可

了解目錄結(jié)構(gòu):

  • e2e: 存放編寫的測試用例
  • support:cypress/support/index.js文件在每個規(guī)范文件之前運(yùn)行,比如有些動作是適用于全局的,那么就可以放在這里。
  • global.d.ts:存放編寫測試用例中的typing,尤其是自定義的函數(shù)需要編寫的ts都是存放在這里。
  • fixtures:存放測試數(shù)據(jù)的地方,可以理解為放接口mock數(shù)據(jù)的地方
  • plugins:存放插件,插件可以是自己編寫的,也可以是第三方,插件是在項(xiàng)目加載之前、瀏覽器啟動之前和測試執(zhí)行期間在Node中執(zhí)行用的。
  • integration: 一般測試用例會寫在integration下面,自帶官方示例測試用例文件。
  • screenshot:當(dāng)測試發(fā)生錯誤時,cypress會自動截圖并保存
  • video:當(dāng)測試發(fā)生錯誤時,cypress會自動錄屏并保存
  • downloads: 存放測試過程中下載的文件

基礎(chǔ)概念

Cypress和cy的區(qū)別 cypress是一個全局對象,在整個測試的過程中會持續(xù)存在,當(dāng)你希望跟蹤整個程序未捕獲或者失敗事件時,比較有用。(以下代碼是自定義的fail方法,可以在各個測試用例中使用)

	Cypress.on('fail', (error, runnable) => {
		throe error;
	})

cy是單個測試的對象,它將綁定到每一個單獨(dú)測試中,并且,在完成這個測試后,自動解綁和清理。

describe( )/context( ) 和 it( ) 對于一條可執(zhí)行的測試用例來說,describe()和it()是兩個必要的組成部分,describe()表示測試套件,context()是它的別名,可以直接用context()代替

鉤子函數(shù) - before() 運(yùn)行cypress時,在開始測試前都會調(diào)用這個鉤子函數(shù),在鉤子中,可以將接口代理到mock數(shù)據(jù) - after() 在所有用例跑完后運(yùn)行 - beforeEach() 每個用例開始前都會運(yùn)行 - afterEach() 每個用例結(jié)束后運(yùn)行。有人會在這里寫下以下代碼:

	describe('loggout', () => {
		beforeEach(() => {
			cy.login();
		})
	
		afterEach(() => {
			cy.logout();
		})
	})

這樣的行為可能是不必要的,原因是,當(dāng)測試用例跑完后,這些登錄狀態(tài)不僅在測試時被修改,而且會保存到程序的狀態(tài)中。意味著你測試完后退出登錄后,當(dāng)你運(yùn)行代碼時,就會發(fā)現(xiàn)自己回到了登錄頁(cypress保存了你退出登錄的狀態(tài))。

使用場景:

如果你想要在不同的測試用例中共享同一個變量,你可以在before或beforeEach鉤子中定義這個變量,在隨后的用例中使用它。

在開始測試前,準(zhǔn)備好測試環(huán)境(向后端發(fā)起請求,準(zhǔn)備好測試數(shù)據(jù),或者mock數(shù)據(jù))

以上就是一文詳解e2e測試之cypress的使用的詳細(xì)內(nèi)容,更多關(guān)于e2e測試cypress使用的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

最新評論