自动化为你的项目添加证明可靠性的 badge
前言
开源社区里,开源项目一般会将一排花花绿绿的 badge(徽章)摆在 README 最显眼的位置,它们一般可以起到一些说明和证明的作用。
比如下面的这个项目:
https://github.com/calimanco/promise-polyfill-plus
第一个 badge 证明其能正常构建,点击跳转至构建过程报告; 第二个 badge 证明其测试覆盖率达到100%,点击跳转至单元测试报告; 第三个 badge 说明其是 MIT 授权协议; 第四个 badge 说明其最小化后包的大小;
上面提到的 badge 中前两个可以算是项目可靠性的证明,是比较有份量的 badge,接下来我们将指引大家如何自动化添加这两 badge。
准备
编写一个项目,在 package.json 中以“build”为构建命令,dist 为打包后输出的目录; 编写好该项目的单元测试,在 package.json 中以“test:prod”为测试命令,并且会自动在 coverage 目录下生成覆盖率报告; 为项目安装 devDependencies(开发依赖): coveralls 注册一个 Github 帐号,提交项目到一个仓库。
Travis 配置
本次的自动化就是依靠这个服务完成的,这里只展示相关的配置,更多的用法请自行查看文档。
新建配置文件
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+$/
language:Travis 可以支持多种语言,这里是 node 项目,填“node_js”即可; cache:缓存,可加快构建。配置为 npm 会缓存 $HOME/.npm 和 node_modules 目录; notifications:默认情况下会邮件通知提交者和作者,如果不需要则设置为 false,还支持设置钩子、接口通知等方式,详细见文档; https://docs.travis-ci.com/user/notifications#configuring-email-notifications node_js:运行容器安装的 node 版本,这里是指构建和测试的环境,与实际运行环境是不同的,一般与本机相同即可,设置多个的话每次每一个都会运行一次,会增加构建时间; script:要运行的命令,这里我们进行的就是单元测试和构建两步操作; after_success:script 运行结束,且无错误的情况下运行的命令,这里我们进行单测覆盖率报告提交; branches:需要运行的 git 分支,默认是只运行主分支,这里我们增加了对“vXX.XX.XX”分支的支持。
开启 Travis 监听
进入 Travis 官网:https://travis-ci.com/; 用 Github 帐号授权登录; 点击左上角的加号,或者点击指引里的按钮,进入对 Github 仓库进行授权; 可以选择授权当前 Github 帐号的部分仓库,也可以选择全部。
获取构建 badge 代码
Coveralls 配置
编写提交命令
上面 .travis.yml 中我们使用了“report-coverage”命令,这个是自定义的 scripts,在 package.json 里的 scripts 块中写入该命令,
"scripts": {
"report-coverage": "cat ./coverage/lcov.info | coveralls",
}
开启 Coveralls 监听
进入 Coveralls 官网:https://coveralls.io/; 用 Github 帐号授权登录; 点击右侧加号(ADD REPO); 把需要的项目的开关打开;
获取覆盖率 badge 代码
完成,启动 Travis
额外配置(可选)
但如果你使用的是 Travis Pro(Travis 的付费版,一般免费的已经够用)和其他 CI 系统,或者需要非 git 主分支的结果时,需要进行写入环境变量告知系统。
Coveralls 提供三个必填项:
COVERALLS_SERVICE_NAME:CI 系统名,比如 travis-pro; COVERALLS_REPO_TOKEN:Coveralls 给每个项目的唯一标识,也是提交单测覆盖率报告的依据; COVERALLS_GIT_BRANCH:提交报告是哪个 git 分支。
全局的环境变量
env:
- DB=postgres
- SH=bash
- PACKAGE_VERSION="1.0.*"
局部的环境变量
script:
- COVERALLS_GIT_BRANCH=test npm run test:prod && npm run build
一些不能公开的变量
因此我们可以将他们写到 Travis 上项目的设置里(这不是加密,如果要更加严格的加密,可以使用加密文件,详情看Travis 文档)。
进入项目对应的 Travis 主页; 点击右上角的“More options”里“Settings”; 在“Environment Variables”块进行“ADD”操作。
结束
一劳永逸,还不赶紧试试。
评论