测试微服务之建立测试文化

作者:超级管理员 更新时间:2017-10-30 16:58:38 来源:未知 点击:15642
  这是由来自AWS的工程师NathanPeck发布的“测试微服务”系列文章的第一篇,介绍了测试金字塔模型以及如何建立测试文化。以下内容翻译自Nathan的博客。  自动化测试是一个软件公司取得成功的
  这是由来自AWS的工程师Nathan Peck发布的“ 测试微服务”系列 文章的第一篇,介绍了测试金字塔模型以及如何建立测试文化。以下内容翻译自Nathan的博客。
   自动化测试是一个软件公司取得成功的关键因素之一。经过严格测试的代码容易获得客户的信赖,而没有经过测试或缺乏严密测试的软件系统容易出现故障,让客户感到失望。
  尽管在测试单体系统方面已经有很多最佳实践,但在测试分布式系统(比如微服务)时仍然面临很多挑战。开发者不但要确保每个组件的内部行为是一致的,也要确保组件之间能够良好地集成。分布式系统需要额外的故障测试,比如针对网络故障进行测试。有些分布式系统太过庞大,进行完整的端到端测试不太现实,所以开发人员需要制定一些策略,对整体架构的局部进行单独测试,同时还能保证组件之间的互操作性。
  这篇文章介绍了一些测试分布式系统的基础概念,并讨论了如何在开发流程中加入这些概念,确保它们可以有效地落地。
   金字塔模型
  为了构建一个全面的测试框架,我们需要先了解“测试金字塔”概念。这一概念是由Mike Cohn提出的,当时的大部分 软件测试还是通过用户界面进行的。测试工程师直接手动操作用户界面,或者编写自动化宏脚本来操作界面。这种方式通常无法检测出代码内部的问题。此时,测试金字塔的概念就变得十分重要,因为它让我们明白,用户界面测试应该处于金字塔的顶端。
  使用多种测试类型可以帮助我们检测出不同类型的问题,不同的测试类型集中在系统的不同层面上。一个分布式系统的端到端测试可以被分为以下几个层次。
   单元测试
  单元测试用于验证服务内部的类方法或函数的行为。它们执行代码文件里的类方法或函数,提供不同的输入,并验证与每一个输入相对应的输出。
   集成测试
  集成测试用于验证服务的外部行为。测试框架会启动服务的一个实例,并调用服务的外部接口来执行业务逻辑。
   端到端测试
  端到端测试用于验证多个服务之间的交互行为。在一个独立的环境里启动多个服务的实例,让服务实例间发生交互,以便完成测试。端到端测试需要发起网络请求,比如REST请求,然后被调用的服务返回的响应进行验证。
   用户界面测试
  用户界面测试用于验证整个平台的行为,不仅会测试客户端的逻辑,也会测试后端系统的逻辑,确保客户端和后端系统能够正常交互。
   建立测试文化
  只有把测试作为开发流程和发布管道不可或缺的组成部分,才能让它发挥应有的作用。如果代码有问题,就不应该把它发布出去。
  无法通过测试的代码不应该被合并到代码仓库里。
  无法通过测试的代码不应该被发布出去。
  金字塔模型里的每个测试层级都建立在下一个层级之上:
  工程师们需要对测试抱有正确的态度,他们不仅要开发功能,也要负责编写测试代码,所以他们在很大程度上决定着测试的质量和效率。如果没有认真对待测试,就无法测出很多边界情况,又或者为了提高“覆盖率”而走捷径,但其实什么都没有测到。
  我们不能为了测试而测试,测试的真正目的是为了交付高质量的软件给用户。测试人员要保证软件质量高起高走,在加入新特性或更改已有特性时仍能保证质量。
  这就要求我们要严肃对待故障测试,我们不能为了让测试能够通过而去修改它们。有些测试时而通过时而失败,它们都是假性的测试,需要引起我们的注意。如果生产环境出现了缺陷,说明测试没有到位。如果发现了测试没能覆盖到的地方,需要给工程师足够的时间和资源去修复缺陷。
  我们不能仅仅依赖工程师来建立良好的测试文化。产品经理也需要了解测试流程,并参与其中。如果他们对开发人员作出过分的要求,要求开发新功能的速度超过了开发人员能够对新功能作出全面测试的速度,那么软件质量就会受到影响,问题会一路跟着进入到测试管道,到达用户那里,影响用户满意度。
   结论
  为分布式系统创建完备的测试框架要求使用多个层级的测试。基于客户端UI的测试无法捕捉到各种类型的错误。软件工程师们必须建立起一种测试文化,把自动化测试融入到开发和发布管道的各个阶段,包括单元测试、集成测试、端到端测试和UI测试。

