《用户故事与敏捷方法》读书笔记——第二章

第 2 章 编写故事

优秀的故事的特点:(INVEST)

  • 独立性(Independent)
  • 可讨论的(Negotiable)
  • 对用户或客户有价值的(Valuable to Purchasers or Users)
  • 可估计的(Estimatable)
  • 小的(Small)
  • 可测试的(Testable)

一、独立的
我们要尽量避免故事间的相互依赖。
假如客户团队已经选择了一个高优先级的故事,但它对一个低优先级的故事有依赖,这就会出现问题。
出现这种依赖时,有两种方法可以绕过这种依赖。

  • 将相互依赖的故事合并成一个大的、独立的故事。
  • 用一个不同的方式去分隔故事。

二、可讨论的
故事是可讨论的。
故事卡是功能的简短描述,不需要包含所有的相关细节,细节将在客户团队和开发团队的讨论中产生。
若我们把故事卡用于提醒开发人员和客户进行关于需求的讨论,那么故事卡包含下面的信息就变得有意义。

  • 一两句短语,用来提醒开发人员和客户进行对话。
  • 一些注释,用以表明在对话中亟待解决的问题。

三、对用户或客户有价值的
应当避免那些只对开发人员有价值的故事。
应该避免在故事中出现用户界面和技术方面的定义。
保证每个故事对客户或用户有价值的最好方法是让客户来编写故事。

四、可估计的
故事不可估算的3个原因:

  • 开发人员缺少领域知识。

  • 开发人员缺少技术知识。

  • 故事太大了。
    如何解决:

  • 如果开发人员不理解故事,他们应该和写故事的客户一起讨论。

  • 如果开发人员缺乏所涉及的技术,可以让一个或多个开发人员去实施极限编程(XP)中所谓的探针实验(spike)。这是一个简短的试验,用于研究应用程序的某一方面。一个不可估计的故事就变成了两个故事:一个快速的探针故事(用来获得足够的信息)和一个故事(真正实现功能)。

  • 如果故事太大了,那么可以将大故事拆分为多个小故事。

五、小的
故事的大小很关键,故事太大或太小,都无助于制定计划。

分割故事
大的故事通常分为以下两种。

  • 复合故事(compound story)
  • 复杂故事(complex story)
    复合故事是由多个小的故事组成的史诗故事。
    复杂故事是其本身就很大且不容易分解的故事。如果一个故事因为不确定性而复杂,可以将它分为两个故事:一个做调研的故事和一个开发故事。

合并故事
有时候,故事太小了,显得微不足道。
在极限编程的团队中,一个比较好的方法通常是将其合并到需要半天或几天完成的故事中。

可测试的
故事必须是可测试的。成功通过测试可以证明开发人员正确地实现了故事。
当产品是增量开发的,很多东西变化得很快,昨天能工作的代码,今天就会出现问题。这时需要自动化测试来帮助你尽早发现这些问题。

小结

  • 理想情况下,故事之间是独立的。故事之间的交付顺序应该是无关的,可以任意拿一个故事来实现。
  • 故事细节由用户和开发人员讨论得出。
  • 故事应该很清晰地体现对用户或客户的价值。最好的做法是让客户编写故事。
  • 故事可以注释一些细节,但是过多的细节会使故事难以理解。
  • 给故事加上注释的最好方法是给它编写测试用例。
  • 如果故事太大,复合故事和复杂故事可以分成几个小的故事。
  • 如果故事太小,几个小故事可以合并成一个较大的故事。
  • 故事应该是可以测试的。

开发人员职责

  • 帮助客户编写故事,这些故事要能提醒你们同客户交谈,不是记录详细的需求定义,故事应该对用户或者客户有价值,它们是独立的、可测的、大小合适的。
  • 使用对用户或客户有价值的术语来描述实现故事所用的技术或者基础架构信息。

客户团队职责
负责编写故事,这些故事要能提醒你们同开发人员交谈,而不是记录详细的需求定义,他们对用户或你们自己是有价值的,他们是独立的、可测的、大小合适的。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,456评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,370评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,337评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,583评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,596评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,572评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,936评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,595评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,850评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,601评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,685评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,371评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,951评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,934评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,167评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,636评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,411评论 2 342

推荐阅读更多精彩内容

  • User Stories Applied 第一部分 起步 第一章 概览 什么是用户故事 用户故事描述了对用户、系统...
    贾尼阅读 3,875评论 0 9
  • 1.埋点是做什么的 2.如何进行埋点 3.埋点方案的设计 近期常被问到这个问题,我担心我的答案会将一些天真烂漫的孩...
    lxg阅读 2,011评论 0 1
  • 第一部分 起步 第一章 概览 什么是用户故事 用户故事描述了对用户、系统或软件购买者有价值的功能。 一份书面的故事...
    yuhan_sining阅读 550评论 0 2
  • 如果要开始一个敏捷项目,应该如何开始和逐步进行下去呢?有没有一些套路是我们可以学习和借鉴的呢?以下就是我阅读这本有...
    缪家阅读 4,313评论 0 8
  • 刚才爷爷奶奶回家了,怎么样也挽留不了留下来吃晚饭,内心还是放不下那几只羊。 爷爷很高,腰板挺直,皮肤黝黑。长期在地...
    Smithereens_J阅读 288评论 0 0