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

简介: 敏捷软件开发宣言在身体力行的同时也帮助我们一直在实践中探寻更好的软件开发方法。由此,我们建立了如下价值观:个体和互动 高于 流程和工具工作的软件,高于 详尽的文档客户合作, 高于 合同谈判响应变化,高于 遵循计划。也就是说,尽管右项有其价值,但我们更重视左项的价值。

第1章 敏捷的定义

1776 年,英国的亚当·斯密在《国富论》中首次提出劳动分工的概念,成为工程管理相关思想的萌芽和发展的里程碑。

20 世纪初,美国的泰勒及海尔和雷斯夫妇等工程师们经过不断研究和探索,提出了科学管理和提高生产力的原则,为工业工程的发展做出了极大贡献,而奉勒更被誉为“工业工程之父”

1913 年,福特公司实验了第一条汽车流水线。流水线使汽车的组老制造时闻大大缩短,工人的效率也极大提升,福特公司的T型车产量因此占据当时全世界汽车总产量的一半以上。

工业工程推动软件工程,提出:JIT JustIn-Time)的精益理念和看板_(Kanban)等。

第一个程序早在 1842 年就被设出来了,负责设计程序的人是Ada Lovelace。她父亲是英国著名诗人拜伦

1968年,为了解决软件开发的混乱状态,当时的北大西洋公约组织 (NATO) 在德国小城举行了次学术会议,这次会议被命名为“软件工程大会”,标志着软件工程学科的诞生。

1970年,美国计算机科学家温斯顿·罗伊斯(Winston Royce)在发表的文章《管理大型软件系统的开发》中首次提出了著名的瀑布模型。

1 什么是敏捷

敏捷类型

1994 年,英国一个由 17 家公司发起的联盟提出了动态系统开发方法 (Dynamic Systems Development Method、DSDM)

1995 年,美国软件开发专家Jef Sutherland 和 Ken Schwaber 共同提出了 Scrum开发框架

1996年,美国软件开发大师,同时也是 JUnit 作者的 Kent Beck 提出了极限编程(Extreme Programming,简称XP)

1996年,Alistair Cockburn 和Jim Highsmith 共同提出了水晶方(Crystal)

1997 年,Jeff De Luca、Eric Lefebvre 和 Peter Coad 一起提出了特性驱动开发(Feature Driven Development , FDD)

2001年,17 位来自 DSDM、Scrum、XP、FDD 等流派的专家代表在美国犹他州一个名为雪鸟的滑雪胜地齐聚一堂,提出敏捷宣言

敏捷软件开发宣言

敏捷软件开发宣言在身体力行的同时也帮助我们一直在实践中探寻更好的软件开发方法。由此,我们建立了如下价值观:个体和互动 高于 流程和工具工作的软件,高于 详尽的文档客户合作, 高于 合同谈判响应变化,高于 遵循计划。也就是说,尽管右项有其价值,但我们更重视左项的价值。Kent Beck James Grenning Robert C. MartinMike Beedle Jim Highsmith Steve MellorArie van Bennekum Andrew Hunt Ken SchwaberAlistair Cockburn Ron Jeffries Jeff Sutherland Ward Cunningham Jon Kem Dave ThomasMartin Fowler Brian Marick

敏捷宣言遵循的原则

敏捷宣言遵循的原则我们遵循以下原则:

1.我们最重要的目标,是通过持续不断地及早交付有价值的软件使客户满意。

2.欣然面对需求变化即使在开发后期也一样。为了客户的竞争优势,敏捷过程掌控变化。

3.经常地交付可工作的软件,相隔几星期或一两个月,倾向于采取较短的周期。

4.业务人员和开发人员必须相互合作,项目中的每一天都不例外。

5.激发个体的斗志,以他们为核心搭建项目。提供所需的环境和支援,辅以信任,从而达成目标。

6.不论团队内外,传递信息效果最好、效率最高的方式是面对面交谈。

7.可工作的软件是进度的首要度量标准。

8.敏捷过程倡导可持续开发。责任人、开发人员和用户要能够共同维持其步调稳定延续。

9.坚持不懈地追求技术卓越和良好设计,敏捷能力由此增强。

10.以简洁为本,它是极力减少不必要工作量的艺术。

11.最好的架构、需求和设计出自自组织团队。

12.团队定期反思如何能提高成效,并以此调整自身的举止表现。

2 敏捷定义

(1)敏捷是一系列方法,如XP、Scrum、Lean 等的总称,其目的是通过选代和增量的开发,以及经常性地检视和调整来提升项目的管理和交付水平。

首先,敏捷并不是某种具体的方法,而是各种方法的总称

其次,敏捷是通过造代和增量的方式来进行开发的

最后,敏捷通过经常性地检视和调整来提升项目管理和交付水平

(2) 敏捷不只是一个新的流程,还要用新的文化方式来进行软件开发

敏捷涉及的不仅是流程,还有文化、理念、组织等方面的转变

