启发式测试策略

简介: 启发式测试策略

640.jpg

现如今,市面上有太多关于测试技术的文章。网上随便就可以搜到各种自动化、以及各种高大上的框架,然而关于测试思维和测试方法却鲜有人提及。诚然测试人员不能缺少代码相关的硬技术,但同时也不应忽略测试思维等“软素质”,这个系列将重点探讨测试策略及测试设计相关的知识。今天先聊一聊启发式测试策略。


01


启发式测试策略模型(Heuristic Test Strategy Model,简称HTSM)是测试专家James Bach提出的一组帮助测试设计的指南(guideline),如下图所示。启发式测试策略模型是这样一个框架,需要根据质量定义(Quality Criteria)、项目环境(Project Environment)和产品元素(Product Elements)来选择测试技术(Test Techniques)进行测试,并最终得到可感知的产品质量(Perceived Quality)。


76825be2ce466caa10c1752c900eb9f9.png

 

项目环境:资源、约束和其他影响测试的项目元素。比如产品的成熟度、需求的质量、测试人员的能力,研发模式等。有经验的测试人员会根据当前语境(Context),在约束条件下充分运用资源,以高效地测试。

 

产品元素:需要测试的对象,它通常会包含产品的物理结构、功能覆盖、数据逻辑处理、外部依赖元素及日常操作等内容,需要测试人员根据产品特性做针对性的分析、拆解。在定义产品元素的过程中,加深对产品的理解

 

质量定义:产品在不同的阶段需要对质量做不同的定义,高质量注入意味着高成本(时间成本、技术成本、人力成本),当下我们追求的是合适的质量。所以需要在制定测试策略的时候和团队一起定义好质量,包含研发质量和交付质量目标是什么。

 

测试技术:基于前面三者信息,测试人员需要针对性地选择不同的测试技术,功能测试、性能测试、安全测试、兼容性测试、探索性测试、容量测试、安装测试等等一系列测试活动的选择,都将基于以上三个要素进行选择。

 

可感知的产品质量:最终交付给用户的产品质量。经过前面4个步骤,执行过后,能够被客户认可和感知的质量,是经过分析、执行后得到的最终产物。 


02


 

HTSM中指导性词汇是测试的指南,其作用不是教导如何具体地测试,而是启发测试人员的思维,发掘测试对象和测试策略,重点在于"启发式”。HTSM对于测试设计的意义:

 

 (1)测试设计以风险驱动。测试人员分析质量标准、项目环境、产品元素中的风险,设计有针对性的测试策略。

 

 (2)在测试设计时,质量标准启发测试经验,项目环境启发测试过程,产品元素启发测试覆盖,观察到的质量启发测试报告。

 

 (3)对于测试,HTSM强调测试策略的多样性,平衡代价和收益,利用启发式方法充分发挥测试人员的技能。

 

在制定测试计划初稿时,测试人员可以更完整的地思考产品的方方面面,从而产生系统的测试计划。



在测试过程中,它也可以帮助测试人员组合测试想法、深入探索产品,以开发出强有力的测试策略。



在回归测试中,它同样可以帮助测试人员确定测试范围,制定测试方案。


03


HTSM是层次结构,其顶层元素(质量标准、项目环境、产品元素、测试技术)可以分解为次层元素,而这次层元素可进一步分解为第三层元素,对于第三层元素,团队可以根据团队特性和测试人员的认知能力,逐步去完善和修改,没有具体的约束。James Bach也给出了自己的思考和建议,形成了一张导图,把众多需要思考的小节点都给出对应的说明,有兴趣的同学可以学习下,值得借鉴,但不需要被它所固化,我们需要有更多的思考和总结,结合更新的测试技术能力和质量要求,不断改进它。


640.jpg


04


测试能力不仅仅是代码能力的比拼,还有众多的测试策略和理论体系需要去学习和补充。还有哪些好玩的测试理论呢?漫游测试和情景测试是什么,如何在实际的项目中应用呢?测试设计有哪些方法论和框架支撑?笔者会结合自己的测试经验,对测试理论做一次梳理,敬请期待。


往期推荐:

微服务的测试策略

微服务间的测试策略

单体微服务的测试策略

你还记得测试策略么

敏捷测试系列文章合集

