敏捷方法:什么是软件测试中的敏捷模式?

简介: 敏捷方法:什么是软件测试中的敏捷模式?

什么是敏捷方法?

敏捷方法是指在项目的整个软件开发生命周期中,促进开发和测试的持续迭代的一种做法。在软件测试的敏捷模式中,开发和测试活动是同时进行的,这与瀑布模式不同。


什么是敏捷软件开发?

敏捷软件开发方法是将商业需求的愿景变成软件解决方案的最简单有效的过程之一。敏捷是一个用来描述软件开发方法的术语,它采用持续的计划、学习、改进、团队协作、进化的开发和早期交付。它鼓励对变化作出灵活的反应。

敏捷软件开发强调了四个核心价值。

  1. 个人和团队的互动胜过过程和工具
  2. 工作软件高于全面的文件
  3. 客户合作胜过合同谈判
  4. 应对变化而不是遵循计划

敏捷过程

敏捷测试中存在各种敏捷方法,下面列出了这些方法。


敏捷


SCRUM是一种敏捷开发方法,它特别集中于如何在一个基于团队的开发环境中管理任务。基本上,Scrum来源于橄榄球比赛中的活动。Scrum相信授权给开发团队,并提倡在小团队中工作(例如,7到9名成员)。敏捷和Scrum由三个角色组成,他们的职责如下 :

- Scrum主管
Scrum Master负责建立团队,召开冲刺会议,消除进展的障碍。


- 产品负责人
产品负责人创建产品积压,确定积压的优先次序,并负责在每个迭代中交付功能


- Scrum团队
团队管理自己的工作,组织工作以完成冲刺或周期的工作


产品需求列表


这是一个跟踪需求的存储库,其中有每个版本要完成的需求(用户故事)的数量的细节。它应该由产品负责人维护并确定优先级,并且应该分发给Scrum团队。团队也可以要求增加、修改或删除新的需求。

Scrum流程


Scrum测试的过程流程如下:

  • 一个Scrum的每个迭代被称为Sprint
  • 产品需求列表是一个列表,所有的细节都被输入,以获得最终产品。
  • 在每个Sprint期间,产品需求列表中的顶级用户故事被挑选出来并转化为Sprint积压。
  • 团队在确定的冲刺需求上工作
  • 团队检查每天的工作情况
  • 在冲刺结束时,团队提供产品功能。


极限编程(XP)


当客户的需求不断变化或对系统的功能不确定时,极限编程技术是非常有用的。它主张在较短的开发周期内频繁地 "发布 "产品,这从本质上提高了系统的生产力,同时也引入了一个检查点,任何客户的要求都可以轻松实现。XP开发软件时,将客户放在目标位置。

业务需求是以故事的形式收集的。所有这些故事被储存在一个叫做停车场的地方。

在这种方法论中,发布是基于较短的周期,称为 "迭代",时间跨度为14天。每个迭代包括编码、单元测试和系统测试等阶段,在每个阶段都会在应用程序中建立一些次要或主要的功能。

eXtreme编程的阶段


敏捷XP方法有6个阶段,具体解释如下。

计划

  • 确定利益相关者和赞助商
  • 基础设施要求
  • 安全相关的信息和收集
  • 服务水平协议和其条件


分析

  • 分析列表中的故事
  • 对列表中的故事进行优先排序
  • 分析故事以进行评估
  • 定义迭代范围(时间)。
  • 开发和QA团队的资源规划


设计

  • 分解任务
  • 为每个任务准备测试方案
  • 回归自动化框架
  • 执行


编码

  • 单元测试
  • 手动测试方案的执行
  • 缺陷报告的生成
  • 将手工测试转换为自动化回归测试案例
  • 迭代中期审查
  • 迭代结束审查


发布

  • 小规模发布
  • 回归测试
  • 演示和审查
  • 根据需要开发新的故事
  • 根据迭代结束时的审查意见进行流程改进


