自动化测试理解

1 定义

把以人为驱动的测试行为转化为机器执行的一种过程

  • 简单讲:比如使用自动化测试框架、脚本、工具等自动打开测试对象(引用),自动去执行测试用例(此过程中包含自动化查找元素、控件等),自动输入测试数据、自动生成测试报告等一系列的自动化过程;
  • 通俗讲:用机器来模拟用户的实际行为,如键盘、鼠标等操作,来达到预期。

2 做自动化的目的是什么?

  • 测试工作量比较大,使用自动化来完成一部分工作;
  • 测试过程有大量重复的工作,使用自动化来进行提升效率;
  • 手工测试难以覆盖的场景,需要自动化造数据等来完成;
  • 有些测试结果,可能自动化比手工更为精确

3 自动化测试的优缺点

优点 缺点
重复执行、频繁操作 不能100%替代人工测试
模拟手动测试无法覆盖的场景 不能达到100%覆盖率
利用空闲时间执行 需要时间去分析结果
释放一部分测试人员精力 对软件质量依赖大(前提是软件稳定、改动小等)
测试结果客观公正 需要专业的工程师投入专门的时间开发
/ 投入成本可能会大一些

4 自动化测试的前提条件(重要)

即做自动化前先对软件进行分析,是否满足或者要不要做自动化,有几个前提条件需要注意。

4.1 需求变动不频繁

  • 脚本的稳定性最直观的决定要素是需求的变动,如果需求变化大,隔三差五的进行需求更改,那脚本势必也要进行同步更新,这样投入的维护成本就很大,得不偿失,还不如不做。

4.2 项目周期比较长

  • 自动化测试和普通的测试一样,需要前期的规划、框架设计、脚本开发、人员选择、脚本执行、后期维护以及结果跟踪分析等,是一个比较全的且投入较多的一个过程,如果项目周期很短,就不适合做自动化,其实也没必要;
  • 另外项目周期短,手动测试都无法保证的前提下,更不用谈及做自动化了。

4.3 脚本的重复使用率高

  • 我们投入了较大的人力、物力、财力等最终完成了一套比较完美的自动化脚本、框架或者平台,但是复用率很低,只能在单个产品单独使用,那么这样的代价就太大了。此时我们需要评估是否必须要进行自动化测试,如果非必须,可以不做;
  • 相反的,如果自动化的一系列东西都能迁移到其他的产品测试,那这样的投入是值得的,也是必要的。我们也应该投入更多的精力进行测试开发。

4.4 团队实力

  • 做自动化,不是随便摘抄一些代码拿来用,他是一个专项测试,需要投入专门的人力去研究及测试,那么我们要想做好自动化,先要对自己的团队进行评估,团队的人员、技术能力等是否满足要求;
  • 另外,自动化需要不断的进行迭代和优化,不能拿着脚本运行看看结果,那其实很多时候,并不能给产品带来客观的价值。我们需要进行不定期的升级维护,针对项目业务要进行优化,根据测试过程和结果的数据反馈要进行稳定性的升级等等。所以这也需要专门投入人力进行研究。

4.5 部门的规划和上级的支持

这个是我加的,根据个人的经验的总结;

  • 部门的规划:如果自动化是在部门规划中,以及有考核目标,那肯定是要做的。如果不是规划,也没有纳入计划,那就要根据实际情况定,毕竟这不会直接影响你团队的实际考评。你的重点应该是在其他的地方,优先保证工作重点内容的完成;
  • 上级的支持:这个很重要,做自动化无非是为了提升效率和质量,但是如果没有得到应有的效果,领导看不到成绩,也无感知,那么做自动化也许不会长久。这个得慢慢体会了,哈哈。

5 应用场合

自动化测试主要应用在以下场合,具体还要根据项目以及自动化的实际开发情况开定:

场景 说明
测试周期 项目周期长,轮次较多的软件
数据量级 需要制造大量的测试数据
软件稳定性 使用稳定和成熟阶段的产品测试
回归测试 需要进行简单回归的测试
冒烟测试 主线功能的冒烟
巡检测试 线上环境的定期巡检
发布验证 主线功能的发布验证测试

6 自动化认识误区(重点)

6.1 自动化可100%覆盖

  • 概率不大,要使得自动化的测试覆盖率达到100%,需要投入专门的人力、物力、财力等,成本比较大;
  • 某些业务的特殊性,或者场景的复杂性,用自动化是无法进行覆盖的;
  • 项目的周期限制,不允许投入更多的精力去开发;

6.2 自动化可替代人力

  • 领导的口头禅:你就告诉我,自动化能干掉多少人力?!====每次听到这样的话,不知道你们怎么想的,反正我是很无奈。但从领导的角度来思考,也不为错;
  • 这里存在一些误区,自动化测试是辅助功能测试的,或者说是为了解决某些人工不能覆盖的场景;
  • 另外,不存在完完全全的自动化,都是需要人工参与的;
  • 遇到类似的认识,建议自动化测试人员需要进行解释,不能任由这个观点滋生,不然===你猜会咋办!!

6.3 自动化很牛逼

  • 任何的事情,都是看谁先知道而已,与其说牛逼的技术,不如说牛逼的人
  • 自动化只是一门技术,我们不能脱离业务搞自动化;
  • 很多人认为自动化很厉害,就脱离了工作的重心,天天喊着自动化、自动化,最后到头来啥也不是,啥也没得到。当然如果是专业、专门搞自动化测试开发的那就另说了。因为他们的工作就这,就是转、精

6.4 万物皆可自动化

  • 这个其实和前边的提到的一致,搞自动化,先要符合一些前提条件以及明白他的应用场景,不是所有软件都要搞自动化。
  • 盲目的自动化,只会适得其反

6.4 自动化很简单

  • 这是一个很复杂的但是又简单的话题,对自动化的方向、工具、技能等研究的程度不同,对他的认识就不一样;
  • 如果只是解决一些简单的问题,你掌握他很简单。如果是复杂的一些东西,可能需要深入研究;
  • 自动化方向也是很多,不论是功能、性能,还是面向接口、UI、GUI、协议,更或是自动化工具开发等,都需要不同的技能和知识,入门或许简单,要做的很专一,还是需要点积累的。

6.5 自动化尽早做

不一定。不同的自动化,介入时间可能有差异,比如

  • UI的,建议软件稍微稳定或者需求变更不频繁的时候再去开发;
  • 接口的,可以在开发阶段同步进行;

7 自动化测试工具

太多了,举个例子,不代表所有的。事例而已:
自动化测试理解_第1张图片

你可能感兴趣的:(自动化测试软件测试测试)