十一、KeystoneInterface

软件开发团队发现只要他们集成的越频繁,生活就会越简单。同样的,他们发现发布到生产越快也会越有价值。但是团队并不想将半成品暴露给用户。处理这种紧张关系的一种有用的技术是构建所有后端代码,进行集成,但不构建用户界面。功能可以被集成和测试,但是UI会被保留到最后,直到它被添加来完成功能,并向用户展示它。

这种技术的一个简单示例可能是让客户选择紧急订单(加急)。这样的订单需要根据客户的居住地以及当地的快递公司来定价。所涉及的货物的性质会影响仓库中使用的拣选方法。某些客户可能有资格获得紧急订单,这也可能取决于交付地点、一年的时间和所订购的商品的种类。

总之,这是商业上的逻辑,特别是因为它将涉及到与各种仓库、目录和客户服务系统的复杂集成。完成这个功能的开发需要几周的时间,但是其他功能在几天之内就要发布。但是对于用户来说,急单只是订单表单上的一个复选框。

使用复选框最为keystone来构建这个,该团队在多个生产版本的过程中对内部系统的底层业务逻辑和接口进行开发工作。用户不知道所有这些潜在的代码。只有在最后一步,楔石复选框需要使可见,这可以在一个相对短的时间内完成。通过这种方式,所有潜在的代码都可以被集成,并成为进入生产环境的系统的一部分,从而减少长期存在的特性分支带来的问题。

image.png

image.png

潜在的代码如果在激活时也需要被测试。这个可以在系统最初建立时就完成,假设系统测试不依赖用户接口。 Unit Tests和更底层的 Test Pyramid很容易做到这点。甚至Broad Stack Tests也可以运行,假如有一个机制可以让他们Subcutaneous Tests。在一些场景中,在UI中有相当多的行为,但如果在设计上允许UI成为一个 Humble Object,这也可以被测试。

并不是所有的程序都可以采取这种方式测试,但是,即使没有使用keystone的能力,这样做所需要的努力也是值得的。即使使用最好的工具来自动化这个过程,使用UI来测试也是很麻烦的。迁移更多的测试到更底层,特别是unit test,会大幅度提升 Deployment PipelinesContinuous Delivery
的效率。

当然,大多数ui将不仅仅是一个复选框,尽管它们通常并不需要做太多工作。在一个web app,一个复杂的功能通常是一个独立的web页面,这可以完整的来构建和测试,而keystone只是一个链接。一个桌面可能有几个屏幕,而keystone是菜单项使他们可见。

即便如此,也有一些情况不能简单的直接将UI打包进keystone。当这样时,就是用 Feature Toggles的时候。然而,即使在这种情况下,考虑一个keystone也是有用的,因为它可以确保特性切换只适用于UI。这会减少开关的使用量和以及使用开关的复杂性,允许simple toggle mechanisms的使用,当时机成熟时,它更容易被移除。

最后开发UI也存在风险,后端代码可能设计的和UI在一起不工作,或者是UI直到最后才关注到它所需要的,导致缺乏迭代和糟糕的用户体验。由于这些原因,keystone方法在整体方法中工作得最好,这种方法鼓励通过薄的垂直切片构建产品,从而导致快速发布小型但完全可用的功能。

我已经使用过用户接口的例子,但是同样的方法也适用其他接口,比如一个API接口。通过最后构建用户的接口,保持简单,我们可以构建和集成一个很大的功能。

Dark Launching是新功能构建时不展现给用户,开发完成后才被调用的一个变种。这可以用来评估对后端系统的影响,有利于一些改变。当所有的事情都做好后,我们可以增加这个keystone。

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

推荐阅读更多精彩内容

  • 现代的源代码控制系统提供了强大的工具,可以非常轻松的在源代码上创建分支。但最终分支还是要合并在一起,许多团队不得不...
    暴走的初号机阅读 1,293评论 0 0
  • 微服务 这个新架构术语的定义 在过去的几年中,出现了“微服务体系结构”一词,用于描述将软件应用程序设计为可独立部署...
    Locker阅读 16,094评论 0 10
  • DarkLaunching一个功能意味着调用一个新的或者变更的后端行为,但不让用户知道这个接口的存在。这是在新功能...
    bylaw阅读 355评论 0 0
  • 原文如下:http://martinfowler.com/articles/microservices.html ...
    jacky_谦阅读 854评论 0 1
  • 渐变的面目拼图要我怎么拼? 我是疲乏了还是投降了? 不是不允许自己坠落, 我没有滴水不进的保护膜。 就是害怕变得面...
    闷热当乘凉阅读 4,241评论 0 13