摘要:好的單元測試全面的功能拋錯和邊緣覆蓋可以成為項目開發或修改完成后是否能安全上線的重要判斷依據之一。目前國內外的云測試工具和方案有很多,因為云測試的實質是運行遠程虛擬機,需要大量的服務器和齊全的設備,所以大多數都是收費的。
關于單元測試
前端的單元測試也可以稱為自動化測試,測試驅動開發,單元測試對于前端模塊化、框架和功能庫的開發是非常有必要的,只要做好模塊的解耦和功能劃分,單元測試就可以愉快地進行。好的單元測試(全面的功能、拋錯和邊緣覆蓋)可以成為項目開發或修改完成后是否能“安全上線”的重要判斷依據之一。
引進跨平臺測試開發和運行單元測試通常是在開發人員的電腦上完成,而任何一臺電腦上所能安裝的瀏覽器是遠遠不能滿足測試兼容性需求的,如果需要配備各種平臺的電腦也是非常浪費人力物力。那么有沒有工具能自動把本地的測試代碼在所有平臺上都跑一遍,并且追蹤完整的測試過程,把 log 信息反饋回本地?有!那就是云測試工具。
目前國內外的云測試工具和方案有很多,因為云測試的實質是運行遠程虛擬機,需要大量的服務器和齊全的設備,所以大多數都是收費的。這里推薦 SauceLabs,它雖然也是收費的,但是新注冊的賬號可以提供 8 個并發測試,免費 90 個小時的自動測試時長,而且操作簡單,用戶體驗非常友好,很多著名的前端框架比如 Vue 等也在使用它進行兼容性測試。
這篇文章就詳細介紹一下如何利用 SauceLabs 這個云測試工具進行跨平臺的 JavaScript 單元測試,讓你的代碼可以輕松的通過所有版本的 Windows IE, Mac Safari 以及各種移動設備瀏覽器的測試評估,測試后還可以生成瀏覽器測試狀態矩陣圖:
主流的 JavaScript 測試框架在 SauceLabs 上都有文檔和配置說明,其中 Karma 是配置最為簡單易懂的測試框架之一,下文就詳細介紹下 Karma + SauceLabs 進行跨平臺單元測試的整個流程,以及我自己在使用中遇到的一些問題和解決方法,如果你不用 Karma,可以在 這里 查找其他測試框架的配置方法。
以下步驟的前提是你已經寫好了測試用例,如果你還不知道如何編寫和組織單元測試,可以參考 js-test-workflows 的簡單例子來開始學習 JavaScript 單元測試。
配置步驟 1. 安裝 Karma整個 SauceLabs 測試都是基于 Karma 配置文件 karma.sauce.js 完成的,通過插件 karma-sauce-launcher 自動完成遠程服務器的連接和測試代碼的提交。如果你的項目已經配備好了 Karma 和斷言庫,可以忽略此步驟。
安裝測試框架 Karma
npm install karma -g
安裝測試斷言庫 jasmine (也可以選擇其他庫如 assert, should 等)
npm install karma-jasmine2. 安裝 karma-sauce-launcher
這個工具是讓 Karma 和 SauceLabs 建立連接的橋梁,它的作用是把本地的測試代碼提交到云端測試虛擬機上,告訴 SauceLabs 要啟動哪個系統哪個版本的瀏覽器來跑我們的測試代碼,并且把測試結果、錯誤信息和追蹤棧返回到本地的終端,一旦測試不通過,可以根據返回的信息來調試出錯的代碼。
npm install karma-sauce-launcher --save-dev3. 注冊 SauceLabs 并獲取 accessKey
SauceLabs 免費注冊地址:https://saucelabs.com/signup/...
注冊完成后,登陸賬號,進入 Dashboard, 點擊右下角的用戶名,彈出菜單選擇 User Setting 進入用戶設置:
找到 USERNAME 和 Access Key:
在項目目錄下建立一個 sauce.json 文件來記錄上面的 userName 和 accessKey,這兩個字段的作用是連接 SauceLabs 服務器的身份驗證。
{ "username": "xxxx", "accesskey": "xxx" }4. 編寫測試配置文件
在項目目錄下添加測試配置文件 karma.sauce.js 該文件是整個跨平臺測試的主要文件,也是 Karma 的入口文件,配置內容如下:
var sauce = require("./sauce.json"); // 引進 userName 和 key // 生成一個 SauceLabs 瀏覽器配置信息,可以指定運行的系統和瀏覽器版本 function createCustomLauncher (browser, platform, version) { return { base: "SauceLabs", browserName: browser, platform: platform, version: version }; } // 定義所有需要在云端測試的平臺和瀏覽器 // 名字的定義是隨意的,SauceLabs 只會根據配置內容來啟動對應的瀏覽器 // 所有完整的平臺設備列表:https://saucelabs.com/platforms var customLaunchers = { // 主流瀏覽器 sl_win_chrome: createCustomLauncher("chrome", "Windows 7"), sl_mac_chrome: createCustomLauncher("chrome", "OS X 10.10"), sl_win_firefox: createCustomLauncher("firefox", "Windows 7"), sl_mac_firefox: createCustomLauncher("firefox", "OS X 10.10"), sl_mac_safari: createCustomLauncher("safari", "OS X 10.11"), // 移動設備瀏覽器 sl_ios_8_safari: createCustomLauncher("iphone", null, "8.4"), sl_ios_9_safari: createCustomLauncher("iphone", null, "9.3"), sl_android_4_2: createCustomLauncher("android", null, "4.2"), sl_android_5_1: createCustomLauncher("android", null, "5.1"), // Microsoft Edge sl_edge: createCustomLauncher("MicrosoftEdge", "Windows 10"), // IE 瀏覽器 sl_ie_9: createCustomLauncher("internet explorer", "Windows 7", "9"), sl_ie_10: createCustomLauncher("internet explorer", "Windows 8", "10"), sl_ie_11: createCustomLauncher("internet explorer", "Windows 10", "11") }; // Karma 配置參數 // https://karma-runner.github.io/1.0/config/configuration-file.html module.exports = function (KarmaConfig) { // 將 SauceLabs 提供的 username 和 accesskey 放到環境變量中 if (!process.env.SAUCE_USERNAME || !process.env.SAUCE_ACCESS_KEY) { process.env.SAUCE_USERNAME = sauce.username; process.env.SAUCE_ACCESS_KEY = sauce.accesskey; } // 設置測試的超時時間 var maxExecuteTime = 5*60*1000; KarmaConfig.set({ // 加載測試文件的根目錄 basePath: "", // 使用的斷言庫 frameworks: ["jasmine"], // 告訴 Karma 要將哪些 js 文件加載到瀏覽器運行測試 files: [ "../src/**/*.js", "../test/**/*.js" ], // SauceLabs 的配置,這里只需要配置幾個重要的字段即可,完整的字段可以參考: // https://wiki.saucelabs.com/display/DOCS/Test+Configuration+Options sauceLabs: { // 測試結果是否公開,如果希望生成矩陣圖,必須是 public public: "public", // 是否在測試過程記錄虛擬機的運行錄像 recordVideo: false, // 是否在測試過程記錄虛擬機的圖像 recordScreenshots: false, // 測試名稱 testName: "Cross browsers test", // 測試的記錄號,可以為任意字符,如果希望生成矩陣圖,build 不能為空 build: "build-" + Date.now() }, // 自定義運行測試的 SauceLabs 瀏覽器 customLaunchers: customLaunchers, browsers: Object.keys(customLaunchers), // 測試處理的報告程序 reporters: ["progress", "saucelabs"], // 最大超時時間 captureTimeout: maxExecuteTime, browserNoActivityTimeout: maxExecuteTime }); }5. 啟動 SauceLabs 測試
在終端輸入:
karma start karma.sauce.js
本地的測試代碼就會在 SauceLabs 云端跑起來了,注意的一點是,雖然免費用戶只有 8 個并發的測試連接,但并不意味著一次只能測試 8 種瀏覽器,上面的 customLaunchers 一共定義了 13 中不同的瀏覽器,他們會先執行 8 個,空閑后再執行余下的,直至全部運行完畢。
云端測試完畢后的信息如下:
Chrome 54.0.2840 (Windows 7 0.0.0): Executed 143 of 143 SUCCESS (1.365 secs / 1.176 secs) IE 10.0.0 (Windows 8 0.0.0): Executed 143 of 143 SUCCESS (1.313 secs / 1.118 secs) IE 9.0.0 (Windows 7 0.0.0): Executed 143 of 143 SUCCESS (1.312 secs / 1.113 secs) Firefox 47.0.0 (Mac OS X 10.10.0): Executed 143 of 143 SUCCESS (2.016 secs / 2.058 secs) Chrome 54.0.2840 (Mac OS X 10.10.5): Executed 143 of 143 SUCCESS (1.724 secs / 1.485 secs) Chrome 54.0.2840 (Windows 7 0.0.0): Executed 143 of 143 SUCCESS (1.365 secs / 1.176 secs) IE 10.0.0 (Windows 8 0.0.0): Executed 143 of 143 SUCCESS (1.313 secs / 1.118 secs) IE 9.0.0 (Windows 7 0.0.0): Executed 143 of 143 SUCCESS (1.312 secs / 1.113 secs) Firefox 47.0.0 (Mac OS X 10.10.0): Executed 143 of 143 SUCCESS (2.016 secs / 2.058 secs) Chrome 54.0.2840 (Mac OS X 10.10.5): Executed 143 of 143 SUCCESS (1.724 secs / 1.485 secs) IE 11.0.0 (Windows 10 0.0.0): Executed 143 of 143 SUCCESS (2.584 secs / 1.262 secs) Firefox 49.0.0 (Windows 7 0.0.0): Executed 143 of 143 SUCCESS (2.3 secs / 1.25 secs) Safari 9.1.2 (Mac OS X 10.11.6): Executed 143 of 143 SUCCESS (1.164 secs / 1.173 secs) Edge 14.14393.0 (Windows 10 0.0.0): Executed 143 of 143 SUCCESS (1.441 secs / 1.301 secs) Chrome Mobile 39.0.0 (Android 5.1.0): Executed 143 of 143 SUCCESS (1.815 secs / 1.52 secs) Android 4.2.0 (Android 4.2.0): Executed 143 of 143 SUCCESS (1.727 secs / 1.153 secs) Mobile Safari 9.0.0 (iOS 9.3.0): Executed 143 of 143 SUCCESS (2.328 secs / 1.061 secs)6. 獲取測試狀態和矩陣圖
等所有瀏覽器都運行測試完畢后 SauceLabs 會生成狀態和矩陣 svg 方便檢查和公布代碼測試狀態,也可以在 https://saucelabs.com/u/YOUR_... 上查看狀態結果。
狀態圖標
瀏覽器矩陣圖
然后可以把這兩個狀態圖標放到項目的 README 中,讓人一看就知道目前項目的測試狀態和瀏覽器兼容性了(SauceLabs 的 svg 的更新有點慢):
總結簡單總結下 SauceLabs 的優點:
提供幾百種平臺設備,基本上可以滿足所有的兼容性測試需求;
配合 Karma 進行單元測試,操作簡單易于部署;
提供測試、錯誤信息的及時反饋,便于查找錯誤;
免費使用 90 個小時的測試時長!
另外,分享下我自己使用 SauceLabs 遇到的幾個問題:
偶爾遇到 Disconnect 和 Timeout 的情況,可能是由于國內網絡原因,多試幾次就好了。
配置參數里面的 captureTimeout 和 browserNoActivityTimeout 可以設得稍長些,有些連接超時也是因為這兩個的默認時長太小了,另外如果不需要記錄錄像和圖像,可以將 recordVideo 和 recordScreenshots 設為 false 可以縮短運行時間。
如果總是遇到 Disconnect 的情況,一個就是可能你的代碼有問題(有些錯誤警告在某些瀏覽器下是不會拋出的,比如 Safari)還有一個就是 Karma 的版本問題,v0.13.x 經常出現鏈接超時,升到最新版本即可。
對于錯誤產生的 Disconnect 并且沒有拋錯的情況,可以安裝 karma-spec-launcher 并且把 Karma 的測試處理報告程序改成 reporters: ["spec", "saucelabs"] 這樣就可以在終端很清晰的看到運行到哪個測試用例導致的 Disconnect,方便排查出錯的地方。
如果是開源項目,記得把 sauce.json 文件放到 .gitignore 中,不要暴露你的 AccessKey 到 git 提交中。
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/91027.html
摘要:手把手教你做個人火的時候,隨便一個都能賺的盆滿缽滿,但是,個人沒有服務端,沒有美工,似乎就不能開發了,真的是這樣的嗎秘密花園經典的中文手冊。涵蓋前端知識體系知識結構圖書推薦以及入門視頻教程,全的簡直不要不要的了。 JavaScript 實現點擊按鈕復制指定區域文本 html5 的 webAPI 接口可以很輕松的使用短短的幾行代碼就實現點擊按鈕復制區域文本的功能,不需要依賴 flash。...
摘要:在有了基礎之后,進一步學習內容包括框架。前端學習交流群禁止閑聊,非喜勿進。代碼提交前必須做的三個事情檢查所有變更跑一邊單元測試手動運行一遍所有 網站開發開發大致分為前端和后端,前端主要負責實現視覺和交互效果,以及與服務器通信,完成業務邏輯。其核心價值在于對用戶體驗的追求。可以按如下思路學習系統學習: 基礎知識: html + css 這部分建議在?w3school 在線教程上學習,邊...
摘要:在有了基礎之后,進一步學習內容包括框架。前端學習交流群禁止閑聊,非喜勿進。代碼提交前必須做的三個事情檢查所有變更跑一邊單元測試手動運行一遍所有 網站開發開發大致分為前端和后端,前端主要負責實現視覺和交互效果,以及與服務器通信,完成業務邏輯。其核心價值在于對用戶體驗的追求。可以按如下思路學習系統學習: 基礎知識: html + css 這部分建議在?w3school 在線教程上學習,邊...
摘要:幸運的是,為了完成獨特的任務,無以計數的工具已經被開發者發布。圖像顯示的是一個針對該框架的在線開發工具。是用創建的命令行工具,用于壓縮文件。是一組處理所有跟文件相關的工作的組件庫。是一個基于任務的命令行項目構建工具。 JavaScript是一種靈活多變的腳本語言,它在全世界被廣泛的應用在Web頁面和服務器應用中。你可以因為任何目的去使用它,但是你需要一些工具。幸運的是,為了完成獨特的任...
閱讀 1304·2021-10-08 10:05
閱讀 4127·2021-09-22 15:54
閱讀 3113·2021-08-27 16:18
閱讀 3112·2019-08-30 15:55
閱讀 1445·2019-08-29 12:54
閱讀 2754·2019-08-26 11:42
閱讀 550·2019-08-26 11:39
閱讀 2134·2019-08-26 10:11