热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

【测试左移专栏】测试左移实践探讨——测试左移在腾讯地图SDK的实践

作者:赵丽娜团队:腾讯移动品质中心TMQ我理解的”测试左移”,即将测试活动与开发活动结合更加紧密,同步于开发活动甚至早于开发活动便开始的质量保障活动。业界已有关于测试前置的一些讨论,

作者:赵丽娜

团队:腾讯移动品质中心TMQ

我理解的”测试左移”,即将测试活动与开发活动结合更加紧密, 同步于开发活动甚至早于开发活动便开始的质量保障活动。业界已有关于测试前置的一些讨论, 因此本文也沿用测试前置的概念. 本文将讲解测试前置在腾讯地图SDK的实践情况。鉴于APP与SDK的不同形式,APP类产品在实践测试前置方法时需做适当调整。

一、持续测试过程

测试前置的前提是持续集成和持续测试,持续测试的前提是自动化测试。自动化测试的实现离不开好的测试框架和测试平台的支持。地图SDK之所以能逐渐做到测试前置,正是依赖于地图SDK在自动化测试的积累。详细的测试框架介绍请期待后续tmq相关文章。

持续测试过程中,开发工程和测试工程的统一使得自动化测试校验点增强,同时也使得测试用例开发与开发功能开发同步进行变得可能。

二、测试前置活动

1、引入测试前置活动的原因

通过对版本bug的系统分析,我们发现基础类问题占比达到30%(如图1),基础类问题是可以通过codereview,静态扫描,或者单元测试活动发现的,大量的基础类问题遗留到测试执行阶段,浪费了测试成本,也增加了问题定位成本。另外通过Coverity扫描发现静态扫描问题多 (如图2),潜在稳定性风险大。因此我们认为测试前置活动是有必要的。

图1 Bug根因构成


图2 静态扫描问题对比

2、测试前置活动

测试前置活动包含两方面内容,一是开发参与质量保证;二是测试活动提前。开发参与质量保证的活动有CodeReview,进行静态扫描并扫清扫描中出现的问题,和高质量的自测。业界开发自测通常采用UT的方式。在本产品中,自测以功能验证方式为主。

图3描述了从需求评审开始,测试线与开发线并行进行的活动过程。在开发线,开发通过需求文档映射到设计文档(由于互联网应用的快节奏,在小feature中可跳过。) 这时测试线同步进行手工测试用例的设计和编写。开发线进一步在梳理接口后输出比较确定的接口定义,测试线基于接口定义进行自动化用例和测试demo的实现。开发代码完成时,由于在同一工程下,测试用例代码可实时(或相对实时)与开发代码集成和调试,开发code review,自测的过程的同时自动化测试用例也在调试中。提测后,测试进入手工测试环节,关注在复杂逻辑和效果验证。


图3: 测试前置流程

汇而总之,目前采用的测试前置活动如下:

(1)手工用例提测前输出;

(2)自动化用例提测前编写和调试;

(3)代码静态扫描;

(4)code review。

3、测试前置效果检测

我们定义测试交付件包括手工用例,自动化用例,bug和符合测试准出标准的被测包。我们通过每个版本中的bug ODC分析来检查是否有基础问题遗留到后期手工测试阶段,遗留的问题是由于什么原因引起的,进而反作用于测试前置流程,完善测试前置流程。

以下举例说明。图4和图5为一次ODC分析结果,从图中可以看出基本功能覆盖引起的问题占问题总量40+%,基础类的问题(条件检查、初始化、算法基本逻辑等)占有效问题50%。说明本次测试中,测试前置效果不好。进一步分析,基础类问题集中在一个feature上,最终调研发现,该feature没有开展测试前置活动。


图4: ODC触发原因分析


图5: ODC缺陷类型分析

汇总一下, 检测步骤如下:

(1)测试结果ODC分析;

(2) 结果反馈跟进;

(3)反馈完善测试前置流程和方法。

三、测试前置的下一步——UT

从上面的讨论我们已了解,单元测试也是测试前置的重要活动。但单元测试在互联网产品尤其是前端实施阻力非常大,因此我们通过一定原则筛选出一些适合做单元测试的模块,目前正在实践中,有一定实践效果再与大家分享。

筛选的原则如下:

1、逻辑性强的模块;