(3) 需求和解决方案通过自组织、跨职能团队之间的协作而发展

强调敏捷团队需要是自组织且跨职能的团队,因为只有跨职能的团队才能最大限度地提升沟通和执行效率。

3 敏捷Scrum介绍

起源

根据 CollabNet VersionOne 在2019 年公布的第 13 届年度敏告,Scrum 在敏捷方法的使用占比高居第一,达到了 54%。

核心内容

“3355”:Scrum框架

3个重要角色

3个重要工件

5个重要事件

5 个价值观

3 个角色

(1)产品负责人(Product Owner)

(2)Developers

(3)Scrum Master

3个重要工件

(1)产品待办列表(Product Backlog): 产品的需求列表,由 PBI (ProductBackloItem)组成。PBI一般包括新特性、变更、缺陷或技术改进需求等。

(2)选代待办列表(Sprint Backlog):每次 Sprint 选代需要完成的需求列表集

(3)产品增量(Increment):当次选代中完成的可交付的工作输出件

5 个重要事件

(1)Sprint

(2)Sprint 计划会(Sprint Planning Meeting)

(3)每日站会(Daily Scrum Meeting)

(4)Sprint 评审会(Sprint Review Meeting)

(5)Sprint 回顾会 (Sprint Retrospective Meeting)

需求梳理(Requirement Refinement)

DEEP原则,如下所示。

适当的细节(DetailAppropriately)

不断涌现(Emergent)

经过估算 (Estimated)

经过排序(Prioritized)

5个价值观

(1)勇气 (Courage)

(2)公开(Openness)

(3)专注(Focus)

(4)承诺(Commitment)

(5)尊重(Respeet)

4 规模化敏捷

SAFe 框架

主导设计者 Dean Lefingwell

SAFe 框架的核心理念是,通过在 Scrum 的基础上增加不同的层级和角色来应对大项目、大型复杂解决方案,甚至是产品组合管理对于敏捷的需要。

SAFe 分层结构是从团队级(Team Level)->项目群级(ProgramLevel)->价值流级(Value StreanLevel)->投资组合级 (Portfolio Level)

在此过程中合了精益-敏捷、质量内建、系统思考、排队论等知识体系。

CollabNet VersionOne 在2019 年公布的第13 届年度敏捷状态报告,SAFe框众多规模化敏捷体系中的占比最高,达到30%。

SAFe的基本原理

根据其作者,SAFe基于十个基本概念,这些概念源自现有的精益和敏捷原则以及观察:

1.Take an economic view

2.Apply systems thinking

3.Assume variability; preserve options

4.Build incrementally with fast integrated learning cycles

5.Base milestones on objective evaluation of working systems

6.Visualize and limit work-in-progress, reduce batch sizes, and manage queue lengths

7.Apply cadence (timing), synchronize with cross-domain planning

8.Unlock the intrinsic motivation of knowledge workers

9.Decentralize decision-making

10.Organize around value

1.从经济角度来看

2.运用系统思维

3.假设可变性;保留选项

4.通过快速集成的学习周期逐步构建

5.基于工作系统的客观评估的里程碑

6.可视化和限制正在进行的工作,减少批量大小,并管理队列长度

7.应用节奏(计时),与跨领域规划同步

8.释放知识工作者的内在动力

9.分散决策

10.围绕价值进行组织

在SAFe 5.0版中,有四种配置:

Essential SAFe (基本SAFe):描述了所需的最关键要素,旨在提供大多数框架收益。它包括团队和程序级别(称为敏捷发布培训或ART)。

Large Solution (大型解决方案):SAFe允许跨多个程序进行协调和同步,但无需考虑产品组合。在SAFe的早期版本中,此级别称为“ 价值流”。

SAFe Portfolio SAFe(SAFe投资组合SAFe) :包括对战略方向,投资资金和精益治理的关注。

Full SAFe(完整SAFe):结合了其他三个级别

Scrum@Scale 框架

创建者 Jef Sutherland

两个好朋友

Jef Sutherland 和 Ken Schwaber:共创Scrum

Jef Sutherland:Scrum@Scale

Ken Schwaber:Nexus

ScrumMaster 循环(Scrum Master Cycle):How

产品负责人循环(Product Owner Cycle):Wat

LeSS 框架

LeSS是 Large Scale Scrum 的简写,由 Bas Vodde和 Craig Larman 共同设计并率先队扩展和协调的问题诺基亚公司的网络部门进行实践

“less is more”,“请神容易送神难”,以后想要去掉这个色就会非常困难,所以,LeSS 框架的理念和 SAFe 框架存在很大不同。

其他大规模敏捷框架,如

·纪律敏捷交付(DAD):Scott Ambler提出

·Spotify:亨利克·尼伯格

·Nexus

