开源社区里,开源项目通常会将一排花花绿绿的 badge(徽章)摆在 README 最显眼的位置,它们通常能够起到一些说明和证实的做用。
好比下面的这个项目(传送门):node
别觉得他们只是图片,正规的项目是随项目更新而更新的,点击不了或者点击进入的不是对应项目的报告均可以算做伪造,请远离这些项目。
上面提到的 badge 中前两个能够算是项目可靠性的证实,是比较有分量的 badge,接下来咱们将指引你们如何自动化添加这两 badge。git
注意:本文以 Github 为代码仓库,第三方账号受权都以 Github 账号进行,请确保自身网络环境能正常访问;不涉及项目自己的构建和测试。github
为项目安装 devDependencies(开发依赖):npm
Travis CI 提供的是持续集成服务(Continuous Integration,简称 CI)。它绑定 Github 上面的项目,只要有新的代码,就会自动抓取。而后,提供一个运行环境(容器),执行测试,完成构建,还能自动部署到服务器。
本次的自动化就是依靠这个服务完成的,这里只展现相关的配置,更多的用法请自行查看文档。json
在项目根目录下新建 .travis.yml 文件,输入下面配置并保存。promise
language: node_js cache: npm notifications: email: false node_js: - '10' script: - npm run test:prod && npm run build after_success: - npm run report-coverage branches: except: - /^v\d+\.\d+\.\d+$/
配置说明:缓存
待仓库导入后,进入项目主页,右上角就能看到 badge,点击它会弹出一个选择代码类型的弹框,选择须要的类型复制粘贴到 README 就好了(通常选择 Markdown)。 bash
Coveralls 是一个展现单元测试覆盖率报告的网站,它自己不会运行单测或生成报告,它只是提供用于提交标准单元测试覆盖率报告的包(也就是上面准备阶段安装的coveralls),能够配合测试套件使用。服务器
以 Jest 为例,默认运行jest --coverage
后会在 coverage 目录下生成标准的单测报告。但咱们不须要在本地跑,Travis 会帮咱们完成,只须要确保能够目录正确便可。
上面 .travis.yml 中咱们使用了“report-coverage”命令,这个是自定义的 scripts,在 package.json 里的 scripts 块中写入该命令,网络
"scripts": { "report-coverage": "cat ./coverage/lcov.info | coveralls", }
点击 DETAILS 进入详情页,这时候你还未有报告,因此看到的是指引页,咱们能够先在底部找到获取 badge 代码的入口,选择须要的类型复制粘贴到 README 就好了(通常选择 Markdown)。
将 .travis.yml、package.json 和 README 提交,Travis 监听到提交就会启动运行。偶尔第一次未成功 ,能够点击 Travis 的项目详情页右侧,点击“Trigger build”手动开启。
由于 Coveralls 自己就已经能与 Travis 无缝配合,默认状况下它们会识别相同的仓库,并更新。
但若是你使用的是 Travis Pro(Travis 的付费版,通常免费的已经够用)和其余 CI 系统,或者须要非 git 主分支的结果时,须要进行写入环境变量告知系统。
Coveralls 提供三个必填项:
若是是全局的变量,能够直接写到 .travis.yml 文件的 env 块。好比:
env: - DB=postgres - SH=bash - PACKAGE_VERSION="1.0.*"
若是是每一个命令独立使用的变量,能够直接写到 .travis.yml 文件的 script 块里的命令里。
script: - COVERALLS_GIT_BRANCH=test npm run test:prod && npm run build
固然同理写到 package.json 文件的 script 也是能够的。
不管写到 .travis.yml 或 package.json 文件都须要提交的 git,这些内容都会公开(公共仓库),但相似 COVERALLS_REPO_TOKEN 这类数据是不能公开的。
所以咱们能够将他们写到 Travis 上项目的设置里(这不是加密,若是要更加严格的加密,可使用加密文件,详情看Travis 文档)。
教程到此已经完成,总体流程就是:经过 Travis 配置监听 Github 上对应仓库的提交,Travis 发现提交就拉取代码,在 Travis 提供的容器里完成构建和单元测试,完成后再自动提交单测覆盖率报告到 Coveralls,最终结果反映到 README 的 badge 上。一劳永逸,还不赶忙试试。