结案


  • 试点启动
  • 培训
  • 生产启动
  • 服务水平协议的保证
  • 审查SOA战略
  • 生产支持


    有两个故事板可以用来跟踪每天的工作,下面列出了这些故事板供参考。


  • 故事卡板

    这是一种传统的方式,将所有的故事以贴纸的形式收集在一个板子上,以跟踪每天的XP活动。由于这种手工活动涉及更多的精力和时间,因此最好改用在线形式。
  • 在线故事板
    在线工具Storyboard可以用来存储故事。几个团队可以为不同的目的使用它。


    水晶方法论
    水晶 方法论是基于三个概念

    1:制定章程。这一阶段涉及的各种活动是创建一个开发团队,进行初步的可行性分析,制定初步计划和微调开发方法


    2: 循环交付。主要的开发阶段包括两个或更多的交付周期,在这期间
    团队更新和完善发布计划

  • 通过一个或多个程序测试集成迭代来实施需求的子集
  • 集成的产品交付给真正的用户
  • 对项目计划和采用的开发方法进行审查
  • 在这个阶段进行的活动是部署到用户环境中,进行部署后审查和反思。


动态软件开发方法(DSDM)


DSDM是一种快速应用开发(RAD)的软件开发方法,提供了一个敏捷的项目交付框架。DSDM的重要方面是要求用户积极参与,并赋予团队决策权。频繁地交付产品成为DSDM的积极焦点。DSDM中使用的技术是

1  计时法
2. MoSCoW规则
3. 原型设计

DSDM项目由7个阶段组成

1. 项目前期
2. 可行性研究
3. 业务研究
4. 功能模型迭代
5. 设计和建造迭代
6. 实施
7. 项目后

功能驱动开发(FDD)


这种方法主要是围绕 "设计和构建 "功能。与软件工程中的其他敏捷方法不同,FDD描述了非常具体和简短的工作阶段,每个功能必须单独完成。它包括领域穿行、设计检查、促进构建、代码检查和设计。FDD开发产品的目标是保持以下内容

1. 领域对象建模
2. 按特性开发
3. 组件/类的所有权
4. 特性团队
5. 检查
6. 配置管理
7. 定期构建
8. 进展和结果的可见性

精益软件开发


精益软件开发方法是基于 "及时生产 "的原则。它的目的是提高软件开发的速度和减少成本。精益开发可以归纳为七个步骤。

1. 消除浪费
2. 放大学习
3. 推迟承诺(尽可能晚地做出决定)
4. 早期交付
5. 赋予团队权力
6. 建立诚信
7. 优化整体

看板


看板最初来自日语,意思是一张卡片,包含了产品在每个阶段需要完成的所有信息。这种框架或方法在软件测试方法中被广泛采用,特别是在敏捷概念中。


Scrum的特点


在Scrum技术中,测试必须被分解,以便能在一个冲刺阶段完成。
规定了产品需求的优先次序

Scrum团队承诺在迭代中完成特定数量的工作

规定了Burndown图表

在每个冲刺期间,scrum板会被重置。

它不能向正在进行的迭代添加需求

间接限制WIP

规定的有时间窗的迭代


看板的特点


没有规定特定的项目大小

优先级是可选的

承诺是可选的

没有规定特定的项目大小
看板是持久的。它限制工作流状态下的项目数量

只要有能力,它就可以增加需求

直接限制WIP
有时间限制的迭代是可选的

敏捷的衡量标准:


可以有效使用敏捷而收集的指标是。

1. 拖拽因素

  • 对冲刺目标没有贡献的工作时间
  • 可以通过减少共享资源的数量,减少无贡献的工作量来提高拖累系数。
  • 新的估算可以按拖累因素的百分比增加 - 新估算=(旧估算+拖累因素)。


2. 速度

  • 将积压工作(用户故事)转化为冲刺阶段的可交付功能的数量


3. 增加的单元测试的数量

4. 完成每日构建的时间间隔

5. 迭代中或之前迭代中发现的缺陷

6. 生产缺陷泄漏