【推荐】Appium直播课早鸟价限时优惠,APP自动化的首选利器>>

推荐阅读

热门内容

LoadRunner 中怎么对日期进行参

  【背景】  今天在51Testing...

OpenStack Rally 性能测试

  注意点:在测试nova,在配置文件里...

测试微服务之建立测试文化

  这是由来自AWS的工程师Nathan...

华为一员工因说真话连升两级!质量人,你怎

  话说,职场如战场,什么话该说,什么话...

Python爬虫实战:使用Seleniu

  前面我们接触到的,都是使用reque...

值得收藏!这是SQL数据库优化的六种方法

  SQL命令因为语法简单、操作高效受到...

你们这些戏精,终究还是被消费大数据揪出来

  当你为了联谊和相亲置办面膜和彩妆的时...

实用又强大,6 款 Python 时间&

  在使用Python的开发过程中,除了...

沟通为王:安全人员必备的软技能

  网络安全市场对技术性技能的需求凸显,...

英国认为朝鲜是“WannaCry”网络攻

  网易科技讯消息,据路透社报道,英国周...

最新内容

广告的唯一宗旨是卖货,卖货

  其实,名人说的确实都对,但他是站在自己产品或服务角度的对,而我们都拿来当普遍...

哪些常见的影响内容的设计问题需要规避

  1、不合理的排版  排版设计出问题,首当其冲的空间设计不合理。段间距和行间距...

如何编写文章获得更好的排名

  第一选择合适的关键词。利用百度指数或者谷歌的关键词指数工具,选择和文章内容有...

关于SEO如何定义关键词我的一点理解

从事搜刮引擎优化事变已经1年多了,在从前我也是只是做个网站,并未涉及到关于网站搜...

如何让客户信赖你的营销型网站

信赖是成交最重要的基础,只有客户觉得你企业可以信赖,那么成交不是一件难事,许多企...

如何让百度收录热门关键词

百度热门关键词能带来很大的流量,这是大家有目共睹的事情。看看百度指数,如“货架”...

安全性测试分享之SQL注入

  安全性测试是指机密的数据确保其机密性以及用户只能在其被授权的范围进行操作的这...

网站怎样更新文章有利于网站排名呢

网站怎样更新文章有利于网站排名呢网站每天更新多少文章有利于SEO?站长们都知道每...

利用SEO技术来做网站页面优化

网站页面优化可以说是SEO优化最基础的东西,因为一个网站的页面优化直接影响你网站...

LoadRunner 中怎么对日期进行参数化?

  【背景】  今天在51Testing论坛看到这样一个问题:根据一些查询条件,...

网站建设对网络营销推广起到推动作用

在网站推广建设中,一旦关键词选择过于宽泛、匹配模式不够精准,竞争对手恶意点击等等...

OpenStack Rally 性能测试

  注意点:在测试nova,在配置文件里面如果不指定网络id,那么默认是外网的网...

Python Nose框架编写测试用例方法

  1.关于Nose  nose项目是于2005年发布的,也就是py.test改...

如何有选择的对数组进行操作

#includeint a[3] = {1,2,3};int ...

测试微服务之建立测试文化

  这是由来自AWS的工程师NathanPeck发布的“测试微服务”系列文章的第...

影响软件测试人员才能提升的因素

  今天和一位同事谈起影响软件测试工程师获得提升以及获得高新的原因是什么、可能每...

我的疑问

工作有些年头了,但是感觉不出自己有多厉害,顶多也就是经验多了点,而在纯粹的技术领...

如何使用OnCtlColor消息函数对BUTTON设置不同的颜色

本帖最后由martin_tang于2015-10-1823:23:11编辑我的目...

Jmeter接口自动化测试方法简介

软件大小:613KB资源类型:不详授权方式:免费/开源资料   主要内容:   ...

华为一员工因说真话连升两级!质量人,你怎么看?

  话说,职场如战场,什么话该说,什么话不该说,什么场合说什么话......这是...