测试左移,让质量反馈来得更高效,更可靠

简介: 大家好,我是阿萨。最近几年大家都在说测试左移。今天我们就聊聊测试左移的话题。

一. 之前交付的痛点


我们先来看看如下图片:


9d534028ee1440eb807e73ab0e64ac32_tplv-k3u1fbpfcp-zoom-in-crop-mark_4536_0_0_0.jpg


先看最左边的柱状图,L0,L1的很少部分测试在版本转测试前完成。剩余大量L3的测试工作遗留到上线前才测试。测试周期就会变长,尤其是遇到阻塞性问题的时候。更让质量反馈周期变得无法控制。随着项目需求量的增加,快速得到质量反馈就会更加难了。因为前期的测试不足,大量验证工作积攒到后期,交付压力不言而喻。


二. 未来的测试模型


针对以上问题,DevOps,持续集成,持续交付,持续部署肯定是不希望以上情况发生的。在DevOps里肯定期望更多的测试越早做越好。因此需要对测试进行分类,根据组件依赖关系和运行时间关系对测试进行分类。对别人依赖越小的,级别越低,就可以越早开始测试。让级别越低的做更多的测试。


三. 定义测试分类


比如用搭建幼儿园模型的积木打个比方。

1.L0,可能是独立的函数或者方法,不依赖任何其他对象。类似搭积木时最小块。

2.L1就是调用函数方法的组件。用几个积木搭建好幼儿园的大门,一堵墙等组件。

3.L2是几个组件合并成的功能。用大门和墙组建好幼儿园的围墙,教室,操持等功能区域。

4.L3是具有客户价值的可交付特性。用几个功能区域搭建成一个幼儿园模型。

通过在不同时间完成不同类别的测试,提早暴露风险。快速反馈软件质量。


四. 测试左移的基本原则


这里的测试左移除了测试级别分类,还列举了一些基本原则:

1.级别越低,越需要写更多的单元测试和验证。

2.所有测试脚本一旦开始写,就需要在任何地方都可以运行。甚至包括生产环境。

3.设计产品时就需要考虑其可测试性。

4.测试代码也是产品代码库里的资产。必须保证测试代码可靠性。所以测试代码要求也需要和生产环境代码要求一致。

5.测试基础架构也是一种共享服务。可运行的测试脚本也是产品代码的一部分,运行产品代码就需要运行测试代码。同时它需要在任何地方可运行,所以是共享服务。

6.谁写的代码,谁就有义务去测试自己所写代码。所以L2之前的测试都是开发去完成的。


五. 测试左移的目的


b5d4b8cf984e4ccf95f79dd621b98c41_tplv-k3u1fbpfcp-zoom-in-crop-mark_4536_0_0_0.jpg


通过上图的管道我们能更直观明白测试左移的含义。L0和L1执行更多 单元测试的验证,L2验证功能或者模块。L3仅验证客户可用的特性即可。左移的目标是 通过提前在管道中执行测试任务,将质量反馈从上游就开始。通过测试和流程改进的结合,大大减少了运行测试所花的时间,以及对后续产品的影响。 最重要的是,它可确保将更改合并到 主干之前,大部分测试也已完成 。 转测试前可能只需要验证客户关心的主业务流程即可。大大减少了测试所需要的时间。


六.总结


测试左移,就是对测试进行分层。尽早介入测试,越早越好。这样在后期只需要验证主流程即可。