相关文章
|
数据采集 监控 机器人
浅谈网页端IM技术及相关测试方法实践(包括WebSocket性能测试)
最开始转转的客服系统体系如IM、工单以及机器人等都是使用第三方的产品。但第三方产品对于转转的业务,以及客服的效率等都产生了诸多限制,所以我们决定自研替换第三方系统。下面主要分享一下网页端IM技术及相关测试方法,我们先从了解IM系统和WebSocket开始。
354 4
|
5月前
|
测试技术 开发者 Python
Python单元测试入门:3个核心断言方法,帮你快速定位代码bug
本文介绍Python单元测试基础,详解`unittest`框架中的三大核心断言方法:`assertEqual`验证值相等,`assertTrue`和`assertFalse`判断条件真假。通过实例演示其用法,帮助开发者自动化检测代码逻辑,提升测试效率与可靠性。
459 1
|
5月前
|
机器学习/深度学习 人工智能 自然语言处理
如何让AI更“聪明”?VLM模型的优化策略与测试方法全解析​
本文系统解析视觉语言模型(VLM)的核心机制、推理优化、评测方法与挑战。涵盖多模态对齐、KV Cache优化、性能测试及主流基准,助你全面掌握VLM技术前沿。建议点赞收藏,深入学习。
1397 8
|
测试技术 API 项目管理
API测试方法
【10月更文挑战第18天】API测试方法
436 1
|
安全 测试技术
北大李戈团队提出大模型单测生成新方法,显著提升代码测试覆盖率
【10月更文挑战第1天】北京大学李戈教授团队提出了一种名为“统一生成测试”的创新方法,有效提升了大模型如GPT-2和GPT-3在单一测试中的代码生成覆盖率,分别从56%提升至72%和从61%提升至78%。这种方法结合了模糊测试、变异测试和生成对抗网络等多种技术,克服了传统测试方法的局限性,在大模型测试领域实现了重要突破,有助于提高系统的可靠性和安全性。然而,该方法的实现复杂度较高且实际应用效果仍需进一步验证。论文可从此链接下载:【https://drive.weixin.qq.com/s?k=ACAAewd0AA48Z2kXrJ】
350 1
|
测试技术 UED
软件测试中的“灰盒”方法:一种平衡透明度与效率的策略
在软件开发的复杂世界中,确保产品质量和用户体验至关重要。本文将探讨一种被称为“灰盒测试”的方法,它结合了白盒和黑盒测试的优点,旨在提高测试效率同时保持一定程度的透明度。我们将通过具体案例分析,展示灰盒测试如何在实际工作中发挥作用,并讨论其对现代软件开发流程的影响。
|
8月前
|
测试技术
软考软件评测师——可靠性测试测试方法
软件可靠性是指软件在规定条件和时间内完成预定功能的能力,受运行环境、软件规模、内部结构、开发方法及可靠性投入等因素影响。失效概率指软件运行中出现失效的可能性,可靠度为不发生失效的概率,平均无失效时间(MTTF)体现软件可靠程度。案例分析显示,嵌入式软件需满足高可靠性要求,如机载软件的可靠度需达99.99%以上,通过定量指标评估其是否达标。
|
8月前
|
消息中间件 缓存 监控
性能测试怎么做?方法、流程与核心要点解析
本文系统阐述了性能测试的核心方法论、实施流程、问题定位优化及报告编写规范。涵盖五大测试类型(负载验证、极限压力、基准比对、持续稳定性、弹性扩展)与七项关键指标,详解各阶段任务如需求分析、场景设计和环境搭建,并提供常见瓶颈识别与优化实战案例。最后规范测试报告内容框架与数据可视化建议,为企业级实践提出建立基线库、自动化回归和全链路压测体系等建议,助力高效开展性能测试工作。
|
12月前
|
编解码 缓存 Prometheus
「ximagine」业余爱好者的非专业显示器测试流程规范,同时也是本账号输出内容的数据来源!如何测试显示器?荒岛整理总结出多种测试方法和注意事项,以及粗浅的原理解析!
本期内容为「ximagine」频道《显示器测试流程》的规范及标准,我们主要使用Calman、DisplayCAL、i1Profiler等软件及CA410、Spyder X、i1Pro 2等设备,是我们目前制作内容数据的重要来源,我们深知所做的仍是比较表面的活儿,和工程师、科研人员相比有着不小的差距,测试并不复杂,但是相当繁琐,收集整理测试无不花费大量时间精力,内容不完善或者有错误的地方,希望大佬指出我们好改进!
816 16
「ximagine」业余爱好者的非专业显示器测试流程规范,同时也是本账号输出内容的数据来源!如何测试显示器?荒岛整理总结出多种测试方法和注意事项,以及粗浅的原理解析!