敏捷测试价值观、方法和实践读书笔记(3)

简介: 本章节介绍敏捷测试转型框架,涵盖模型概览、实施难度与顺序、文化转变、角色技能需求及测试流程。敏捷测试转型模型包括文化、组织、流程与实践等关键要素,并针对各层面提出具体实施建议与障碍解决方案。此外,详细阐述了不同敏捷测试角色的技能需求与职责,以及从Sprint内至跨Sprint的测试流程与交付物。

第3章 敏捷测试转型框架

1 敏捷测试转型模型

敏捷测试转型模型概述

  • 文化
  • 组织
  • 流程
  • 实践
  • TDD
  • BDD
  • ATDD

实施重要程度和实施困难程度

  • 实施重要程度
  • 实施困难程度

敏捷测试转型模型实施顺序

  • 自顶向下:领导不重视
  • 自低向上:领导重视
  • 混合

2 敏捷测试文化

组织文化转变

  1. 小心变成“质量警察”
  2. 保持可持续的速度,而不是在项目的最后阶段进行快速激烈的测试
  3. 合作伙伴式的客户关系

管理文化转变

1.每个团队都有能力做出决策

一是外部相关,是指组织或需要赋权给团队,让团队有权利自己做出相关的决策

二是内部相关,是指团队必须有能力判断并做出正确的决策。

2.提倡免责文化

敏捷是基于经验的

3.管理层需要具备敏捷知识

Richard Knaster 和 Dean Leffingwell 在《SAFe4.0精粹:运用规模化敏捷框架实现精益软件与系统工程》中提道:“企业的领导者必须拥抱精益-敏捷”思维。如果领导者只是通过语言而不是自身的行动来支持“精益-敏捷”思维人们很快就会认识到他们不是在全心全意地推动变革。他们必须知晓方法,强调终身学习需要用新的行为践行这些价值观、原则和实践。所以在规模化敏捷 SAEe的系列培训课程中,专门有一门课程叫作Leading SAFe,主要对管理层和主管级别以上的领导进培训。

文化转型障碍及解决方法

1.组织变化带来的恐惧

在 Sprint 回顾会上正面讨论测试人员的恐惧,团队集思广益,共同解决

组织需要规划和制订属于测试人员的职业发展路线

2.缺乏对敏捷概念的基本认识

为测试人员提供敏捷相关知识培训

敏捷教练在辅导团队的时候,需要对这些没有敏捷经验的测试人员多加关注

3 无法满足更高的技能要求

成立测试实践社区

对于部分技能要求较高的岗位,可以考虑从外部招聘合适的人员来补充团队力量。

3 敏捷测试组织与个人

敏捷测试组织架构转变

组织架构转变后的测试人员的归属感问题

1 组织内成立卓越测试中心(Testing Center of Excellence)

卓越测试中心不能于涉和管理测试人,测试人员完全属于项目。

项目结束,测试人员回归卓越测试中心,准备再分配

2 成立测试实践社区(Testing Communities of Practice,TCoP)

传统测试人员的转变法则

敏捷测试专家 Lis Crispin 和 Janet Gregory 在合著的 Agile Testing: A Practical Guide for Testers and Agile Teams中列出了对于敏捷测试人员来说非常重要的 10 条法则。

  • 提供持续反馈:测试人员天生就是信息反馈者。
  • 为客户创造价值:测试人员比开发人员更了解客户需要什么。
  • 进行面对面沟通:业务团队和开发人员经常使用不同的语言,测试人员可以帮助他们拥有一种共通语言。
  • 勇气:要有勇气允许自己失败、他人失败,要有勇气寻求帮助。简单化: 通过最简单的方法验证功能已经达到客户的质量要求
  • 持续改进:努力把工作做得更好。
  • 响应变化:响应变化是敏捷实践的重要价值。
  • 自我组织:团队文化贯彻于敏捷测试理念。
  • 关注人:敏捷团队成员互相尊重并认可个人成就。
  • 享受乐趣:保持对工作的激情。

