基于Istanbul优雅地搭建前端JS覆盖率平台

本文会介绍一种前端JS代码测试覆盖率平台的搭建思路。提供了由简单到复杂的三个场景,并分别提供了不同场景下合适的实现代码覆盖率解决方案。

1.场景1单版本,单次测试的覆盖率统计

要实现这种最简单的场景,有很多好用的插件可以选择:

上述插件各有优劣,但均可以在一定程度上满足这个简单的场景。当然这个场景存在局限性:

1.单版本,单次测试

2.一般用于单元测试、前端自动化

3.报告生成在本地

4.不支持多次测试覆盖率叠加

如果需要突破上述局限性,可以参考一下场景2是否能满足需求。

2.场景2单版本,多终端多次测试的覆盖率统计

要实现这种扩展场景,我们可以找到一些既有的实践,都是基于场景1中列举的插件的开源代码做的,举其中两个例子:

当然,场景2依然存在一些局限性,于是我设计了场景3,来满足当前场景的一些局限性:

1.单项目,单版本

2.数据无统一管理,只能导成文件

3.Repo无法自动匹配更新

3.场景3多版本,多终端多次测试的覆盖率统计

因为场景3存在大量定制化的成分,因此必然存在不少地方需要自己实现。我选择在Istanbul-Middleware的基础上进行改造。

3.1.摸透Istanbul-Middleware的使用方法

根据Git中的说明以及对demo的研究,想要把istanbul-middleware应用到自己的前端工程,可以分为五步:

3.1.1.部署middleware

将istanbul-middleware的代码clone下来,并部署在某个服务器上,使默认接口可用。默认接口的设计详见repo的readme。

3.1.2.插桩

使用Istanbul的插件给前端代码插桩。

以酷家乐的某个前端repo为例,它使用babel编译打包,可使用babel-plugin-Istanbul插桩,具体实现方法,就是在babel的配置文件.babelrc中添加istanbul插件。参考:github.com/istanbuljs/babel-plugin-istanbul

对于其他类型的JS前端工程,可参考:github.com/istanbuljs/nyc

插桩前后代码对比如下。插桩后的代码可以在运行过程中,统计到某一行代码是否运行到,某一段逻辑是否被覆盖。

3.1.3.浏览器运行插桩后代码

浏览器运行的代码如果成功的被istanbul插桩,可以通过window.__coverage__查看前端代码运行过程中的覆盖率数据,如图所示。当然这个数据是一堆json结构,不具可视化。

3.1.4.前端代码调用middleware提供的接口

前端代码调用middleware/coverage/client接口,将window.__coverage__上传给中间件,供它统计。

3.1.5.查看代码覆盖率报告

middleware提供了看报告的页面,直接访问即可查看。

3.2.如何改造

既然我们已经知道了istanbul-middleware的使用方法,那么我们应该如何基于它实现场景3呢?

3.2.1.需求

多个repo的覆盖率分布统计;各个repo部署的各个环境分别统计;各个环境中,不同的版本分别统计。

3.2.2.架构

3.3.3.数据库

3.3.4.接口设计

client接口,增加一个version参数。

show接口,增加四个参数。

3.3.5.结果展示

前端代码在浏览器运行时,通过调用client时配置不同参数,区分repo、环境、版本。

查看特定repo特定version的覆盖率数据

查看某个路径下所有文件的覆盖率数据

查看覆盖率数据的原始数据源

渲染后台架构渲染集群几个机房,每个机房有proxy、renderservice、redis、mysqlProxy:控制节点,角色为master或slave,每个集群至少部署2个以成环;Render:渲染节点,每个集群有上百个;Redis:存储任务信息、配置信息等等,以主

