热门标签 | 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:

版权所属,禁止转载


推荐阅读
  • 地球坐标、火星坐标及百度坐标间的转换算法 C# 实现
    本文介绍了WGS84坐标系统及其精度改进历程,探讨了火星坐标系统的安全性和应用背景,并详细解析了火星坐标与百度坐标之间的转换算法,提供了C#语言的实现代码。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • 作为一名新手,您可能会在初次尝试使用Eclipse进行Struts开发时遇到一些挑战。本文将为您提供详细的指导和解决方案,帮助您克服常见的配置和操作难题。 ... [详细]
  • 2023年京东Android面试真题解析与经验分享
    本文由一位拥有6年Android开发经验的工程师撰写,详细解析了京东面试中常见的技术问题。涵盖引用传递、Handler机制、ListView优化、多线程控制及ANR处理等核心知识点。 ... [详细]
  • 帝国CMS多图上传插件详解及使用指南
    本文介绍了一款用于帝国CMS的多图上传插件,该插件通过Flash技术实现批量图片上传功能,显著提升了多图上传效率。文章详细说明了插件的安装、配置和使用方法。 ... [详细]
  • 堆是一种常见的数据结构,广泛应用于计算机科学领域。它通常表示为一棵完全二叉树,并可通过数组实现。堆的主要特性是每个节点的值与其父节点的值之间存在特定的关系,这使得堆在优先队列和排序算法中非常有用。 ... [详细]
  • 微信小程序中实现位置获取的全面指南
    本文详细介绍了如何在微信小程序中实现地理位置的获取,包括通过微信官方API和腾讯地图API两种方式。文中不仅涵盖了必要的准备工作,如申请开发者密钥、下载并配置SDK等,还提供了处理用户授权及位置信息获取的具体代码示例。 ... [详细]
  • 本文详细介绍了如何在现有的Android Studio项目中集成JNI(Java Native Interface),包括下载必要的NDK和构建工具,配置CMakeLists.txt文件,以及编写和调用JNI函数的具体步骤。 ... [详细]
  • 本文探讨了随着并发需求的增长,MySQL数据库架构如何从简单的单一实例发展到复杂的分布式系统,以及每一步演进背后的原理和技术解决方案。 ... [详细]
  • 金山与万普广告争议:APP开发者权益受侵害
    探讨了金山毒霸对嵌入特定广告SDK的APP进行封禁的行为,分析其对安卓开发者的影响,并揭示了这一系列事件背后的复杂性。 ... [详细]
  • 由中科院自动化所、中科院大学及南昌大学联合研究提出了一种新颖的双路径生成对抗网络(TP-GAN),该技术能通过单一侧面照片生成逼真的正面人脸图像,显著提升了不同姿态下的人脸识别效果。 ... [详细]
  • 2017年苹果全球开发者大会即将开幕,预计iOS将迎来重大更新,同时Siri智能音箱有望首次亮相,AI技术成为大会焦点。 ... [详细]
  • 智慧城市建设现状及未来趋势
    随着新基建政策的推进及‘十四五’规划的实施,我国正步入以5G、人工智能等先进技术引领的智慧经济新时代。规划强调加速数字化转型,促进数字政府建设,新基建政策亦倡导城市基础设施的全面数字化。本文探讨了智慧城市的发展背景、全球及国内进展、市场规模、架构设计,以及百度、阿里、腾讯、华为等领军企业在该领域的布局策略。 ... [详细]
  • MainActivityimportandroid.app.Activity;importandroid.os.Bundle;importandroid.os.Handler;im ... [详细]
  • 本文提供了一个详细的PHP用户认证和管理的代码示例,包括用户登录验证、数据库连接、错误处理等关键部分的实现。 ... [详细]
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社区 版权所有