Linux中國

使用 Headless Chrome 進行自動化測試

如果你想使用 Headless Chrome 進行自動化測試,那麼就往下!這篇文章將讓你完全使用 Karma 作為 運行器 runner ,並且使用 Mocha+Chai 來編撰測試。

這些東西是什麼?

Karma、Mocha、Chai、Headless Chrome,哦,我的天哪!

Karma 是一個測試工具,可以和所有最流行的測試框架(JasmineMochaQUnit)配合使用。

Chai 是一個斷言庫,可以與 Node 和瀏覽器一起使用。這裡我們需要後者。

Headless Chrome 是一種在沒有瀏覽器用戶界面的無需顯示環境中運行 Chrome 瀏覽器的方法。使用 Headless Chrome(而不是直接在 Node 中測試) 的一個好處是 JavaScript 測試將在與你的網站用戶相同的環境中執行。Headless Chrome 為你提供了真正的瀏覽器環境,卻沒有運行完整版本的 Chrome 一樣的內存開銷。

設置

安裝

使用 yarn 安裝 Karma、相關插件和測試用例:

yarn add --dev karma karma-chrome-launcher karma-mocha karma-chai
yarn add --dev mocha chai

或者使用 npm

npm i --save-dev karma karma-chrome-launcher karma-mocha karma-chai
npm i --save-dev mocha chai

在這篇文章中我使用 MochaChai,但是你也可以選擇自己最喜歡的在瀏覽器中工作的斷言庫。

配置 Karma

創建一個使用 ChromeHeadless 啟動器的 karma.config.js 文件。

karma.conf.js

module.exports = function(config) {
  config.set({
    frameworks: ['mocha', 'chai'],
    files: ['test/**/*.js'],
    reporters: ['progress'],
    port: 9876,  // karma web server port
    colors: true,
    logLevel: config.LOG_INFO,
    browsers: ['ChromeHeadless'],
    autoWatch: false,
    // singleRun: false, // Karma captures browsers, runs the tests and exits
    concurrency: Infinity
  })
}

注意: 運行 ./node_modules/karma/bin/karma init karma.conf.js 生成 Karma 的配置文件。

寫一個測試

/test/test.js 中寫一個測試:

/test/test.js

describe('Array', () => {
  describe('#indexOf()', () => {
    it('should return -1 when the value is not present', () => {
      assert.equal(-1, [1,2,3].indexOf(4));
    });
  });
});

運行你的測試

在我們設置好用於運行 Karma 的 package.json 中添加一個測試腳本。

package.json

"scripts": {
  "test": "karma start --single-run --browsers ChromeHeadless karma.conf.js"
}

當你運行你的測試(yarn test)時,Headless Chrome 會啟動並將運行結果輸出到終端:

創建你自己的 Headless Chrome 啟動器

ChromeHeadless 啟動器非常棒,因為它可以在 Headless Chrome 上進行測試。它包含了適合你的 Chrome 標誌,並在埠 9222 上啟動 Chrome 的遠程調試版本。

但是,有時你可能希望將自定義的標誌傳遞給 Chrome 或更改啟動器使用的遠程調試埠。要做到這一點,可以通過創建一個 customLaunchers 欄位來擴展基礎的 ChromeHeadless 啟動器:

karma.conf.js

module.exports = function(config) {
  ...

  config.set({
    browsers: ['Chrome', 'ChromeHeadless', 'MyHeadlessChrome'],

    customLaunchers: {
      MyHeadlessChrome: {
        base: 'ChromeHeadless',
        flags: ['--disable-translate', '--disable-extensions', '--remote-debugging-port=9223']
      }
    },
  }
};

完全在 Travis CI 上運行它

在 Headless Chrome 中配置 Karma 運行測試是很困難的。而在 Travis 中持續集成就只有幾種!

要在 Travis 中運行測試,請使用 dist: trusty 並安裝穩定版 Chrome 插件:

.travis.yml

language: node_js
node_js:
  - "7"
dist: trusty # needs Ubuntu Trusty
sudo: false  # no need for virtualization.
addons:
  chrome: stable # have Travis install chrome stable.
cache:
  yarn: true
  directories:
    - node_modules
install:
  - yarn
script:
  - yarn test

作者簡介

Eric Bidelman 谷歌工程師,Lighthouse 開發,Web 和 Web 組件開發,Chrome 開發

via: https://developers.google.com/web/updates/2017/06/headless-karma-mocha-chai

作者:Eric Bidelman 譯者:firmianay 校對:wxy

本文由 LCTT 原創編譯,Linux中國 榮譽推出


本文轉載來自 Linux 中國: https://github.com/Linux-CN/archive

對這篇文章感覺如何?

太棒了
0
不錯
0
愛死了
0
不太好
0
感覺很糟
0
雨落清風。心向陽

    You may also like

    Leave a reply

    您的郵箱地址不會被公開。 必填項已用 * 標註

    這個站點使用 Akismet 來減少垃圾評論。了解你的評論數據如何被處理

    More in:Linux中國

    Linux中國

    捐贈 Let's Encrypt,共建安全的互聯網

    隨著 Mozilla、蘋果和谷歌對沃通和 StartCom 這兩家 CA 公司處罰落定,很多使用這兩家 CA 所簽發證書的網站紛紛尋求新的證書籤發商。有一個非盈利組織可以為大家提供了免費、可靠和安全的 SSL 證書服務,這就是 Let's Encrypt 項目。現在,它需要您的幫助
    Linux中國

    關於Linux防火牆iptables的面試問答

    Nishita Agarwal是Tecmint的用戶,她將分享關於她剛剛經歷的一家公司(印度的一家私人公司Pune)的面試經驗。在面試中她被問及許多不同的問題,但她是iptables方面的專家,因此她想分享這些關於iptables的問題和相應的答案給那些以後可能會進行相關面試的人。 所有的問題和相應的答案都基於Nishita Agarwal的記憶並經過了重寫。 嗨,朋友!我叫Nishita Agarwal。我已經取得了理學學士學位,我的專業集中在UNIX和它的變種(BSD,Linux)。它們一直深深的吸引著我。我在存儲方面有1年多的經驗。我正在尋求職業上的變化,並將供職於印度的P
    Linux中國

    Lets Encrypt 已被所有主流瀏覽器所信任

    旨在讓每個網站都能使用 HTTPS 加密的非贏利組織 Lets Encrypt 已經得了 IdenTrust的交叉簽名,這意味著其證書現在已經可以被所有主流的瀏覽器所信任。從這個裡程碑事件開始,訪問者訪問使用了Lets Encrypt 證書的網站不再需要特別配置就可以得到 HTTPS 安全保護了。 Lets Encrypt 的兩個中級證書 ...