4 敏捷测试流程

Scrum层级与需求抽象层级

  • 产品组合规划
  • 产品规划
  • 版本规划
  • Sprint 规划
  • 日常规划(每日立会)

2.需求的不同抽象层级

  • 史诗
  • 特性
  • 用户故事
  • 任务
  • 主题

敏捷测试的类型

代码:质量扫描和单元测试 Sprint内

用户故事:验收标准进行测试 Sprint内

特性:用户故事之间如何协同工作,大部分Sprint内,小部分Sprint外

非功能性,比如性能测试,全程

Sprint 内测试

代码质量活动,如代码扫描等

单元测试

用户故事验收测试

部分特性和能力验收测试

跨 Sprint 测试

特性和能力验收测试

史诗验收测试

端到端集成测试

回归测试

敏捷测试角色

1.Sprint 内测试角色

(1)Sprint 内测试工程师。

(2)测试开发工程师(Software Development Engineer in Test,SDET)。

2.跨Sprint (版本发布级别)测试角色

(1)自动手铲架构师。

2)测试架构师

(3) 回归/发布/集成/UAT 测试工程师

(4) 测试经理

敏捷测试角色所需技能

(1)自动化架构师

自动化架构师必须完全掌握包括技术架构和 DevOps、环境/数据/监控、非UI和服务器虚拟化、UI自动化测试、测试执行、测试设计和测试管理等知识技能。

(2) 测试开发工程师

开发、技术架构和 DevOps、环境/数据/监控和服务虚拟化、UI自动化测试、测试执行等知识技能。

(3)Sprint内测试工程师

UI自动化测试、测试执行、测试设计和测试管理等知识技能。

(4)回归/发布/集成/UAT 测试工程师

非UI和服务虚拟化、UI自动化测试、测试执行、测试设计和测试管理等知识技能。

(5)测试架构师和测试经理

包括环境/数据/监控、非 UI 和服务虚拟化、UI自动化测试、测试执行、测试设计和测试管理等知识技能。

敏捷测试流程

类型

步骤

角色

描述

Sprint 内测试流程(针对每个用户故事)

1

产品负责人、团队

在本次 Sprint 开始前,产品负责人和敏捷实施团队一起梳理和角色产品负责人、团队准备用户故事 (《Scrum 精髓:敏捷转型指南》建议开发团队花费不超过 10%的工作时间参与需求梳理工作)

2

产品负责人、团队

在 Sprint 计划会上,产品负贵人和敏捷实施团队一起评审用户故事并确定验收标准

3

开发人员

在 Sprint 计划会后,开发人员针对需求进行特性分解,或者对用户故事进行技术设计或验证工作

4

Sprint 内测试工程师、测试开发工程师、回归/发布/集成/UAT 测试工程师

与步骤3 同时进行:Sprint 内测试工程师编写需求验收测试用例回归/发布/集成/UAT 测试工程师编写端到端验收测试用例测试开发工程师与 Sprint 内测试工程师、回归/发布/集成UAT 测试工程师共同编写需求验收和端到端的自动化测用例(脚本)

5

开发人员

在 Sprint 内的开发环境中,开发人员须遵从测试驱动开发(TDD)的规则,定义单元测试并编写代码,直到所有的单元测试通过。另外,还需要运行代码扫描工具进行代码质量检查

6

开发人员、测试开发工程师、Sprint内测试开发工程师和 Sprint 内测试工程师合并需求验收自动化测测试工程师

与步骤 5 同时进行:测试开发工程师和 Sprint 内测试工程师合并需求验收自动化测试用例到CI/CD部署流水线

7

回归/发布/集成/UAT 测试工程师

与步骤 5 同时进行:回归/发布/集成/UAT测试工程师把准备好的端到端验收自动化测试用例合并到端到端回归测试用例集

8

开发人员

开发人员将代码提交并合并到服务端代码主干,触发 DevOps部署流水线

9

NA

