热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

【Count】自动化为你的项目添加证明可靠性的badge

前言开源社区里,开源项目一般会将一排花花绿绿的badge(徽章)摆在README最显眼的位置,它们一般可以起到一些说明和证明的作用。比如下面的这个项目(传送门):第一个badge证


前言


开源社区里,开源项目一般会将一排花花绿绿的 badge(徽章)摆在 README 最显眼的位置,它们一般可以起到一些说明和证明的作用。


比如下面的这个项目( 传送门 ):



  • 第一个 badge 证明其能正常构建,点击跳转至构建过程报告;

  • 第二个 badge 证明其测试覆盖率达到100%,点击跳转至单元测试报告;

  • 第三个 badge 说明其是 MIT 授权协议;

  • 第四个 badge 说明其最小化后包的大小;



别以为他们只是图片,正规的项目是随项目更新而更新的,点击不了或者点击进入的不是对应项目的报告都可以算作伪造,请远离这些项目。


上面提到的 badge 中前两个可以算是项目可靠性的证明,是比较有份量的 badge,接下来我们将指引大家如何自动化添加这两 badge。


注意:本文以 Github 为代码仓库,第三方帐号授权都以 Github 帐号进行,请确保自身网络环境能正常访问;不涉及项目本身的构建和测试。


准备



  • 编写一个项目,在 package.json 中以“build”为构建命令,dist 为打包后输出的目录;

  • 编写好该项目的单元测试,在 package.json 中以“test:prod”为测试命令,并且会自动在 coverage 目录下生成覆盖率报告;

  • 为项目安装 devDependencies(开发依赖):



    • coveralls


  • 注册一个 Github 帐号,提交项目到一个仓库。


Travis 配置


Travis CI 提供的是持续集成服务(Continuous Integration,简称 CI)。它绑定 Github 上面的项目,只要有新的代码,就会自动抓取。然后,提供一个运行环境(容器),执行测试,完成构建,还能自动部署到服务器。


本次的自动化就是依靠这个服务完成的,这里只展示相关的配置,更多的用法请自行查看文档。


新建配置文件


在项目根目录下新建 .travis.yml 文件,输入下面配置并保存。


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,还支持设置钩子、接口通知等方式,详细见 文档 ;

  • node_js:运行容器安装的 node 版本,这里是指构建和测试的环境,与实际运行环境是不同的,一般与本机相同即可,设置多个的话每次每一个都会运行一次,会增加构建时间;

  • script:要运行的命令,这里我们进行的就是单元测试和构建两步操作;

  • after_success:script 运行结束,且无错误的情况下运行的命令,这里我们进行单测覆盖率报告提交;

  • branches:需要运行的 git 分支,默认是只运行主分支,这里我们增加了对“vXX.XX.XX”分支的支持。


开启 Travis 监听



  1. 进入 Travis 官网: https://travis-ci.com/ ;

  2. 用 Github 帐号授权登录;

  3. 点击左上角的加号,或者点击指引里的按钮,进入对 Github 仓库进行授权;

  4. 可以选择授权当前 Github 帐号的部分仓库,也可以选择全部。


获取构建 badge 代码


待仓库导入后,进入项目主页,右上角就能看到 badge,点击它会弹出一个选择代码类型的弹框,选择需要的类型复制粘贴到 README 就行了(一般选择 Markdown)。



Coveralls 配置


Coveralls 是一个展示单元测试覆盖率报告的网站,它本身不会运行单测或生成报告,它只是提供用于提交标准单元测试覆盖率报告的包(也就是上面准备阶段安装的coveralls),可以配合测试套件使用。


编写提交命令


以 Jest 为例,默认运行 jest --coverage 后会在 coverage 目录下生成标准的单测报告。但我们不需要在本地跑,Travis 会帮我们完成,只需要确保可以目录正确即可。


上面 .travis.yml 中我们使用了“report-coverage”命令,这个是自定义的 scripts,在 package.json 里的 scripts 块中写入该命令,


"scripts": {
"report-coverage": "cat ./coverage/lcov.info | coveralls",
}

开启 Coveralls 监听



  1. 进入 Coveralls 官网: https://coveralls.io/ ;

  2. 用 Github 帐号授权登录;

  3. 点击右侧加号(ADD REPO);

  4. 把需要的项目的开关打开;


获取覆盖率 badge 代码


点击 DETAILS 进入详情页,这时候你还未有报告,所以看到的是指引页,我们可以先在底部找到获取 badge 代码的入口,选择需要的类型复制粘贴到 README 就行了(一般选择 Markdown)。



