用户故事地图(9):开发流程之“研发-评估-交付”阶段

在这一篇文章中,我们将会完成用户故事流程中接下来三个阶段:研发、测试和交付。想想距离写完这个读后感应该还剩1〜2篇文章的距离,不免吐了一口气——要想读懂一本书真是不容易,从一本书中读出三本书的知识,更不容易。


从各方收集得来的需求,以“故事”的方式记录在卡片上,并先后经历了“机会”➝“探索”➝“模型设计”➝“故事工作坊”,终于流入开发阶段。在开发阶段,项目会遇到各种问题,它们转化为信息被讨论并反馈,以此来持续的调整方案,并同时更新地图。

在实际开发过程中,我们常将要一个版本要开发的内容按功能模块进行拆分,例如模块A、B在第一阶段交付测试,C在第二阶段交付测试,以此类推。《用户故事地图》一书对功能的拆分方式略有不同。在《用户故事地图(2)》中,我们对这种切分方式已有简单描述,此处再详细介绍下。

研发阶段

功能在正式上线前,会分为三阶段进行开发。它们分别是:

阶段 内容 目标 说明
第一阶段 完成核心流程开发 排除技术风险 1、通过数据观察功能的性能;
2、使用自动化测试检验稳定性;
3、关注技术挑战和风险,通过消除技术风险,避免风险在后期造成更大成本;
第二阶段 开发周边功能 关注质量,达到可发布标准 1、开发主流程之外的其他可选流程和复杂逻辑;
2、常常加入之前未发现的新特性;
3、原系统无法满足性能上的需求而需要额外投入来解决的问题
第三阶段 打磨产品 让产品更抢眼、使用更高效 1、可能会加入未预想的东西;
2、使用线上真实数据测试;
3、常常会现在原型阶段无法识别的改进点

以上方式并非以独立功能点完成数量进行拆分,而是对所有功能一起进行不同层面的切分。要想达到它,我认为必须达到:功能间耦合度低,自动化测试的参与,还有就是增量开发方式。

在开发过程中,项目会遇到各种问题:来自技术实现、来自外部、来自于设计合理性一致性等。我们心理上是排斥它们的,起码不会认为是好事儿。然而换一个角度想,也许就会不同:

从讨论机会出发,到找到用户,从用户或客户面对的问题,到形成对应的解决方案。所做的每一步、开发的每一个功能都有一个明确的目标,那就是学习(获得更多信息以改进产品)。

——精益创业的核心思路:基于验证的学习

开发过程中出现的问题,恰恰是帮助我们进一步学习的机会。而正视这件事情的关键,在于学习的态度——即遇到的问题可以被总结、沉淀,以解决更多问题。以此来看,“变更”这件事情在某些情况下是正常的,我们必须承认,有一些问题是无法在工作坊中想到的。

在开发过程中,我们依然要保持对用户故事地图的高度使用——实时根据目前项目的开发状态和进度,定时持续的在用户故事地图中标识故事状态(在开发过程中,依然保持对整体的认识)。另一方面,它可以帮助团队在各个阶段都可以看到自己完成了什么,当前的进度和开发重点是什么。做过项目的人都会遇到一个问题,就是为了进度常常会临时去掉一些功能,留待后续开发。然而若没有一个有利的跟踪方式,这部分内容很容易被遗忘,所谓“后续开发”几乎等同于“没有后续”。若将这些功能实时放在地图中,我们就很容易从全局看到这些遗漏功能的影响,并在相应阶段提上开发日程。

由此可见,在项目跟踪上,用户故事地图也发挥着很大的作用。

测试与评测阶段

根据前期的故事切分,我们在开发过程中会陆续获得一些小的开发模块。接下来我们将要对它们进行测试以评估质量,并且判断是否需要调整进度。这个在SCRUM中应该叫“迭代评审会议”或“迭代回顾会议”。我们可以从三个方向来进行测试评估:

  1. 用户体验质量:
    • 交互:从用户角度来看,功能是否简单易用、是否体验到乐趣?
    • 视觉:看起来是否让人舒服?
    • 一致性:和其他功能对比,在设计上是否具有一致性?
  2. 功能质量:
    • 功能实现的正确吗?
    • 是否含有BUG?
  3. 代码质量:
    • 是否符合编码规范?
    • 代码是否鲁棒?

通过以上方式获得了可以基本工作的功能模块后,就可以立即找到用户进行测试,从而获得改进建议。我们常讲MVP,但实际上此阶段用于用户测试的模块完全不需要达到上线级别,只要能够帮助用户“成达一个有意义的目标”即可。

受“专家盲点”的影响,开发者并不能完全体会用户的实际使用情况。而用户行为数据和后台反馈又具有局限性,较难对体验的改进有所帮助。因此在功能模块稳定后第一时间邀请用户(邀请其他干系人也是很有必要的)使用是非常有必要的。它并非是向用户讲解,而是用最小的成本来验证它是否能正确的解决用户的问题(相信我,很多项目成员是不会考虑成本这个事儿的)。

交付阶段

功能完成开发后,接下来需要向利益干系人(老板等)和用户交付了。对于利益干系人而言,他们并不会每天使用软件,他们只关心是否可以尽快上线。因此,当向上级汇报时,他们常常听不懂做了什么。为了解决这个问题,我们需要在交付之前经常汇报(用户故事地图可以整体上说明每个阶段完成的内容),交付时要写清做了什么、目的和背景。对于组织内的干系人,项目进度和完成质量要保持持续可见,这样他们才会信任团队。

产品上线后,运用数据和接触用户来了解结果是否达到预期。反馈达到预期、解决了问题,就可以就此结项。若发现了改进的问题,则把它们记录下来,重新回到原点。

—— end ——

全部内容链接:

用户故事地图(1):体验用户故事
用户故事地图(2):作用
用户故事地图(3):故事与卡片
用户故事地图(4):创建方法
用户故事地图(5):开发流程之“机会”阶段
用户故事地图(6):开发流程之“探索”阶段
用户故事地图(7):开发流程之“设计”阶段
用户故事地图(8):开发流程之“故事工作坊”阶段
用户故事地图(9):开发流程之“研发-评估-交付”阶段
用户故事地图(10):开发流程之“回顾”阶段
用户故事地图(11):故事(需求)拆分
用户故事地图(12):后记

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

推荐阅读更多精彩内容