CI流程自动构建被测应用,执行静态代码扫描和自动化单元测试。如果通过“质量门”,那么二进制代码的应用将被部署到CICD 的测试环境中

10

NA

CICD 流程执行自动化验收测试(包括 API和UI)

11

Sprint 内测试工程师

Sprint 内测试工程师进行探索式测试,如发现缺陷立即反馈给开发人员修复并执行回归测试。运行所有安全扫描测试,最后完成用户故事的测试

跨 Sprint测试流程(本次版本所有已完成用户故事)

12

产品负责人、团队、利益干系人等

在本次 Sprint的所有用户故事通过测试后,进行 Sprint 演示如果演示通过,那么表示本次 Sprint 结束,此时将已接受的用户故事设置为已完成

13

NA

如果通过“质量门”,CI/CD 流程将部署候选版本到系统测试环境,并且运行端到端的自动化回归测试集

14

回归/发布/集成/UAT 测试工程师

回归/发布/集成/UAT 测试工程师执行端到端探索式测试。如果有缺陷,就将缺陷加入产品待办列表并排列优先级

15

NA

达到预发布状态


敏捷测试交付物

Sprint 内测试交付物列表

测试交付物

描述

测试工件

Sprint 内测试的输出物(测试计划、测试用例、测试报告等),并且通过测试管理工具记录,或者根据需要检入配置管理工具

测试自动化工件

自动化配套结构,包括:·Page Objects (模块/组件)·已封装的通用功能·步骤定义(如果正在使用 BDD/ATDD)·己评审的自动化脚本

测试数据

需求定义的业务数据,以及团队需要准备或提供的数据

缺陷

可能不会作为正式缺陷在缺陷管理系统中进行跟踪,但会在 Sprint 中得到处理。当需要延迟解决时,可以作为一个用户故事添加到产品待办列表中

虚拟服务

为支持 Sprint 内测试而开发的可以使用的虚拟服务

跨Sprint 测试交付物列表

测试交付物

描述

版本发布级别测试策略

版本发布级别的总体测试策略,定义将要进行的所有类型的测试,同时概述包括工具、度量标准和沟通计划等公共部分

测试工件

跨 Sprint 范围内测试的输出物(测试计划、测试用例、测试报告等),并且通过测试管理工具记录,或者根据需要检入配置管理工具。 利用来自Sprint 内功能测试(不是单元测试)的可重用部分,如可重用的 PageObjects

测试数据

对于跨 Sprint测试范围,团队能够很好地理解并准备或提供数据

缺陷

缺陷记录在缺陷管理系统中并进行跟踪,同时报告质量度量

发布测试计划

定义发布的测试范围、环境、依赖、资源、时间框架和退出标准

虚拟服务

为支持集成/回归测试而开发的可使用的虚拟服务

发布测试结束备忘录

测试结果和交付/质量度量的总结