完成,启动 Travis


将 .travis.yml、package.json 和 README 提交,Travis 监听到提交就会启动运行。偶尔第一次未成功 ,可以点击 Travis 的项目详情页右侧,点击“Trigger build”手动开启。



额外配置(可选)


因为 Coveralls 本身就已经能与 Travis 无缝配合,默认情况下它们会识别相同的仓库,并更新。


但如果你使用的是 Travis Pro(Travis 的付费版,一般免费的已经够用)和其他 CI 系统,或者需要非 git 主分支的结果时,需要进行写入环境变量告知系统。


Coveralls 提供三个必填项:



  • COVERALLS_SERVICE_NAME:CI 系统名,比如 travis-pro;

  • COVERALLS_REPO_TOKEN:Coveralls 给每个项目的唯一标识,也是提交单测覆盖率报告的依据;

  • COVERALLS_GIT_BRANCH:提交报告是哪个 git 分支。


全局的环境变量


如果是全局的变量,可以直接写到 .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 文档 )。



  1. 进入项目对应的 Travis 主页;

  2. 点击右上角的“More options”里“Settings”;

  3. 在“Environment Variables”块进行“ADD”操作。



结束


教程到此已经完成,整体流程就是:通过 Travis 配置监听 Github 上对应仓库的提交,Travis 发现提交就拉取代码,在 Travis 提供的容器里完成构建和单元测试,完成后再自动提交单测覆盖率报告到 Coveralls,最终结果反映到 README 的 badge 上。


一劳永逸,还不赶紧试试。




推荐阅读
  • Explore how Matterverse is redefining the metaverse experience, creating immersive and meaningful virtual environments that foster genuine connections and economic opportunities. ... [详细]
  • 本文详细介绍如何使用Python进行配置文件的读写操作,涵盖常见的配置文件格式(如INI、JSON、TOML和YAML),并提供具体的代码示例。 ... [详细]
  • 本文深入探讨 MyBatis 中动态 SQL 的使用方法,包括 if/where、trim 自定义字符串截取规则、choose 分支选择、封装查询和修改条件的 where/set 标签、批量处理的 foreach 标签以及内置参数和 bind 的用法。 ... [详细]
  • QUIC协议:快速UDP互联网连接
    QUIC(Quick UDP Internet Connections)是谷歌开发的一种旨在提高网络性能和安全性的传输层协议。它基于UDP,并结合了TLS级别的安全性,提供了更高效、更可靠的互联网通信方式。 ... [详细]
  • PyCharm下载与安装指南
    本文详细介绍如何从官方渠道下载并安装PyCharm集成开发环境(IDE),涵盖Windows、macOS和Linux系统,同时提供详细的安装步骤及配置建议。 ... [详细]
  • Explore a common issue encountered when implementing an OAuth 1.0a API, specifically the inability to encode null objects and how to resolve it. ... [详细]
  • 技术分享:从动态网站提取站点密钥的解决方案
    本文探讨了如何从动态网站中提取站点密钥,特别是针对验证码(reCAPTCHA)的处理方法。通过结合Selenium和requests库,提供了详细的代码示例和优化建议。 ... [详细]
  • Java 中的 BigDecimal pow()方法,示例 ... [详细]
  • 探讨如何高效使用FastJSON进行JSON数据解析,特别是从复杂嵌套结构中提取特定字段值的方法。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 本文介绍了Java并发库中的阻塞队列(BlockingQueue)及其典型应用场景。通过具体实例,展示了如何利用LinkedBlockingQueue实现线程间高效、安全的数据传递,并结合线程池和原子类优化性能。 ... [详细]
  • 数据管理权威指南:《DAMA-DMBOK2 数据管理知识体系》
    本书提供了全面的数据管理职能、术语和最佳实践方法的标准行业解释,构建了数据管理的总体框架,为数据管理的发展奠定了坚实的理论基础。适合各类数据管理专业人士和相关领域的从业人员。 ... [详细]
  • CentOS7源码编译安装MySQL5.6
    2019独角兽企业重金招聘Python工程师标准一、先在cmake官网下个最新的cmake源码包cmake官网:https:www.cmake.org如此时最新 ... [详细]
  • 深入理解Java中的volatile、内存屏障与CPU指令
    本文详细探讨了Java中volatile关键字的作用机制,以及其与内存屏障和CPU指令之间的关系。通过具体示例和专业解析,帮助读者更好地理解多线程编程中的同步问题。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
author-avatar
10651s
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有