1.1自动化测试模式介绍

在正式讲自动化测试之前,我们不妨来先聊聊目前测试团队一般存在的几种模式。

1.1 冰淇淋模式(ice cream cone)

冰淇淋模式

这个冰淇淋模式是2012年被提出来的,从图我们可以非常明显看到,测试团队在自动化测试投入主要在GUI界面,而在集成测试和单元测试的投入则非常少,更可怕的是在图顶端还有一大堆的手工测试,相信看到这个我们的感受是一样,这个测试团队一定处于较低水平,大量的手工测试的存在,必然也就造成了这是一个难吃的冰淇淋。

出现这种情况的团队很多是因为测试团队为了尽快产出效果,获得收益就从最容易上手的用户界面测试开始。还一个原因就是团队成员自动化测试技能较弱,不得不采用更多的手工测试。

这种模式在传统软件公司非常常见,甚至会出现底下三种测试的投入几乎为零。 这是一种非常典型的依赖手工测试完成业务的测试,通过手工测试来测评产品的质量。这样系统随着时间而越来越庞大,业务逻辑越来越复杂,代码耦合性越来越高,系统公共部分越来越多,最后可能出现牵一发而动全身,到那时测试工作就变得极其困难。经常遇到A功能之前测试是正常,等发布几个周期后,因为测试时间紧,就没有再去回归A功能,结果上线后往往A功能就处于一个不可工作状态。

1.2 金字塔模式

金字塔模型1

这是现在非常流行的一种自动化测试分层理念,这个是由Mike Cohn提出的,所以这个模型其实也是敏捷测试模型。 这个模型上,我们看一看到金字塔的底部是 Unit 而且占了绝大多数位置,中间这层是 Service 有时我们也叫接口层API层,而金字塔的顶部是 UI 层,占有空间最小 。

这个自动化测试金字塔提出后,几乎被奉为主旨,甚至一度出现配合敏捷转型,很多公司出现拆撤独立的测试部分,将测试人员大散并入到各个Scrum 团队的风潮。当然其实现实中真正长期执行这种模型的团队很少,因为难度非常大。

为啥呢?

我们再看看这个图,图中自动化测试中 Unit 的自动化占比非常大,大概在80% , Service 占比大概10% ~ 15% ,而最顶端的 UI 自动化占比最少,大概 1% ~ 5%。1% ~ 5% 其实也基本跟我们编写 TestCase 中的冒烟级别的Case数量差不多,这也就说,UI 自动化测试建议做到冒烟回归级别便可,通过UI自动化测试来保证系统不会出现大的问题。

当然从实际工作中往往我们可以把这个比例提高到10%左右,也就是UI自动化测试主要去覆盖系统的重要功能。

当然提个醒UI自动化测试,不要一味去追求覆盖率,也不要去定一些不切实际的UI自动化覆盖率。真正对覆盖率要求高的应该是 Unit层,假设真的做到了80%以上的 UnitTest 覆盖率,是不是觉得这种团队已经偏向TDD团队了。TDD团队对全员要求水平都很高,所以这也就是为啥很少团队真正执行这种模型。

1.3 另一种的金字塔模型

金字塔模型

这个跟上面的金字塔模型没有太大的区别,随着敏捷测试的不断演进,又有个敏捷大师在金字塔上加了顶帽子 --- 探索性测试。 团队有了自动化测试,是不是手工测试团队就解散了?当然不是,还有无穷无尽的探索性测试等着你去做。

1.4 橄榄模式(不倒翁模式)

image.png

刚上说的几种模型要嘛不符合现在的敏捷团队,要嘛难度大。那从个人经验上和测试效果上看,这个橄榄模式更为推荐。

它相比冰淇淋模式它更符合现在的敏捷团队,因为他重视自动化测试。 相比金字塔模式它相对更容易实操。

再来细看这个图,图中占最大比例的是中间部分的接口API层,其次是Unit层,UI 层依旧占比最少。

为啥大力推荐多做接口自动化测试呢?

接口自动化测试与UI自动化测试或单元测试对比,有很多的优势。 单元测试通常针对代码进行测试,系统往往还处于一个还未部署状态,而接口测试则是系统部署完成后才进行的测试,另外一个接口测试TestCase往往会比一个单元测试的TestCase覆盖到的代码更多,而且接口测试通常是面向业务的测试。

这时你们可能就会问那一个UI测试的TestCase不是会覆盖更多代码,更贴近业务,更贴近用户实际操作?

这话没毛病。 但为啥图中反应出来的UI 测试占比还是最少。 原因是接口自动化测试相对UI自动化测试更加简单直接,容易见成效,执行效率也更高。而且根据经验随着自动化测试用例个数的增长,接口自动化测试整体的维护难易度会比UI自动化测试低,因为接口自动化测试更简单直接。

所以,按照以往经验看,我个人认为一个团队如果不是走TDD模式,测试还处在自动化测试的初级阶段,橄榄模式更适合这一团队。平时我也经常喜欢说:重接口,轻UI。

最后如果我们在这橄榄模型上再加一部分的手工测试或者探索性测试,那这样是不是就像一个不倒翁啦。

image.png

按照这个模式,将大部分自动化投资用于接口测试,可以获得最高的投资回报。再结合持续测试与持续集成等最佳实践,在团队中通过接口测试这一承上启下的测试类型,可以自下而上地逐步翻越过冰淇淋模式中的那堵墙。

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

推荐阅读更多精彩内容