目录
相关文章
|
1月前
|
数据采集 监控 机器人
浅谈网页端IM技术及相关测试方法实践(包括WebSocket性能测试)
最开始转转的客服系统体系如IM、工单以及机器人等都是使用第三方的产品。但第三方产品对于转转的业务,以及客服的效率等都产生了诸多限制,所以我们决定自研替换第三方系统。下面主要分享一下网页端IM技术及相关测试方法,我们先从了解IM系统和WebSocket开始。
48 4
|
1月前
|
人工智能 JavaScript 前端开发
自动化测试框架的演进与实践###
本文深入探讨了自动化测试框架从诞生至今的发展历程,重点分析了当前主流框架的优势与局限性,并结合实际案例,阐述了如何根据项目需求选择合适的自动化测试策略。文章还展望了未来自动化测试领域的技术趋势,为读者提供了宝贵的实践经验和前瞻性思考。 ###
|
1月前
|
测试技术 Python
探索软件测试的深度与广度:从理论到实践
在数字化时代,软件已成为我们生活中不可或缺的一部分。随着技术的不断进步和用户需求的多样化,确保软件质量变得尤为重要。本文将深入浅出地介绍软件测试的核心概念、类型及其在软件开发生命周期中的重要性。我们将通过实际案例,展示如何实施有效的测试策略,并探讨自动化测试的未来趋势,旨在为读者提供一套完整的软件测试知识体系,帮助提升软件质量和开发效率。
|
1月前
|
测试技术 Python
探索软件测试的奥秘:从理论到实践
在软件开发的宇宙中,软件测试犹如一颗璀璨的星辰,指引着质量的方向。本文将带你穿梭于软件测试的理论与实践之间,揭示其内在的逻辑和魅力。从测试的重要性出发,我们将探讨不同类型的测试方法,并通过实际案例分析,深入理解测试用例的设计和应用。最后,我们将通过一个代码示例,展示如何将理论知识转化为实际操作,确保软件质量的同时,也提升你的测试技能。让我们一起踏上这段探索之旅,发现软件测试的无限可能。
|
1月前
|
jenkins 测试技术 持续交付
自动化测试框架的搭建与实践
在软件开发领域,自动化测试是提升开发效率、确保软件质量的关键手段。本文将引导读者理解自动化测试的重要性,并介绍如何搭建一个基本的自动化测试框架。通过具体示例和步骤,我们将探索如何有效实施自动化测试策略,以实现软件开发流程的优化。
70 7
|
1月前
|
测试技术
探索软件测试的奥秘:从理论到实践
本文深入探讨了软件测试的基本概念、重要性、主要类型以及实施策略。通过分析不同测试阶段和相应的测试方法,文章旨在为读者提供一套完整的软件测试知识体系,帮助他们更好地理解和应用测试技术,确保软件产品的质量和可靠性。
67 4
|
2月前
|
存储 算法 C语言
用C语言开发游戏的实践过程,包括选择游戏类型、设计游戏框架、实现图形界面、游戏逻辑、调整游戏难度、添加音效音乐、性能优化、测试调试等内容
本文探讨了用C语言开发游戏的实践过程,包括选择游戏类型、设计游戏框架、实现图形界面、游戏逻辑、调整游戏难度、添加音效音乐、性能优化、测试调试等内容,旨在为开发者提供全面的指导和灵感。
53 2
|
30天前
|
监控 搜索推荐 测试技术
电商API的测试与用途:深度解析与实践
在电子商务蓬勃发展的今天,电商API成为连接电商平台、商家、消费者和第三方开发者的重要桥梁。本文深入探讨了电商API的核心功能,包括订单管理、商品管理、用户管理、支付管理和物流管理,并介绍了有效的测试技巧,如理解API文档、设计测试用例、搭建测试环境、自动化测试、压力测试、安全性测试等。文章还详细阐述了电商API的多样化用途,如商品信息获取、订单管理自动化、用户数据管理、库存同步、物流跟踪、支付处理、促销活动管理、评价管理、数据报告和分析、扩展平台功能及跨境电商等,旨在为开发者和电商平台提供有益的参考。
40 0
|
2月前
|
人工智能 数据管理 jenkins
探索软件测试中的自动化框架:从基础到高级实践
在当今快速发展的软件行业中,自动化测试已成为提高开发效率和保障产品质量的关键手段。本文将深入探讨软件测试自动化的各个方面,包括其重要性、主流的自动化测试框架、以及如何有效地实施自动化测试策略。我们还将通过案例分析,展示自动化测试在实际项目中的应用效果,以及面临的挑战和解决方案。无论是软件开发者还是测试工程师,了解并掌握自动化测试技术都将极大提升工作效率和产品质量。
52 0
|
19天前
|
监控 JavaScript 测试技术
postman接口测试工具详解
Postman是一个功能强大且易于使用的API测试工具。通过详细的介绍和实际示例,本文展示了Postman在API测试中的各种应用。无论是简单的请求发送,还是复杂的自动化测试和持续集成,Postman都提供了丰富的功能来满足用户的需求。希望本文能帮助您更好地理解和使用Postman,提高API测试的效率和质量。
71 11