自己折腾了一个python的自动化测试框架,梳理了一下流程,简单分享一下。

项目背景

B/S架构,进行用户界面的自动化测试

工具选择

python开发的自动化测试框架,足够灵活,可以随时根据需求进行变更,易于维护

框架思路(unittest)

采用数据驱动的设计,将数据分层出来,与业务逻辑剥离,测试人员专注测试用例,不用关注代码,提高了测试效率

测试框架介绍

测试工程的结构如下:

Data目录

存放涉及业务的资源,例如上传图片场景的图片资源

Driver目录

存放浏览器驱动文件

Excel目录

存放测试用例(重要)

4个sheet分页,如下:

PageElements分页                 –存储页面元素的关键字定位信息

TestConfig 分页               --配置信息

TestSuite 分页                 --测试用例标题

TestSteps 分页                --测试用例的执行步骤

Package目录

封装的方法简介

assertUtil.py           --断言

assert_equal                    """预期结果和实际结果 相等"""

      assert_prompt                 """页面提示信息"""

      …

base.py                --涉及系统的信息(暂时不用)

base_get_hostname     """获取本机电脑名"""

base_get_ip                 """获取本机ip"""
                   …

browserUtil.py      --浏览器的操作

      browser_title                """获取当前浏览器标题"""

browser_url                  """获取当前浏览器URL"""

excelUtil.py          --excel文件的操作

excel_open               """打开excel文件(xls)"""

excel_sheet              """指定sheet页面"""

excel_cell_data          """获取指定单元格内容"""

keysUtil.py         --键盘操作

location.py         --封装页面元素定位

login.py             --登录业务

objectMap.py     --关键字映射

ob_key_input       """根据关键字input执行页面元素查找"""

ob_key_click        """根据关键字click执行页面元素查找"""

util.py               --通用场景

ut_highlighted     """元素高亮"""

      …

Picture 目录

存放用例执行的报告

Test_case 目录

存放测试用例执行脚本

Config.py

存储常量、配置信息之类的信息

PageElements.py

存储页面元素信息

例如登录页面的3个控件:

"登录-输入用户名"                                                 --表示用户名输入框

"input>css>input[placeholder='请输入账号']"

Input                                                                 –定义的关键字

Css                                                                   –元素定位方式

input[placeholder='请输入账号']                             --元素定位表达式

测试用例执行的流程图:

步骤1:

执行TestCase_UI.py脚本,用例启动

步骤2:

读取excel目录下测试用例(*.xls)

TestConfig分页:

获取浏览器启动类型              --启动相应浏览器

获取URL地址                      --打开URL地址

步骤3:

读取TestSuite分页:

逐行读取测试用例执行标识,标识为“yes”表示执行该条用例,为“no”跳过该用例

获取“测试用例序号”

步骤4:

读取TestSteps分页:

按照“测试用例序号”读取测试用例执行步骤

例如VDT_WDGZT_001用例,存在4个步骤,逐行读取“测试步骤描述”

步骤5:

读取PageElements分页:

按照“测试步骤描述”读取关键字、页面定位元素、页面元素定位表达式

按照关键字、页面定位元素、页面元素定位表达式 定位到页面元素执行相应操作

例如如下3个步骤:

在输入框中输入“搜索资源”

单击搜索按钮

执行检查点操作

注意:

每个步骤执行完毕,根据执行的情况在测试用例中回写“测试结果”

例如“我的工作台”步骤执行成功,在TestSuite分页,“测试结果”填写“用例步骤执行成功”

相应的在TestSteps分页,测试用例1,的“测试结果”填写“用例执行成功”

如果用例步骤执行失败

例如“公共-登录用户名称检查” 步骤执行失败,在TestSuite分页,“测试结果”填写“用例步骤执行失败”,“页面截图”填写失败截图的路径

相应的在TestSteps分页,测试用例1,的“测试结果”填写“用例执行失败”

测试用例步骤出现失败的情况,则不再执行该用例的剩下的步骤,开始执行下一个测试用例

步骤6:

一条测试用例执行完毕,重复执行步骤3、4、5,直至全部测试用例执行完毕

步骤7:

用例执行完毕,输出测试报告,报告详情:

测试用例执行日志

例如在测试用例中勾选2个用例执行,执行日志如下:

(原创)Python 自动化测试框架详解的更多相关文章

  1. (转)python WSGI框架详解

    原文:https://www.cnblogs.com/shijingjing07/p/6407723.html?utm_source=itdadao&utm_medium=referral h ...

  2. python flask框架详解

    Flask是一个Python编写的Web 微框架,让我们可以使用Python语言快速实现一个网站或Web服务.本文参考自Flask官方文档, 英文不好的同学也可以参考中文文档 1.安装flask pi ...

  3. python WSGI框架详解

    1.web应用的本质1)浏览器发送一个HTTP请求2)服务器收到请求,生成一个HTML文档3)服务器把HTML文档作为HTTP响应的body发个浏览器4)浏览器收到HTTP响应,从HTTP Body取 ...

  4. Python开发技术详解PDF

    Python开发技术详解(高清版)PDF 百度网盘 链接:https://pan.baidu.com/s/1F5J9mFfHKgwhkC5KuPd0Pw 提取码:xxy3 复制这段内容后打开百度网盘手 ...

  5. 《python开发技术详解》|百度网盘免费下载|Python开发入门篇

    <python开发技术详解>|百度网盘免费下载|Python开发入门篇 提取码:2sby  内容简介 Python是目前最流行的动态脚本语言之一.本书共27章,由浅入深.全面系统地介绍了利 ...

  6. mapreduce框架详解

    hadoop 学习笔记:mapreduce框架详解 开始聊mapreduce,mapreduce是hadoop的计算框架,我学hadoop是从hive开始入手,再到hdfs,当我学习hdfs时候,就感 ...

  7. python协程详解,gevent asyncio

    python协程详解,gevent asyncio 新建模板小书匠 #协程的概念 #模块操作协程 # gevent 扩展模块 # asyncio 内置模块 # 基础的语法 1.生成器实现切换 [1] ...

  8. python之struct详解

    python之struct详解 2018-05-23 18:20:29 醉小义 阅读数 20115更多 分类专栏: python   版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议 ...

  9. jQuery Validate验证框架详解

    转自:http://www.cnblogs.com/linjiqin/p/3431835.html jQuery校验官网地址:http://bassistance.de/jquery-plugins/ ...

随机推荐

  1. 如何用unity3d实现发送带附件的邮件

    以Gmail为例.点击屏幕的Capture按钮得到当前屏幕截图,点击Send按钮将之前的截图作为附件发送邮件. using UnityEngine; using System.Collections; ...

  2. js中元素(图片)切换和隐藏显示问题

    这个知识点其实也简单,(当然是在理清思路的情况下),在没预习的情况下听的还真是艰难,上课以来唯一的一次懵逼了一天,感觉乱乱的,全是新属性,所以今晚的我破天荒的熬夜敲代码,一定要弄懂! 现在就来梳理下头 ...

  3. javascript动画毛爷爷满天飘

    var minSize=50;var maxSize=100;var newOn=200;var flakeColor="#fff";var flak=$("<di ...

  4. 【JavaScript】让事件支持先发布后订阅

    之前写过一个的事件管理器,就是普通的先订阅后发布模式.但实际场景中我们需要做到后订阅的也能收到发布的消息.比如我们关注微信公众号,还是能看到历史消息的.类似于qq离线消息,我先发给你,你登录了就能收到 ...

  5. C++高精度模板

    原文地址:http://blog.csdn.net/wall_f/article/details/8373395 原文只附代码,没有解析,本文增加了一些对代码的解释. 请注意:本模板不涉及实数运算与负 ...

  6. HDU_1009_FatMouse' Trade

    FatMouse' Trade Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) ...

  7. 简单五子棋,没有电脑AI

    刚学了C#委托,做了个五子棋练习,把前台绘制和后台逻辑分开,前台绘制方法用委托传给后台逻辑. 界面好简单... 先看类图 控制类控制整个游戏的逻辑,包括调用棋盘类的属性初始化棋盘.初始化两个棋手.轮流 ...

  8. .Net程序员学用Oracle系列(24):数据字典、死锁

    1.静态数据字典 1.1.实用静态数据字典 1.2.运用静态数据字典 2.动态数据字典 2.1.实用动态性能视图 2.2.运用动态性能视图 3.死锁 3.1.定位死锁 3.2.解锁方法 3.3.强制删 ...

  9. CSS3特效----制作立体导航栏菜单

    使用CSS3实现下图的导航菜单效果 <!doctype html> <html lang="en"> <head> <meta chars ...

  10. 通过DNS传输后门来绕过杀软

    前言 在本篇文章里,我想解释怎么样不使用加密数据的方法也能绕过杀软,同时我也想在github上分享源代码.https://github.com/DamonMohammadbagher/NativePa ...