测试左移,使质量反馈更快速,更可靠

简介: 测试左移,使质量反馈更快速,更可靠

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


一. 之前交付的痛点


我们先来看看如下图片:


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


二. 未来的测试模型


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


三. 定义测试分类


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

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

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

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

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


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


四. 测试左移的基本原则


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


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


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


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


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


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


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


五. 测试左移的目的




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


六.总结


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


注:本文内容参考https://docs.microsoft.com/zh-cn/devops/develop/shift-left-make-testing-fast-reliable?cid=kerryherger


相关文章
|
2月前
|
测试技术 持续交付 UED
软件测试的艺术:确保质量的实战策略
在软件开发的舞台上,测试是那把确保每个功能如交响乐般和谐奏响的指挥棒。本文将深入探讨软件测试的重要性、基本类型以及如何设计高效的测试策略。我们将通过一个实际的代码示例,展示如何运用这些策略来提升软件质量和用户体验。
|
2月前
|
jenkins 测试技术 持续交付
软件测试中的自动化与持续集成:提升效率与质量的关键
在快节奏的软件开发环境中,自动化测试和持续集成已经成为不可或缺的部分。本文将探讨自动化测试和持续集成的重要性,以及它们如何协同工作以提高软件开发的效率和质量。通过分析自动化测试的策略、工具选择以及持续集成的实践,我们将揭示这些技术如何帮助开发团队快速响应变化,减少错误,并加速产品上市时间。
|
2月前
|
测试技术 开发者 Python
自动化测试之美:从零构建你的软件质量防线
【10月更文挑战第34天】在数字化时代的浪潮中,软件成为我们生活和工作不可或缺的一部分。然而,随着软件复杂性的增加,如何保证其质量和稳定性成为开发者面临的一大挑战。自动化测试,作为现代软件开发过程中的关键实践,不仅提高了测试效率,还确保了软件产品的质量。本文将深入浅出地介绍自动化测试的概念、重要性以及实施步骤,带领读者从零基础开始,一步步构建起属于自己的软件质量防线。通过具体实例,我们将探索如何有效地设计和执行自动化测试脚本,最终实现软件开发流程的优化和产品质量的提升。无论你是软件开发新手,还是希望提高项目质量的资深开发者,这篇文章都将为你提供宝贵的指导和启示。
|
3月前
|
机器学习/深度学习 人工智能 监控
提升软件质量的关键路径:高效测试策略与实践在软件开发的宇宙中,每一行代码都如同星辰般璀璨,而将这些星辰编织成星系的过程,则依赖于严谨而高效的测试策略。本文将引领读者探索软件测试的奥秘,揭示如何通过精心设计的测试方案,不仅提升软件的性能与稳定性,还能加速产品上市的步伐,最终实现质量与效率的双重飞跃。
在软件工程的浩瀚星海中,测试不仅是发现缺陷的放大镜,更是保障软件质量的坚固防线。本文旨在探讨一种高效且创新的软件测试策略框架,它融合了传统方法的精髓与现代技术的突破,旨在为软件开发团队提供一套系统化、可执行性强的测试指引。我们将从测试规划的起点出发,沿着测试设计、执行、反馈再到持续优化的轨迹,逐步展开论述。每一步都强调实用性与前瞻性相结合,确保测试活动能够紧跟软件开发的步伐,及时适应变化,有效应对各种挑战。
|
2月前
|
敏捷开发 监控 测试技术
软件测试中的自动化策略:提升效率与质量
在软件开发过程中,测试是确保产品质量的关键环节。随着敏捷开发模式的普及,自动化测试成为提升测试效率和质量的重要手段。本文将介绍自动化测试的基本概念、实施步骤以及如何通过自动化测试提高软件测试的效率和质量,同时分享一些实用的自动化测试工具和技巧。
68 3
|
2月前
|
机器学习/深度学习 人工智能 自然语言处理
自动化测试的新篇章:利用AI提升软件质量
【10月更文挑战第35天】在软件开发的海洋中,自动化测试犹如一艘救生艇,它帮助团队确保产品质量,同时减少人为错误。本文将探索如何通过集成人工智能(AI)技术,使自动化测试更加智能化,从而提升软件测试的效率和准确性。我们将从AI在测试用例生成、测试执行和结果分析中的应用出发,深入讨论AI如何重塑软件测试领域,并配以实际代码示例来说明这些概念。
81 3
|
3月前
|
敏捷开发 监控 jenkins
自动化测试之美:打造高效的软件质量保障体系
【10月更文挑战第20天】在软件开发的海洋中,自动化测试如同一艘精准的导航船,引领项目避开错误的礁石,驶向质量的彼岸。本文将扬帆起航,探索如何构建和实施一个高效的自动化测试体系,确保软件产品的稳定性和可靠性。我们将从测试策略的制定、工具的选择、脚本的编写,到持续集成的实施,一步步描绘出自动化测试的蓝图,让读者能够掌握这一技术的关键要素,并在自己的项目中加以应用。
43 5
|
3月前
|
Java 测试技术 持续交付
探索自动化测试的奥秘:提升软件质量的关键
【10月更文挑战第20天】 在当今快速发展的软件行业中,自动化测试已成为确保产品质量和加速开发周期的重要工具。本文将深入探讨自动化测试的核心概念、实施策略及其对软件开发生命周期的影响,旨在为读者提供一种全面理解自动化测试的视角,并展示如何有效地将其应用于实际项目中以提高软件质量和效率。
36 2
|
3月前
|
测试技术
软件质量保护与测试(第2版)学习总结第十一章 白盒测试
本文是《软件质量保护与测试》(第2版)第十一章的学习总结,详细讲解了白盒测试中的控制流测试技术,包括语句覆盖、判断覆盖、条件覆盖、判定-条件覆盖和路径覆盖等方法,并通过具体代码示例展示了如何设计测试用例来验证程序中的不同执行路径。
81 2
|
3月前
|
测试技术 UED
软件测试中的探索性测试:一种创新的质量保证方法
在软件开发的生命周期中,测试阶段扮演着至关重要的角色。传统的软件测试方法,如自动化测试和回归测试,虽然在一定程度上保证了软件质量,但它们往往依赖于预定义的测试用例和脚本,可能无法覆盖所有用户场景和边缘情况。为了克服这些限制,探索性测试作为一种创新的质量保证方法应运而生。本文将深入探讨探索性测试的概念、优势以及如何有效地实施它,以帮助读者更好地理解和应用这种测试技术。