摘要:約定我們假定要被測試的頁面是這樣的標(biāo)題開始編寫測試首先是導(dǎo)入。我們推薦使用的語法當(dāng)然您也可以用方式第一件事是構(gòu)造一個實例然后要轉(zhuǎn)到要被測試的頁面。
之前我曾經(jīng)在《Rize - 一個可以讓你簡單、優(yōu)雅地使用 puppeteer 的 Node.js 庫》一文簡單介紹過 Rize 這個庫。當(dāng)時僅僅是介紹這個庫本身,關(guān)于如何使用,我沒有給太多的指導(dǎo)。
這篇文章講的是如何使用 Rize 來做 UI 測試或 E2E 測試。
在正式開始之前,先給可能沒了解過 Rize 的同學(xué)做個簡單的介紹:Rize 是一個提供了相對頂層并且可鏈?zhǔn)秸{(diào)用的 API 的庫,可與 puppeteer 一起使用。目前開源在 GitHub,地址是 https://github.com/g-plane/rize,歡迎大家前往 GitHub 給個 star。
安裝首先是安裝 Rize 和 puppeteer。
如果您使用 Yarn:
$ yarn add --dev rize puppeteer
如果您使用 npm:
$ npm install --save-dev rize puppeteer
考慮到國內(nèi)的網(wǎng)絡(luò)原因,您可能需要使用國內(nèi)的 Chromium 鏡像:
對于 Linux 或 macOS 用戶:
PUPPETEER_DOWNLOAD_HOST=https://storage.googleapis.com.cnpmjs.org yarn add --dev puppeteer rize
Windows 用戶:
SET PUPPETEER_DOWNLOAD_HOST=https://storage.googleapis.com.cnpmjs.org yarn add --dev puppeteer rize
(npm 用戶同理)
由于安裝 puppeteer 的時候會下載 Chromium,所以整個過程可能比較費時,需要耐心等待。
約定我們假定要被測試的頁面是這樣的:
開始編寫測試標(biāo)題 Hello World!Another Page
首先是導(dǎo)入。我們推薦使用 ES2015 的 import 語法:
import Rize from "rize"
當(dāng)然您也可以用 CommonJS 方式:
const Rize = require("rize")
第一件事是構(gòu)造一個 Rize 實例:
describe("UI test", () => { it("example test", async () => { const rize = new Rize() }) })
然后要轉(zhuǎn)到要被測試的頁面。我們假定前面設(shè)定的頁面運行在 http://localhost:8000/ 上,那么我們可以:
describe("UI test", () => { it("example test", async () => { const rize = new Rize() rize .goto("http://localhost:8000/") }) })斷言 斷言頁面標(biāo)題
我們可以使用 assertTitle 方法來斷言當(dāng)前頁面的標(biāo)題:
describe("UI test", () => { it("example test", async () => { const rize = new Rize() rize .goto("http://localhost:8000/") .assertTitle("標(biāo)題") }) })斷言文本內(nèi)容
可以使用 assertTitle 方法來斷言當(dāng)前頁面存在指定的文本:
describe("UI test", () => { it("example test", async () => { const rize = new Rize() rize .goto("http://localhost:8000/") .assertTitle("標(biāo)題") .assertSee("Hello World!") }) })
我們還可以明確在某個元素中存在指定文本,只需給出該元素的 CSS 選擇器即可:
describe("UI test", () => { it("example test", async () => { const rize = new Rize() rize .goto("http://localhost:8000/") .assertTitle("標(biāo)題") .assertSee("Hello World!") .assertSeeIn(".greeting", "Hello World!") }) })斷言是否存在指定的類名
我們可以斷言某個元素存在指定的類名:
describe("UI test", () => { it("example test", async () => { const rize = new Rize() rize .goto("http://localhost:8000/") .assertTitle("標(biāo)題") .assertSee("Hello World!") .assertSeeIn(".greeting", "Hello World!") .assertClassHas("div", "greeting") }) })
還可以斷言不存在指定的類名:
describe("UI test", () => { it("example test", async () => { const rize = new Rize() rize .goto("http://localhost:8000/") .assertTitle("標(biāo)題") .assertSee("Hello World!") .assertSeeIn(".greeting", "Hello World!") .assertClassHas("div", "greeting") .assertClassMissing("div", "greet") }) })斷言表單狀態(tài)
我們可以斷言一些表單控件的狀態(tài),例如復(fù)選框(checkbox)選中或未選中:
describe("UI test", () => { it("example test", async () => { const rize = new Rize() rize .goto("http://localhost:8000/") .assertTitle("標(biāo)題") .assertSee("Hello World!") .assertSeeIn(".greeting", "Hello World!") .assertClassHas("div", "greeting") .assertClassMissing("div", "greet") .assertChecked("[name="cb1"]") // 斷言已選中 .assertNotChecked("[name="cb2"]") // 斷言未選中 }) })與頁面交互
在實際測試的過程中,我們不僅僅需要進行一些斷言,還需要與頁面進行交互。
例如,我們以上面的頁面為例,我們可以單擊那個按鈕:
describe("UI test", () => { it("example test", async () => { const rize = new Rize() rize .goto("http://localhost:8000/") .assertTitle("標(biāo)題") .assertSee("Hello World!") .assertSeeIn(".greeting", "Hello World!") .assertClassHas("div", "greeting") .assertClassMissing("div", "greet") .assertChecked("[name="cb1"]") // 斷言已選中 .assertNotChecked("[name="cb2"]") // 斷言未選中 .click("#btn") }) })
也可以單擊某個鏈接,我們只需要給出該鏈接上的文本:
describe("UI test", () => { it("example test", async () => { const rize = new Rize() rize .goto("http://localhost:8000/") .assertTitle("標(biāo)題") .assertSee("Hello World!") .assertSeeIn(".greeting", "Hello World!") .assertClassHas("div", "greeting") .assertClassMissing("div", "greet") .assertChecked("[name="cb1"]") // 斷言已選中 .assertNotChecked("[name="cb2"]") // 斷言未選中 .click("#btn") .clickLink("Another Page") }) })
當(dāng)然,我們還能與表單進行交互。例如,勾選某個復(fù)選框:
describe("UI test", () => { it("example test", async () => { const rize = new Rize() rize .goto("http://localhost:8000/") .assertTitle("標(biāo)題") .assertSee("Hello World!") .assertSeeIn(".greeting", "Hello World!") .assertClassHas("div", "greeting") .assertClassMissing("div", "greet") .assertChecked("[name="cb1"]") // 斷言已選中 .assertNotChecked("[name="cb2"]") // 斷言未選中 .click("#btn") .clickLink("Another Page") .check("[name="cb2"]") }) })
或者取消勾選某個復(fù)選框:
describe("UI test", () => { it("example test", async () => { const rize = new Rize() rize .goto("http://localhost:8000/") .assertTitle("標(biāo)題") .assertSee("Hello World!") .assertSeeIn(".greeting", "Hello World!") .assertClassHas("div", "greeting") .assertClassMissing("div", "greet") .assertChecked("[name="cb1"]") // 斷言已選中 .assertNotChecked("[name="cb2"]") // 斷言未選中 .click("#btn") .clickLink("Another Page") .check("[name="cb2"]") .uncheck("[name="cb1"]") }) })關(guān)閉瀏覽器
在完成所有工作之后,需要退出瀏覽器:
describe("UI test", () => { it("example test", async () => { const rize = new Rize() rize .goto("http://localhost:8000/") .assertTitle("標(biāo)題") .assertSee("Hello World!") .assertSeeIn(".greeting", "Hello World!") .assertClassHas("div", "greeting") .assertClassMissing("div", "greet") .assertChecked("[name="cb1"]") // 斷言已選中 .assertNotChecked("[name="cb2"]") // 斷言未選中 .click("#btn") .clickLink("Another Page") .check("[name="cb2"]") .uncheck("[name="cb1"]") await rize.end() }) })更多
實際上 Rize 的功能遠(yuǎn)不只上面那些。想要獲取更多信息,可以前往以下頁面:
Rize 的 GitHub 倉庫:https://github.com/g-plane/rize (歡迎 star)
Rize 的文檔教程:https://rize.js.org/
Rize 所有的 API 參考:https://rize.js.org/api/classes/_index_.rize.html
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://specialneedsforspecialkids.com/yun/52012.html
摘要:約定我們假定要被測試的頁面是這樣的標(biāo)題開始編寫測試首先是導(dǎo)入。我們推薦使用的語法當(dāng)然您也可以用方式第一件事是構(gòu)造一個實例然后要轉(zhuǎn)到要被測試的頁面。 之前我曾經(jīng)在《Rize - 一個可以讓你簡單、優(yōu)雅地使用 puppeteer 的 Node.js 庫》一文簡單介紹過 Rize 這個庫。當(dāng)時僅僅是介紹這個庫本身,關(guān)于如何使用,我沒有給太多的指導(dǎo)。 這篇文章講的是如何使用 Rize 來做 U...
摘要:約定我們假定要被測試的頁面是這樣的標(biāo)題開始編寫測試首先是導(dǎo)入。我們推薦使用的語法當(dāng)然您也可以用方式第一件事是構(gòu)造一個實例然后要轉(zhuǎn)到要被測試的頁面。 之前我曾經(jīng)在《Rize - 一個可以讓你簡單、優(yōu)雅地使用 puppeteer 的 Node.js 庫》一文簡單介紹過 Rize 這個庫。當(dāng)時僅僅是介紹這個庫本身,關(guān)于如何使用,我沒有給太多的指導(dǎo)。 這篇文章講的是如何使用 Rize 來做 U...
摘要:目前已經(jīng)成為了非常流行的的庫,被廣泛用于爬蟲或測試。然而,的幾乎所有的都是異步的,它返回的是一個。而提供了一系列的,使得測試變得簡單方便,測試同樣沒有問題。更多的可以參考的文檔鏈接在下方。 目前 puppeteer 已經(jīng)成為了非常流行的 Node.js 的庫,被廣泛用于爬蟲或 UI 測試。 我也很歡喜 puppeteer 這個庫。然而,puppeteer 的幾乎所有的 API 都是異步...
摘要:目前已經(jīng)成為了非常流行的的庫,被廣泛用于爬蟲或測試。然而,的幾乎所有的都是異步的,它返回的是一個。而提供了一系列的,使得測試變得簡單方便,測試同樣沒有問題。更多的可以參考的文檔鏈接在下方。 目前 puppeteer 已經(jīng)成為了非常流行的 Node.js 的庫,被廣泛用于爬蟲或 UI 測試。 我也很歡喜 puppeteer 這個庫。然而,puppeteer 的幾乎所有的 API 都是異步...
摘要:與其它自動化測試不同,前端的測試一直是個老大難問題,難點主要在于如何描述測試。自動化測試的核心是檢查特定輸入能不能得到符合預(yù)期的結(jié)果。結(jié)構(gòu)不能反應(yīng)視圖的真實狀態(tài),很可能會出現(xiàn)雖然測試通過,但實際上在用戶眼里仍然是錯誤的表現(xiàn)。 與其它自動化測試不同,前端的 E2E 測試一直是個老大難問題,難點主要在于 如何描述測試。 自動化測試的核心是檢查特定輸入能不能得到符合預(yù)期的結(jié)果。對于單元測試和...
閱讀 693·2021-11-18 10:07
閱讀 2884·2021-09-22 16:04
閱讀 884·2021-08-16 10:50
閱讀 3346·2019-08-30 15:56
閱讀 1790·2019-08-29 13:22
閱讀 2667·2019-08-26 17:15
閱讀 1239·2019-08-26 10:57
閱讀 1111·2019-08-23 15:23