web-e2e-gui v1.1.2
Table Of Contents
Summary
WEB-E2E-GUI 是以 Protractor 為主的可介面操作 E2E 測試工具。
目標與定位是在中小型專案,大多是人手不足的情況下(大多時候專案只有兩位人員)能夠平均分擔 QA 的部分,
如果是大型專案或有專門進行 QA 的團隊基本上可以無視本工具。
WEG有以下特點:
- 能夠輸出序列化檔案,利於工程師與其他專案管理人員交流。 
- 最終結果仍是輸出 - Protractor專案,就算捨棄 GUI 工具也能擁有原生的 E2E 測試檔案。
- 進行測試時可以看到美麗的測試 Log。 
- 可視化與可自定義操作的按鈕介面。 
安裝
WEG仍是較為工程師導向的工具,你必須安裝 NodeJs 才能正常運作。
# 安裝
npm install web-e2e-gui -g
# 執行
weg建議
JavaScript
雖然盡可能的使用可視化按鍵來操作,但不用幻想不會 JavaScript 也能暢用 WEG,沒有 Node 的操作經驗大概在安裝就會卡關。
Protractor
由於所有的程式碼都在 Protractor(jasmine) 中執行,理解其判斷方式與邏輯有助於寫出良好的測試。
Protractor是源於Angular的測試工具,但本工具只借用其自動化測試功能,在運行時會關閉Angular的檢測。
邏輯測試應該通通由Javascript編寫
有時候需要複雜的邏輯驗證,建議直接編寫 JavaScript,因此建議由工程師先行編寫測試,再由其他專案負責人補足應用方的應用操作。
操作手冊
應用Store
所有的Spec中都有一個全局且獨立的 store 物件,可以藉由該物件進行誇模板的測試:


運行結果:

使用變數
你可以在工具列上看到 (x) 的按鈕,點擊後會出現變數編輯畫面。
在所有文字輸出之後,WEG 會將 {key} 轉換成 Protractor Params:


it('輸出結果', async function() {
    console.log('執行 => C')
    await browser.sleep(120)
    await (async () => {
        console.log('動作 => 驗證網址 包含 {baseUrl}')
        await expect(await browser.getCurrentUrl()).toMatch(`${browser.params['baseUrl']}`)
        await browser.sleep(100)
    })()
})自定義按鈕
你需要理解 JavaScript 才能開始自訂按鈕,點擊自定義按鈕後可以建立一個按鈕並創造一個範例:
{
    // 短說明
    info: '短說明',
    // 點擊Help按鈕時出現的詳細說明,支援HTML格式
    help: '詳細說明',
    // 本按鈕的主題顏色
    color: '#000000',
    // 按鈕上的文字
    btnText: '按鈕文字',
    // 選項
    props: {
        value: {
            type: 'text',
            info: '毫秒',
            default: '1000'
        }
    },
    // 在模板與測試訊息中出現的文字
    display(props) {
        return '等待' + props.value + '毫秒'
    },
    // 驗證Props的格式是否正確,回傳字串代表錯誤
    validate(props) {
        let result = Number(props.value)
        if (isNaN(result)) {
            return '必須為數字'
        } else {
            return true
        }
    },
    // 輸出成Protractor的文本,注意要使用變數的字串必須使用``包裹起來。
    write(props) {
        return 'await browser.sleep(' + props.value + ')'
    }
}輸出結果
所有由 write 返回的結果都會輸出在一個 async 閉包內,因此你可以較大膽地宣告一些行為,輸出如下:
await (async () => {
    console.log('動作 => 等待 1000 毫秒')
    await browser.sleep(1000)
    await browser.sleep(100) // 每個動作都會間格100毫秒
})()其實 WEG 就是將模板轉化成程式碼的工具而已。
Event
有些功能比較難在 Node 中實現,例如:多媒體,此時可以藉由 console.log('@event:{my-event}') 推播 event 給瀏覽器知道:
play-sound
要求播放聲音:
write(props) {
    return `console.log('@event:play-sound')`
}選項列表
Porp 是使用者操作的核心目標,各類行所需要的屬性如下:
text
顯示單行文字輸入框。
{
    type: 'text',
    info: 'label', // 文字框說明
    show: (props) => { return Boolean }, // 回傳true即顯示
    default: 'hello world.' // 預設值
}radio-group
顯示多個選項。
{
    type: 'radio-group',
    info: 'label', // 選項說明
    // 顯示的選項,text是顯示文字,value是選取的值
    options: [
        {
            text: '新增',
            value: 'add'            
        },
        {
            text: '清除',
            value: 'clear'  
        }
    ],
    show: (props) => { return Boolean }, // 回傳true即顯示
    default: 'clear' // 預設值
}javascript
javascript 的文字編輯器。
{
    type: 'javascript',
    info: 'editor', // 編輯器說明
    show: (props) => { return Boolean }, // 回傳true即顯示
    default: '{}' // 預設值
}