相关文章
|
5天前
|
设计模式 测试技术 持续交付
深入白盒测试:提升软件质量与性能的关键策略
【4月更文挑战第20天】 在软件开发的复杂世界中,确保产品的质量和性能始终是至关重要的任务。白盒测试,作为软件测试领域的重要分支,提供了对程序内部结构和逻辑的深入分析手段。本文将探讨如何通过有效的白盒测试策略来优化软件性能,减少缺陷,并最终提高用户满意度。通过剖析代码检查、单元测试、集成测试等白盒测试技术,我们将了解这些方法如何揭示潜在的问题点,并为改进提供方向。
|
3天前
|
算法 测试技术 持续交付
深入白盒测试:提升软件质量与效率的关键策略
【4月更文挑战第23天】 在软件开发的复杂多变的环境中,确保产品的质量和可靠性是至关重要的。白盒测试作为一种重要的软件测试方法,允许测试者通过检查内部结构、设计和编码来验证软件的功能性和正确性。本文将探讨白盒测试的关键概念、技术及其在提升软件测试效率和质量中的应用。我们将重点讨论如何借助白盒测试发现潜在缺陷、优化测试用例设计,并通过具体案例分析展示其在实际中的应用效果。
|
4天前
|
算法 Java 测试技术
深入解析白盒测试:提升软件质量与效率的关键
【4月更文挑战第22天】 在软件开发的复杂多变的世界中,保证代码质量和功能的正确性是至关重要的。白盒测试作为一种重要的软件测试方法,提供了一种透视软件内部逻辑结构的途径。本文将详细探讨白盒测试的概念、技术手段和实际应用,旨在帮助读者理解如何通过这种测试提高软件系统的稳定性和性能。文章还将讨论白盒测试中面临的挑战以及应对策略,以期为软件质量保证提供实用的指导。
12 2
|
7天前
|
敏捷开发 Devops 测试技术
深入探索软件测试:保障质量的终极策略
【4月更文挑战第18天】在软件开发生命周期中,确保最终产品的质量至关重要,而软件测试则是达成这一目标的关键步骤。本文将探讨软件测试的多维度作用,包括其在不同开发阶段的应用、面临的挑战以及未来趋势。通过分析自动化测试工具的选择、测试用例设计的最佳实践和持续集成的重要性,文章为读者提供了一套全面的质量保证策略,旨在帮助团队提升测试效率并优化产品质量。
|
15天前
|
算法 测试技术 持续交付
深入探索白盒测试:提升软件质量的关键策略
【4月更文挑战第11天】 在软件开发的复杂世界中,确保代码的健康性与可靠性是至关重要的。白盒测试作为一种软件测试方法,允许测试者深入到程序的内部结构,以检查其逻辑和算法的正确性。本文将探讨白盒测试的核心概念、技术及其在提高软件质量方面的应用,特别是如何通过有效的白盒测试策略来优化测试过程并降低错误率。
|
15天前
|
jenkins 测试技术 持续交付
提升软件测试效率与质量的策略
【4月更文挑战第11天】在快速迭代的软件开发过程中,确保代码质量和减少缺陷至关重要。本文将深入探讨如何通过自动化测试、持续集成和敏捷测试方法来提高软件测试的效率和质量。我们将分析各种测试策略的优势与局限,并讨论如何根据项目需求定制测试计划。通过案例研究和最佳实践,我们的目标是为读者提供一套实用的工具和方法,以便在不断变化的技术环境中保持软件测试活动的高效性和适应性。
50 0
|
20天前
|
测试技术
深入白盒测试:提升软件质量与性能的关键策略
【4月更文挑战第6天】 在软件开发的生命周期中,确保代码质量和性能始终是至关重要的环节。白盒测试作为一种深入代码内部的测试方法,提供了对程序结构、逻辑路径和内部功能的全面评估。本文将探讨白盒测试的核心概念、技术及其在提升软件质量与性能方面的应用。通过分析控制流测试、数据流测试和静态代码分析等关键技术,我们揭示了白盒测试如何有效发现潜在缺陷,优化代码效率,并增强系统稳定性。
|
25天前
|
机器学习/深度学习 人工智能 算法
提升软件测试效率与质量的策略分析
在快速发展的信息技术时代,软件产品已成为日常生活和工作的核心组成部分。随着软件系统的复杂度日益增加,确保其功能性、稳定性及安全性的软件测试工作变得尤为重要。本文针对如何提升软件测试的效率与质量进行了深入探讨,分析了当前软件测试面临的挑战,并提出了一系列创新策略。这些策略包括采用自动化测试工具、实施持续集成和持续部署(CI/CD)、利用人工智能进行测试用例生成以及强化测试团队的技能培训等。通过综合运用这些策略,可以显著提高软件测试的质量和效率,减少人工成本,同时加速产品的上市时间。
|
1月前
|
安全 测试技术
【软件设计师备考 专题 】软件测试的原则与方法:确保软件质量的关键步骤
【软件设计师备考 专题 】软件测试的原则与方法:确保软件质量的关键步骤
41 0
|
1月前
|
算法 测试技术 开发者
软件质量测试笔记-合工大
软件质量测试笔记-合工大
101 1

热门文章

最新文章