THE END
1.VS如何运行测试代码VS如何运行测试代码 简介 现在我们来看看,VS如何运行测试代码。工具/原料 联想2020 Win11 VS 2017 方法/步骤 1 我们可以使用最简单的办法直接点击启动按钮。2 或者我们点击菜单栏中的测试按钮。3 然后我们点击运行二级菜单。4 接下来我们点击所以测试按钮。5 也可以使用它的快捷键。6 同理,还可以使用它的调试命令https://jingyan.baidu.com/article/67662997a06a7d54d51b84e7.html
2.Python中如何实现代码测试问答在Python中,通常可以使用以下几种方法来实现代码测试:1. 单元测试(Unit testing):使用Python内置的unittest模块或第三方库如pytest来编写和运行单元测试,以验证https://www.yisu.com/ask/27942242.html
3.Golang中如何编写test测试代码这个输出结果是否是我们期望的!很多是否都要碰都这种情况,特别是在写一些项目的时候,文件很多代码也多,以前在不知道这样方法的时候就很恼火,以前在遇到这种情况的时候处理方法就是用IDE新建一个环境,然后把要测试的函数直接复制过去,但是这样不仅麻烦很多时候还没有办法做。https://www.jianshu.com/p/3e9aa5d20782
4.MSDN—探索如何创建测试和理解代码MicrosoftLearn创建代码 了解如何创建代码,获取工具,并立即开始学习。 测试代码 阅读有关测试代码的基础知识,获取工具,并立即了解更多信息。 理解代码 学习理解代码的过程,获取工具,并深入了解! 所有开发人员中心 展开表 任务 展开表 理解代码 理解代码涉及多个任务。工具可帮助您以直观形式查看和理解代码的组织、关系和行为。 https://msdn.microsoft.com/zh-cn/gg192976
5.如何创建临时查询,测试运行代码临时查询用于在本地测试代码的实际情况与期望值是否相符或排查代码错误。 背景信息 若您仅需在数据开发(DataStudio),即开发环境,查询数据及相关SQL代码、测试代码的实际运行情况与期望值是否相符,或验证代码的正确性,而无需将数据或SQL代码发布至生产环境并操作生产环境引擎,则可通过 新建临时查询文件实现。https://help.aliyun.com/zh/dataworks/user-guide/create-an-ad-hoc-query
6.四种常见的代码覆盖率测试当您添加新的功能和测试时,增加代码覆盖率百分比可以让您更加确信您的应用程序已经经过了彻底的测试。然而,还有更多的问题有待发现。 四种常见的代码覆盖类型 有四种常见的方法来收集和计算代码覆盖率:函数、行、分支和语句覆盖率。要查看每种类型的代码覆盖率如何计算其百分比,请思考以下计算咖啡成分的代码示例: https://blog.csdn.net/2301_81967508/article/details/144409765
7.谷歌指南:编写可测试的代码谷歌的软件工程师为了保持代码的最佳状态, 写了以下提醒. 缺陷: 构造器做了真正的工作 构造器中的工作包括: 创建/初始化协同类, 和其他service通信, 和设置自身状态的逻辑, 失去了测试的必要, 迫使subclass/mocks去继承不必要的行为. 构造器中太多的工作阻止了测试中的实例化或协同类的修改. https://zhuanlan.zhihu.com/p/146951456
8.JavaIDE如何使用代码覆盖率工具?在软件开发中,代码覆盖率是一个重要的质量指标,它用于衡量测试代码对实际代码的覆盖程度。Java 开发者常常使用 IntelliJ IDEA 这样的 IDE 来进行项目开发和代码测试。然而,有时在使用“Run with Coverage”功能时,会遇到一些问题,导致代码覆盖率无法正常工作。本文将介绍如何在 IntelliJ IDEA 中使用代码覆盖率工具,并https://blog.51cto.com/u_16175520/11996918
9.如何在树莓派4B上通过GoogleMediapipe解决方案实现手势检测6. 编写代码测试 接下来就可以尝试编写代码进行测试了,其中可以参考官方提供Python代码示例来进行学习: import cv2 import mediapipe as mp mp_drawing = mp.solutions.drawing_utils mp_drawing_styles = mp.solutions.drawing_styles mp_hands = mp.solutions.hands https://www.eet-china.com/mp/a148964.html
10.如何在Simulink中实现MIL的自动化测试?汽车测试技术自动化测试代码主要包括3个指令:xlsread、sim、xlswrite。 先用xlsread把测试用例的输入和期望输出读取进来;借助for循环,实现每一个测试用例的单独执行,这里会用到sim(‘XX.mdl’),把执行完的结果与期望的结果对比即可获得测试结果;最后把测试结果通过xlswrite写入excel。 https://www.auto-testing.net/news/show-107747.html
11.通过调试器如何在线测试S7SCL源代码?内容预览:描述: 调试器帮助对S7-SCL源代码进行一个简单调试,如果在编译S7-SCL 源代码过程没有错误发生,能够通过利用断点找出程序逻辑错误,并在运行时监视S7-SCL 代码的函数功能。过程如下面表格中描述: https://www.ad.siemens.com.cn/download/DocumentDetail_2719.html
12.静态代码分析测试静态分析如何保障软件质量和软件安全? 提高代码质量并降低缺陷成本 在开发过程的早期防止代码缺陷,以免它们在软件测试的后期阶段造成昂贵的成本。 满足行业功能安全标准 引入支持IS26262、DO-178C、IEC62304、IEC61508、EN50128等功能安全标准的静态分析解决方案。 https://www.parasoftchina.cn/solutions/static-code-analysis/