2、当前测试用例代码覆盖率低的模块;

3、代码可测性高的模块:我们是从函数扇入扇出、函数行数、函数深度、函数圈复杂度等方面进行函数分级。

原文链接:http://tmq.cs0309.3g.qq.com/2017/06/sdk/

获取更多测试干货,关注腾讯移动品质中心TMQ:

版权所属,禁止转载


推荐阅读
  • 三角测量计算三维坐标的代码_双目三维重建——层次化重建思考
    双目三维重建——层次化重建思考FesianXu2020.7.22atANTFINANCIALintern前言本文是笔者阅读[1]第10章内容的笔记,本文从宏观的角度阐 ... [详细]
  • iOS 百度地图使用指南:基本定位与地理编码
    本文详细介绍如何在 iOS 应用中集成百度地图,实现基本的地图定位和地理编码功能。配置详情请参考官方文档:http://developer.baidu.com/map/index.php?title=iossdk ... [详细]
  • oracle 对硬件环境要求,Oracle 10G数据库软硬件环境的要求 ... [详细]
  • 电商高并发解决方案详解
    本文以京东为例,详细探讨了电商中常见的高并发解决方案,包括多级缓存和Nginx限流技术,旨在帮助读者更好地理解和应用这些技术。 ... [详细]
  • 前言:由于Android系统本身决定了其自身的单线程模型结构。在日常的开发过程中,我们又不能把所有的工作都交给主线程去处理(会造成UI卡顿现象)。因此,适当的创建子线程去处理一些耗 ... [详细]
  • PHP函数的工作原理与性能分析
    在编程语言中,函数是最基本的组成单元。本文将探讨PHP函数的特点、调用机制以及性能表现,并通过实际测试给出优化建议。 ... [详细]
  • Android异步处理一:使用Thread+Handler实现非UI线程更新UI界面Android异步处理二:使用AsyncTask异步更新UI界面Android异步处理三:Handler+Loope ... [详细]
  • 短暂的人生中,IT和技术只是其中的一部分。无论换工作还是换行业,最终的目标是成功、荣誉和收获。本文探讨了技术人员如何跳出纯技术的局限,实现更大的职业发展。 ... [详细]
  • 专业人士如何做自媒体 ... [详细]
  • 非计算机专业的朋友如何拿下多个Offer
    大家好,我是归辰。秋招结束后,我已顺利入职,并应公子龙的邀请,分享一些秋招面试的心得体会,希望能帮助到学弟学妹们,让他们在未来的面试中更加顺利。 ... [详细]
  • Python 数据可视化实战指南
    本文详细介绍如何使用 Python 进行数据可视化,涵盖从环境搭建到具体实例的全过程。 ... [详细]
  • 在2019中国国际智能产业博览会上,百度董事长兼CEO李彦宏强调,人工智能应务实推进其在各行业的应用。随后,在“ABC SUMMIT 2019百度云智峰会”上,百度展示了通过“云+AI”推动AI工业化和产业智能化的最新成果。 ... [详细]
  • 本文通过对快速排序和堆排序的算法效率进行详细对比分析,探讨了快速排序在实际应用中为何能表现出更高的性能。快速排序通过分治策略实现高效排序,其平均时间复杂度为O(n log n),而堆排序虽然最坏情况下的时间复杂度也是O(n log n),但在实际运行中由于频繁的数据交换和维护堆结构的操作,导致其性能不如快速排序。此外,快速排序在缓存友好性和并行处理方面也具有明显优势,使其在现代计算机架构中表现更为出色。 ... [详细]
  • 解决Eclipse中缺少Android SDK和AVD管理器的问题
    本文介绍了如何在Eclipse的Window菜单中添加Android SDK和AVD管理器选项,通过自定义透视图中的命令组可用性设置来实现。 ... [详细]
  • 在机器学习领域,深入探讨了概率论与数理统计的基础知识,特别是这些理论在数据挖掘中的应用。文章重点分析了偏差(Bias)与方差(Variance)之间的平衡问题,强调了方差反映了不同训练模型之间的差异,例如在K折交叉验证中,不同模型之间的性能差异显著。此外,还讨论了如何通过优化模型选择和参数调整来有效控制这一平衡,以提高模型的泛化能力。 ... [详细]
author-avatar
mobiledu2502878025
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有