敏捷测试价值观、方法和实践读书笔记(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测试范围,团队能够很好地理解并准备或提供数据

缺陷

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

发布测试计划

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

虚拟服务

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

发布测试结束备忘录

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

目录
相关文章
|
3天前
|
敏捷开发 人工智能 Devops
探索自动化测试的高效策略与实践###
当今软件开发生命周期中,自动化测试已成为提升效率、保障质量的关键工具。本文深入剖析了自动化测试的核心价值,探讨了一系列高效策略,包括选择合适的自动化框架、设计可维护的测试脚本、集成持续集成/持续部署(CI/CD)流程,以及有效管理和维护测试用例库。通过具体案例分析,揭示了这些策略在实际应用中的成效,为软件测试人员提供了宝贵的经验分享和实践指导。 ###
|
3天前
|
机器学习/深度学习 人工智能 jenkins
软件测试中的自动化与持续集成实践
在快速迭代的软件开发过程中,自动化测试和持续集成(CI)是确保代码质量和加速产品上市的关键。本文探讨了自动化测试的重要性、常见的自动化测试工具以及如何将自动化测试整合到持续集成流程中,以提高软件测试的效率和可靠性。通过案例分析,展示了自动化测试和持续集成在实际项目中的应用效果,并提供了实施建议。
|
3天前
|
Java 测试技术 持续交付
探索自动化测试在软件开发中的关键作用与实践
在现代软件开发流程中,自动化测试已成为提升产品质量、加速交付速度的不可或缺的一环。本文深入探讨了自动化测试的重要性,分析了其在不同阶段的应用价值,并结合实际案例阐述了如何有效实施自动化测试策略,以期为读者提供一套可操作的实践指南。
|
3天前
|
Web App开发 敏捷开发 测试技术
探索自动化测试的奥秘:从理论到实践
【10月更文挑战第39天】在软件质量保障的战场上,自动化测试是提升效率和准确性的利器。本文将深入浅出地介绍自动化测试的基本概念、必要性以及如何实施自动化测试。我们将通过一个实际案例,展示如何利用流行的自动化测试工具Selenium进行网页测试,并分享一些实用的技巧和最佳实践。无论你是新手还是有经验的测试工程师,这篇文章都将为你提供宝贵的知识,帮助你在自动化测试的道路上更进一步。
|
3天前
|
敏捷开发 Java 测试技术
探索自动化测试:从理论到实践
【10月更文挑战第39天】在软件开发的海洋中,自动化测试是一艘能够带领团队高效航行的船只。本文将作为你的航海图,指引你理解自动化测试的核心概念,并分享一段实际的代码旅程,让你领略自动化测试的魅力和力量。准备好了吗?让我们启航!
|
8天前
|
测试技术 API Android开发
探索软件测试中的自动化框架选择与实践####
本文深入探讨了软件测试领域内,面对众多自动化测试框架时,如何依据项目特性和团队需求做出明智选择,并分享了实践中的有效策略与技巧。不同于传统摘要的概述方式,本文将直接以一段实践指南的形式,简述在选择自动化测试框架时应考虑的核心要素及推荐路径,旨在为读者提供即时可用的参考。 ####
|
14天前
|
Java 测试技术 Maven
Java一分钟之-PowerMock:静态方法与私有方法测试
通过本文的详细介绍,您可以使用PowerMock轻松地测试Java代码中的静态方法和私有方法。PowerMock通过扩展Mockito,提供了强大的功能,帮助开发者在复杂的测试场景中保持高效和准确的单元测试。希望本文对您的Java单元测试有所帮助。
27 2
|
18天前
|
监控 安全 jenkins
探索软件测试的奥秘:自动化测试框架的搭建与实践
【10月更文挑战第24天】在软件开发的海洋里,测试是确保航行安全的灯塔。本文将带领读者揭开软件测试的神秘面纱,深入探讨如何从零开始搭建一个自动化测试框架,并配以代码示例。我们将一起航行在自动化测试的浪潮之上,体验从理论到实践的转变,最终达到提高测试效率和质量的彼岸。
|
13天前
|
NoSQL 测试技术 Go
自动化测试在 Go 开源库中的应用与实践
本文介绍了 Go 语言的自动化测试及其在 `go mongox` 库中的实践。Go 语言通过 `testing` 库和 `go test` 命令提供了简洁高效的测试框架,支持单元测试、集成测试和基准测试。`go mongox` 库通过单元测试和集成测试确保与 MongoDB 交互的正确性和稳定性,使用 Docker Compose 快速搭建测试环境。文章还探讨了表驱动测试、覆盖率检查和 Mock 工具的使用,强调了自动化测试在开源库中的重要性。
|
19天前
|
测试技术 Python
软件测试的艺术:从理论到实践的探索
【10月更文挑战第23天】在软件开发的世界中,测试是确保产品质量的关键步骤。本文将深入探讨软件测试的核心理念、方法和实践,揭示如何通过精心设计和执行测试来提高软件质量。我们将一起探索测试的不同阶段,包括单元测试、集成测试、系统测试和验收测试,以及它们如何相互补充,共同构建起一个坚实的质量保证体系。文章旨在启发读者思考如何在自己的项目中实施有效的测试策略,从而提升软件的可靠性和性能。