testing-on-headless-ci.md to zh-CN

This commit is contained in:
Weiqiang Lin 2017-01-22 14:15:51 +08:00
parent 11259b0ea2
commit cf54c4cbb2

View file

@ -1,25 +1,25 @@
# Testing Electron with headless CI Systems (Travis CI, Jenkins)
# Headless CI Systems 测试 (Travis CI, Jenkins)
Electron基于Chromium所以需要一个显示驱动使其运转。如果Chromium无法找到一个显示驱动
ELectron 会启动失败因此无论你如何去运行它Electron不会执行你的任何测试。在Travis, Circle,
Electron 基于 Chromium所以需要一个显示驱动使其运转。如果 Chromium 无法找到一个显示驱动,
ELectron 会启动失败因此无论你如何去运行它Electron 不会执行你的任何测试。在 TravisCircle
Jenkins 或者类似的系统上测试基于Electron的应用时需要进行一些配置。本质上我们需要使用一个
虚拟的显示驱动。
## Configuring the Virtual Display Server
## 配置虚拟显示服务器
首先安装[Xvfb](https://en.wikipedia.org/wiki/Xvfb)。
首先安装 [Xvfb](https://en.wikipedia.org/wiki/Xvfb)。
这是一个虚拟的帧缓冲实现了X11显示服务协议所有的图形操作都在内存中表现而不需要显示在
任何屏幕输出设备上。这正是我们所需要的。
然后创建一个虚拟的xvfb屏幕并且导出一个指向他的名为`DISPLAY`的环境变量。Electron中的Chromium
会自动的去寻找`$DISPLAY`,所以你的应用不需要再去进行配置。这一步可以通过Paul Betts's
[xvfb-maybe](https://github.com/paulcbetts/xvfb-maybe)实现自动化:如果系统需要,在`xvfb-maybe`前加上你的测试命令
然后这个小工具会自动的设置xvfb。在Windows或者macOS系统下它不会执行任何东西。
然后创建一个虚拟的xvfb屏幕并且导出一个指向他的名为 `DISPLAY` 的环境变量。Electron 中的 Chromium
会自动的去寻找 `$DISPLAY`,所以你的应用不需要再去进行配置。这一步可以通过 Paul Betts
[xvfb-maybe](https://github.com/paulcbetts/xvfb-maybe) 实现自动化:如果系统需要,在`xvfb-maybe`前加上你的测试命令
然后这个小工具会自动的设置 xvfb。在 Windows 或者 macOS 系统下,它不会执行任何东西。
```
## On Windows or macOS, this just invokes electron-mocha
## On Linux, if we are in a headless environment, this will be equivalent
## to xvfb-run electron-mocha ./test/*.js
## 在 Windows 或者 macOS这只是调用 electron-mocha
## 在 Linux 如果我们在 headless 环境,这将是等同于
## xvfb-run electron-mocha ./test/*.js
xvfb-maybe electron-mocha ./test/*.js
```
@ -40,12 +40,12 @@ install:
### Jenkins
Jenkins下, 有一个可用的[Xvfb插件](https://wiki.jenkins-ci.org/display/JENKINS/Xvfb+Plugin).
Jenkins下, 有一个可用的 [Xvfb插件](https://wiki.jenkins-ci.org/display/JENKINS/Xvfb+Plugin)。
### Circle CI
Circle CI 是非常棒的而且有xvfb`$DISPLAY`也[已经搭建,所以不需要再进行设置](https://circleci.com/docs/environment#browsers)。
Circle CI 是非常棒的而且有xvfb`$DISPLAY` 也 [已经搭建,所以不需要再进行设置](https://circleci.com/docs/environment#browsers)。
### AppVeyor
AppVeyor运行于Windows上支持 Selenium, Chromium, Electron 以及一些类似的工具,开箱即用,无需配置。
AppVeyor 运行于 Windows 上,支持 SeleniumChromiumElectron 以及一些类似的工具,开箱即用,无需配置。