敏捷开发自动化测试框架之用户故事

Posted 51Testing软件测试网

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了敏捷开发自动化测试框架之用户故事相关的知识,希望对你有一定的参考价值。


敏捷开发自动化测试框架之用户故事

  自动化测试框架搭建及开发,我是按照敏捷开发的用户故事模式,把每个阶段都拆成一个大故事,再拆分成一个个小的故事,一一实现。

  用户故事是描述对用户有价值的功能,好的用户故事应该包括角色、功能和商业价值三个要素:

  1、角色:谁要使用这个功能。

  2、功能:需要完成什么样的功能。

  3、价值:为什么需要这个功能,这个功能带来什么样的价值。

  使用这种模式的目的:用户故事越细,越能更好的统计每个阶段的目标,完成的时间,所需要的人力,越容易控制测试开发的周期,及阶段性的工作成果,若测试开发期出各种问题可以及时弥补。

  以公司移动端自动化项目来介绍,如何以敏捷开发之用户故事模式来完成测试框架搭建及开发:

  一、选择合适的框架

  1、罗列出对框架的要求

  1)测试对像为移动端客户端,平台为androidios

  2)App应用类型:原生+web,其中支付会调用第三方App;

  3)你会用什么语言开发,例:JAVA;

  注:这个框架要满足跨平台,跨进程,支付混合模式,支持JAVA编程语言;

  2、要满足1)的条件都列出,选择最适合的框架:

  如上要求,最满足条件得只有Appium了;

  二、配置环境

  1、安装Appium开发环境;

  2、下载找到系统,软件,硬件都兼容的版本,否则会在版本兼容上浪费很多时间;

  3、下载一个实例,调试,运行。

  三、框架结构整改

  下载的实例都是比简单流程操作,易用性较差,需要改进:

  1、我使用的JAVA工厂模式 ;元素定位,操作,用例,场景都是按最小单元划分;

  1)定位元素封装为一个公共的方法;用到调用及可;

  2)元素操作为最小单元:例:点击登录按钮为一个方法:

  3)多个方法组为一个CASE,一个方法可以被多个CASE调用;

  4)一个或者多个CASE可以组合为一个场景;可也可被多个场景调用;

  5)像截图,滑屏,...公共方法都封装起来调用执行。

  2、关键字驱动;

  1)参数属性存放在一方法里

  2)操作元素的ID,Name,Xpath,...都放在一个指定文件,在写方法操作时在指定文件读取,修改即可,例:元位

  定位变了,修改一处可以实现多处被修改,不用一处理去修改。

  3、部份数据初始或者销毁会用到数据库;

  4、代码结构

  四、用例是否可自动化

  把可以需要自动化的用例加以标识,并标识需要自动化用例的优先级,按照优先级别开发自动化CASE。

  五、自动化功能分块,以公司产品为O2O模式;

  1、可以先大至分为三大块:用户,商户,流程(用户与商户交互);

  2、在将大类按模块拆分成小类;

  六、CASE颗粒度设计

  越细越好,方便组合与拆分。

  七、场景设计

  1、每一个模块,或者一个流程组合成一个场景;

  2、再按大类组合一个用例集

  • 用户主页:只覆盖用户主页的CASE;

  • 用户侧边栏:用户侧边栏CASE;

  • 商户功能:用户所有CASE;

  • 流程功能:订单部份,用户与商户交互订单流程CASE;

  • 支付功能:所有与支付相关的CASE;

  • BVT脚本:覆盖所有功能,是将以上功能组合实现;

  按用户故事划分的好处是分开执行,也可以组合执行,各功能也可以分不同人去编写,然后组合再一起,也利于分配和过程控制。

敏捷开发自动化测试框架之用户故事

 
推荐阅读

点击阅读☞

点击阅读☞

点击阅读☞

点击阅读☞

点击阅读☞

敏捷开发自动化测试框架之用户故事

点击左下角“阅读原文”查看更多内容!

以上是关于敏捷开发自动化测试框架之用户故事的主要内容,如果未能解决你的问题,请参考以下文章

在高度自动化的敏捷项目中,您是不是为每个故事创建手动测试用例? [关闭]

用户故事与敏捷开发方法笔记03

敏捷测试

《用户故事与敏捷方法》阅读笔记05

Restful and 前后端分离

在敏捷中应用测试驱动开发