目录
相关文章
|
1天前
|
机器学习/深度学习 人工智能 测试技术
软件测试中的自动化测试实践与挑战
本文深入探讨了软件测试领域中的自动化测试,从基本概念到实际应用案例,揭示了自动化测试在提升软件开发效率和质量中的关键作用。同时,文章也分析了在实施自动化测试过程中面临的主要挑战,并提出了相应的解决策略。
12 5
|
2天前
|
Ubuntu jenkins 测试技术
软件测试中的自动化与持续集成实践
【9月更文挑战第15天】在软件开发的快节奏世界中,自动化测试和持续集成(CI)已成为确保质量和效率的关键策略。本文旨在揭示如何通过实施自动化测试框架和CI流程来优化开发周期,减少人为错误,并加快产品上市时间。我们将探讨一些实用的工具和技术,以及它们如何帮助团队实现更流畅、更可靠的软件发布。
|
3天前
|
监控 jenkins 测试技术
软件测试中的自动化测试策略与实践
本文将深入探讨自动化测试在软件开发中的重要性及其实施策略。我们将从自动化测试的基本概念入手,分析其在提高软件质量、缩短开发周期和降低维护成本方面的优势。通过具体案例,展示如何有效地规划和执行自动化测试,以及如何评估其效果。
13 1
|
4天前
|
Devops jenkins 测试技术
敏捷测试价值观、方法和实践读书笔记(10)
本文介绍了敏捷测试的延伸实践,重点讨论了持续集成(CI)和持续部署(CD)的概念与实践方法。持续集成强调频繁提交代码至主干并自动化构建测试,确保快速反馈和高质量代码。持续部署则进一步实现自动化部署,通过蓝绿部署、金丝雀发布等方式提升软件交付效率。此外,文章还探讨了持续反馈机制,如A/B测试和混沌工程,以及DevOps文化下的测试策略,强调测试在整个开发流程中的重要性。
11 0
敏捷测试价值观、方法和实践读书笔记(10)
|
4天前
|
XML 存储 API
敏捷测试价值观、方法和实践读书笔记(8)
本文介绍了API的基础知识,区分了Web Service和Web API的概念,详细阐述了Web Service中的SOAP服务和REST服务的特点及区别。同时,文章还探讨了如何在项目中进行API测试,包括API测试的类型和实施阶段,强调了API在现代软件开发中的重要性和优势。
6 0
敏捷测试价值观、方法和实践读书笔记(8)
|
1天前
|
敏捷开发 人工智能 测试技术
提升软件质量的关键——高效软件测试策略与实践
在软件开发过程中,测试是一个至关重要的环节。它不仅决定了产品的可靠性和用户体验,还直接影响到企业的声誉和市场竞争力。本文将详细探讨如何通过科学的测试策略和方法,确保软件质量达到高标准的要求。从测试流程的设计、自动化测试工具的应用,到持续集成和持续部署的实践,我们将全面解析如何在软件开发中实施有效的测试,以降低错误率,缩短上市时间,并提供优质的软件产品。
12 0
|
1天前
|
敏捷开发 测试技术 UED
软件测试中的探索性测试方法
在软件开发过程中,测试是确保产品质量的重要环节。本文将探讨一种常被忽视但极其重要的测试方法——探索性测试。通过分析其定义、优势及实际应用案例,揭示如何更有效地发现软件缺陷,提升软件质量。
5 0
|
3天前
|
测试技术 持续交付
软件测试中的自动化测试实践与探索
在软件开发生命周期中,测试阶段是确保产品质量和稳定性的关键环节。随着技术的快速发展,自动化测试逐渐成为提升测试效率和覆盖率的重要手段。本文将探讨自动化测试的基本概念、工具选择、实施策略以及面临的挑战,旨在为读者提供关于如何在项目中有效应用自动化测试的指导性见解。
8 0
|
4天前
|
测试技术 UED 开发者
《敏捷测试价值观、方法与价值观》读书笔记(9)
本章节聚焦于非功能性测试,尤其深入探讨了可用性测试的重要性和实施方法。首先,阐述了可用性原则如简洁设计、一致性及高效性等,并强调用户而非开发者才是评判应用易用性的关键。接着介绍了可用性测试的不同技术和环境需求,包括卡片分类、结构化评估等方法,并讨论了测试实验室的具体配置。此外,详细说明了测试过程中的计划、执行、分析阶段,涵盖了从测试目标设定到测试结果优化的全流程。同时,还提供了测试参与者招募标准、测试材料准备及执行过程中注意事项的具体示例。最后,指导如何整合与分类测试结果,以及生成可用性测试报告的方法。
7 0
|
5天前
|
移动开发 JSON Java
Jmeter实现WebSocket协议的接口测试方法
WebSocket协议是HTML5的一种新协议,实现了浏览器与服务器之间的全双工通信。通过简单的握手动作,双方可直接传输数据。其优势包括极小的头部开销和服务器推送功能。使用JMeter进行WebSocket接口和性能测试时,需安装特定插件并配置相关参数,如服务器地址、端口号等,还可通过CSV文件实现参数化,以满足不同测试需求。
30 7
Jmeter实现WebSocket协议的接口测试方法