相关文章
|
9天前
|
敏捷开发 人工智能 Devops
探索自动化测试的高效策略与实践###
当今软件开发生命周期中,自动化测试已成为提升效率、保障质量的关键工具。本文深入剖析了自动化测试的核心价值,探讨了一系列高效策略,包括选择合适的自动化框架、设计可维护的测试脚本、集成持续集成/持续部署(CI/CD)流程,以及有效管理和维护测试用例库。通过具体案例分析,揭示了这些策略在实际应用中的成效,为软件测试人员提供了宝贵的经验分享和实践指导。 ###
|
8天前
|
人工智能 前端开发 测试技术
探索软件测试中的自动化框架选择与优化策略####
本文深入剖析了当前主流的自动化测试框架,通过对比分析各自的优势、局限性及适用场景,为读者提供了一套系统性的选择与优化指南。文章首先概述了自动化测试的重要性及其在软件开发生命周期中的位置,接着逐一探讨了Selenium、Appium、Cypress等热门框架的特点,并通过实际案例展示了如何根据项目需求灵活选用与配置框架,以提升测试效率和质量。最后,文章还分享了若干最佳实践和未来趋势预测,旨在帮助测试工程师更好地应对复杂多变的测试环境。 ####
30 4
|
14天前
|
机器学习/深度学习 前端开发 测试技术
探索软件测试中的自动化测试框架选择与优化策略####
本文深入探讨了在当前软件开发生命周期中,自动化测试框架的选择对于提升测试效率、保障产品质量的重要性。通过分析市场上主流的自动化测试工具,如Selenium、Appium、Jest等,结合具体项目需求,提出了一套系统化的选型与优化策略。文章首先概述了自动化测试的基本原理及其在现代软件开发中的角色变迁,随后详细对比了各主流框架的功能特点、适用场景及优缺点,最后基于实际案例,阐述了如何根据项目特性量身定制自动化测试解决方案,并给出了持续集成/持续部署(CI/CD)环境下的最佳实践建议。 --- ####
|
1月前
|
缓存 监控 算法
软件测试中的性能瓶颈分析与优化策略
【10月更文挑战第6天】 性能测试是确保软件系统在高负载条件下稳定运行的重要手段。本文将深入探讨性能测试的常见瓶颈,包括硬件资源、网络延迟和代码效率等问题。通过具体案例分析,我们将展示如何识别并解决这些问题,从而提升软件的整体性能。最后,文章还将分享一些实用的性能优化技巧,帮助读者在日常开发和测试中更好地应对性能挑战。
86 3
|
1月前
|
机器学习/深度学习 人工智能 监控
提升软件质量的关键路径:高效测试策略与实践在软件开发的宇宙中,每一行代码都如同星辰般璀璨,而将这些星辰编织成星系的过程,则依赖于严谨而高效的测试策略。本文将引领读者探索软件测试的奥秘,揭示如何通过精心设计的测试方案,不仅提升软件的性能与稳定性,还能加速产品上市的步伐,最终实现质量与效率的双重飞跃。
在软件工程的浩瀚星海中,测试不仅是发现缺陷的放大镜,更是保障软件质量的坚固防线。本文旨在探讨一种高效且创新的软件测试策略框架,它融合了传统方法的精髓与现代技术的突破,旨在为软件开发团队提供一套系统化、可执行性强的测试指引。我们将从测试规划的起点出发,沿着测试设计、执行、反馈再到持续优化的轨迹,逐步展开论述。每一步都强调实用性与前瞻性相结合,确保测试活动能够紧跟软件开发的步伐,及时适应变化,有效应对各种挑战。
|
1月前
|
存储 数据管理 测试技术
提升软件测试效率的实用技巧与策略
在软件开发过程中,测试是一个至关重要的环节,它直接关系到产品质量和用户体验。本文将探讨几种实用的技巧和策略,帮助测试人员提升工作效率,确保软件质量。从测试自动化到持续集成,我们将一一解析这些方法如何优化测试流程。
|
28天前
|
测试技术 UED
软件测试中的“灰盒”方法:一种平衡透明度与效率的策略
在软件开发的复杂世界中,确保产品质量和用户体验至关重要。本文将探讨一种被称为“灰盒测试”的方法,它结合了白盒和黑盒测试的优点,旨在提高测试效率同时保持一定程度的透明度。我们将通过具体案例分析,展示灰盒测试如何在实际工作中发挥作用,并讨论其对现代软件开发流程的影响。
|
11天前
|
测试技术 持续交付 Docker
探索软件测试中的自动化策略与挑战
在当今快节奏的软件开发周期中,自动化测试已成为提高产品质量和缩短上市时间的关键。然而,实施有效的自动化测试策略并非易事,它面临着技术选型、脚本维护、环境配置等一系列挑战。本文深入探讨了自动化测试的重要性,分析了常见的自动化测试工具和框架,并讨论了在构建和维护自动化测试体系过程中遇到的主要难题及其解决方案。通过案例分析,本文旨在为软件测试工程师提供实用的指导和建议,以优化他们的自动化测试实践。
|
16天前
|
jenkins 测试技术 持续交付
软件测试中的自动化测试策略
在当今快速发展的软件行业中,自动化测试已成为确保软件质量和效率的关键工具。本文将探讨自动化测试的重要性、实施策略以及面临的挑战,旨在为软件开发团队提供实用的指导和建议。
|
16天前
|
测试技术 持续交付
探索软件测试的艺术:从基础到高级策略
【10月更文挑战第31天】本文是一篇深入探讨软件测试领域的指南,旨在为读者提供一个结构化的框架来理解并应用各种测试技术。文章将通过浅显易懂的语言和实际代码示例,带领读者从测试的基础概念出发,逐步深入到更复杂的测试策略。无论你是测试新手还是希望提升技能的专业人士,这篇文章都将为你揭示如何通过有效的软件测试保证产品质量和用户满意度。