在敏捷开发中,采用 SPIDR 框架中的 5 种方法可以很好地完成需求的垂直切片,将大的需求纵向拆分成小但有价值的、可独立交付的用户故事。// 回顾「需求垂直切片」和「拆分第一招:SPIDR 框架」,请戳 👉 假如需求拆分像切蛋糕一样简单 。
本期内容将继续揭秘敏捷开发中的需求拆分全流程,建议收藏⭐先码后看。
听上去似乎与「如何把大象🐘放进冰箱里」有异曲同工之妙,但它并不是什么「废话文学」。
《用户故事切分流程图》(下文简称《流程图》)介绍了 9 种常见的垂直切分模式,并详细地说明了每一种模式的具体思考路径和判断规则;此外,它还提供了许多需求拆分实战的细节建议:
👇关注 LigaAI 公众号,回复关键词【需求拆分】即可获取中文版《流程图》。
《用户故事切分流程图》by Richard Lawrence | 来源:https://www.humanizingwork.com
在正式开始拆分需求之前,敏捷团队应该花一些时间梳理和确定工作目标,充分理解工作范围,比如涉及的利益相关者、需求验收标准等等。其中,明确需求价值是最为重要的。
将研发需求拆分到用户故事,本质上是对交付增量做出的进一步细分。如果待拆分的需求没有明确的价值引导,那么研发工作就极有可能进入错误的方向或者「死胡同」,导致前功尽弃。
举个简单的例子:重构企业官网的用户注册页面。
在该描述下,「重构注册页面」究竟是为了让网站管理者更好地管理注册信息,还是为了让访问者拥有更好的使用体验?如果是后者,那么需要优化的「使用体验」具体指什么,是更美观好用的用户界面,还是更简洁的注册流程?
用户故事的「WHO-WHAT-WHY」语言结构要求故事必须说明需求价值,即清晰传递用户能获得的好处。这个规范,同样适用于待拆分的大需求。甚至可以说,缺乏价值描述的需求是无效的,因为研发团队必须知悉工作目标和需求价值,才能更快速、正确地推进后续工作。
那么有效的需求应该怎么写?其实,只要对上述描述稍作改进,补充重要的价值信息,说清楚「WHO」和「WHY」就能使其成为一条合格的待拆分需求:
【需求】重构企业官网的用户注册页面,以便让访问者快速获得感兴趣的内容。
除了强调价值描述外,《流程图》还要求待拆分的需求要尽量符合除 Small 原则外的 INVEST 原则,即待拆分需求应是独立的、可协商的、有价值的、可估算的和可测试的。
对于不满足此条件的需求,可以尝试将其与另一个需求合并,或者重新构思得到另一个需求,再将这个符合条件的新需求作为拆分起点。
明确了待拆分需求的交付价值和工作大小后,研发团队可运用以下 9 种切分模式进行规划和拆分。
依照工作流程的步骤顺序,将大需求拆分成一个个逻辑连续的、有独立价值的用户故事是最常见的拆分模式。在敏捷实践中,构建完善、 周全的工作流程常用以下两种方式:
在实际工作中,我们可以借用快乐路径(Happy Path)表示最常见的主流程,是没有任何异常情况的成功路径;用异常路径(Unhappy Path)表示异常情况的处理路径,它代表了用户没有按照操作预期顺利抵达终点的各种错误情况。
二八定律指出,最有价值的流程往往只占 20%,其余的 80% 通常是次要的。因此,遵循「部分到整体」的原则,先抓取最重要的工作流程,再逐步扩大和丰富需求的故事集是操作重点。
当大需求与「管理」或「配置」等描述词相关,可以将其按照不同的用户操作切分成更小的故事。这里借用 CRUD 操作概念作为用户操作分类的底层逻辑是个不错的选择。
CRUD 操作是四种基本操作的首字母缩略词缩写,分别代表了增加 Create、读取 Read、更新 Update 和删除 Delete。在需求拆分领域,可以这样应用:
该模式可与 SPIDR 框架中的 Rules 方法对应。在实际工作中,一些业务逻辑会带有很多隐形的规则限制,尤其是与时间、空间、选择等范围词相关的业务。
敏捷团队可以按照业务规则和技术标准对需求进行拆分,并根据时间和价值排序,逐步实现对技术规范或业务规则的适应。
例如,在线售票系统的购票流程通常隐含对数量限制、排他性等规则,研发团队可以先实现没有限制条件的购票流程,再进一步实现约束规则相关的故事。
根据不同的数据类型或数据来源,拆分大型需求,是处理输入 / 输出操作的常用手段。敏捷团队可以根据不同数据子集的优先顺序,先在一个迭代内专注一种数据类型的实现,以快速交付故事价值。
与 SPIDR 框架中的接口法类似,当待拆分需求涉及多个交互系统的使用,或者涉及用户界面展示的升级和变更时,可以按照不同的用户界面拆分多个用户故事集。
或理解为:按主要工作目标作切分。如果完整需求描述中含有和 / 或 / 等 / 然后这类连接词,通常意味着该需求可以被拆分成多个独立的用户故事,且故事集都必须基于相同的基础设施建设才能完成。
此时,只有将基础设施建设标记为主要工作,率先完成,才能更好地推进用户故事和大型需求的研发。
对于一些复杂的大型需求而言,在研发早期将全部情况都考虑并且实现是很困难的,因此可以先交付最基本的简单版本,再依据其他的拆分模式做进一步扩展,将需求拆分为不同的故事合集,通过一个个更复杂的故事交付,逐步实现大型需求。
延迟交付模式的核心是将大型需求拆分成「能用」和「好用」两个部分,以故事优先级为驱动,将需求分步完成。例如:
这种拆分的好处是能让团队专注于交付功能,而不是被非功能性需求分散注意力,但是也要小心待完成的非功能性需求遗留、堆积成「技术债」。
以下是一些常见的非功能性需求列表:
当你发现运用上述八种拆分模式都无法将一个大的需求拆小,那么很有可能是因为敏捷团队缺乏重要的、支撑拆分的信息,比如团队对需求描述的业务不熟悉、对其中涉及到的技术不了解等等。此时,就需要使用探针模式,对不确定的领域进行探索,明确需求方向。
敏捷团队可以通过技术预研充分理解需求内涵,快速探知可能的技术方案,初步判断工作量,以支持需求的细化拆分。
Richard Lawrence 指出,在敏捷开发中,需求拆分遵守两条经验法则:
切分完成的用户故事可以通过以下判断标准评估是否进入后续开发流程:
参考资料
了解更多敏捷开发、项目管理、行业动态等消息,关注我们 LigaAI@oschina 或点击 LigaAI - 新一代智能研发协作平台,在线申请体验我们的产品。
原网址: 访问
创建于: 2022-07-26 10:04:20
目录: default
标签: 无
未标明原创文章均为采集,版权归作者所有,转载无需和我联系,请注明原出处,南摩阿彌陀佛,知识,不只知道,要得到
java windows火焰图_mob64ca12ec8020的技术博客_51CTO博客 - 在windows下不可行,不知道作者是怎样搞的 监听SpringBoot 服务启动成功事件并打印信息_监听springboot启动完毕-CSDN博客 SpringBoot中就绪探针和存活探针_management.endpoint.health.probes.enabled-CSDN博客 u2u转换板 - 嘉立创EDA开源硬件平台 Spring Boot 项目的轻量级 HTTP 客户端 retrofit 框架,快来试试它!_Java精选-CSDN博客 手把手教你打造一套最牛的知识笔记管理系统! - 知乎 - 想法有重合-理论可参考 安宇雨 闲鱼 机械键盘 客制化 开贴记录 文本 linux 使用find命令查找包含某字符串的文件_beijihukk的博客-CSDN博客_find 查找字符串 ---- mac 也适用 安宇雨 打字音 记录集合 B站 bilibili 自行搭建 开坑 真正的客制化 安宇雨 黑苹果开坑 查找工具包maven pom 引用地 工具网站 Dantelis 介绍的玩轴入坑攻略 --- 关于轴的一些说法 --- 非官方 ---- 心得而已 --- 长期开坑更新 [本人问题][新开坑位]关于自动化测试的工具与平台应用 机械键盘 开团 网站记录 -- 能做一个收集的程序就好了 不过现在没时间 -- 信息大多是在群里发的 - 你要让垃圾佬 都去一个地方看难度也是很大的 精神支柱 [超级前台]sprinbboot maven superdesk-app 记录 [信息有用] [环境准备] [基本完成] [sebp/elk] 给已创建的Docker容器增加新的端口映射 - qq_30599553的博客 - CSDN博客 [正在研究] Elasticsearch, Logstash, Kibana (ELK) Docker image documentation elasticsearch centos 安装记录 及 启动手记 正式服务器 39 elasticsearch 问题合集 不断更新 6.1.1 | 6.5.1 两个版本 博客程序 - 测试 - bug记录 等等问题 laravel的启动过程解析 - lpfuture - 博客园 OAuth2 Server PHP 用 Laravel 搭建带 OAuth2 验证的 RESTful 服务 | Laravel China 社区 - 高品质的 Laravel 和 PHP 开发者社区 利用Laravel 搭建oauth2 API接口 附 Unauthenticated 解决办法 - 煮茶的博客 - SegmentFault 思否 使用 OAuth2-Server-php 搭建 OAuth2 Server - 午时的海 - 博客园 基于PHP构建OAuth 2.0 服务端 认证平台 - Endv - 博客园 Laravel 的 Artisan 命令行工具 Laravel 的文件系统和云存储功能集成 浅谈Chromium中的设计模式--终--Observer模式 浅谈Chromium中的设计模式--二--pre/post和Delegate模式 浅谈Chromium中的设计模式--一--Chromium中模块分层和进程模型 DeepMind 4 Hacking Yourself README.md update 20211011
Laravel China 简书 知乎 博客园 CSDN博客 开源中国 Go Further Ryan是菜鸟 | LNMP技术栈笔记 云栖社区-阿里云 Netflix技术博客 Techie Delight Linkedin技术博客 Dropbox技术博客 Facebook技术博客 淘宝中间件团队 美团技术博客 360技术博客 古巷博客 - 一个专注于分享的不正常博客 软件测试知识传播 - 测试窝 有赞技术团队 阮一峰 语雀 静觅丨崔庆才的个人博客 软件测试从业者综合能力提升 - isTester IBM Java 开发 使用开放 Java 生态系统开发现代应用程序 pengdai 一个强大的博主 HTML5资源教程 | 分享HTML5开发资源和开发教程 蘑菇博客 - 专注于技术分享的博客平台 个人博客-leapMie 流星007 CSDN博客 - 舍其小伙伴 稀土掘金 Go 技术论坛 | Golang / Go 语言中国知识社区
最新评论