一、安装selenium和环境配置

1 pip install selenium

2 三个驱动文件放到d:盘根目录

3 安装火狐版本33

4 安装插件:selenium ide\firebug\firepath

5 下载三个Py程序,分别修改,将路径设定为三个驱动文件所在的路径,然后分别执行,看看是否可以打开浏览器,显示搜狗页面,有一个能成功即可

【踩坑】

IE浏览器的话需要设置

1、  缩放100%

2、  全勾选或者全不勾选

二、自动化测试
1、自动化测试优势:
(1)重复多次执行时节省时间,提高测试覆盖率
(2)自动化回归
(3)规范化过程
(4)历史文档记录
2、自动化测试局限性:
(1)只能发现15%的bug
(2)不能提高测试有效性,只能提高效率
(3)不具想象力,没人聪明
(4)不能取代手工测试
3、自动化测试的内容:
(1)测试数据自动生成
(2)自动化输入
(3)测试结果自动比较
(4)测试自动执行
(5)测试用例的管理
(6)在线监控
4、自动化脚本技术:
(1)线性脚本
(2)结构化脚本
(3)共享脚本
(4)数据驱动脚本
(5)关键字驱动脚本
数据驱动脚本示例:程序不变数据变
data.txt:
e:\\a.txt
e:\\1.html
 
main.py:
#encoding=utf-8
 
with open("data.txt") as fp:
    for i in fp:
        with open(i.strip()) as fp1:
            print fp1.read()
 
 
关键字驱动脚本示例:通过数据文件中的关键字,调用另一个文件中的函数,实现某个功能。 将测试逻辑按照这些关键字进行分解,形成数据文件,用关键字的形式将测试逻辑封装在数据文件中,测试工具只要能够解释这些关键字即可对其应用自动化
 
#练习:(1)将data.txt文件中op作为关键字,调用kd.py中的op()方法读取1.txt文件中的所有内容;(2)将data.txt文件中第二、三行数据用","区分,write和read作为操作类型;e:\\test4\\...作为操作路径;w和r作为操作权限;"glory road is good!"为写入内容;
kd.py:
#encoding=utf-8
def op():
    with open("e:\\test4\\1.txt") as fp:
        print fp.read()
 
def write(file_path,mode,content):
    with open(file_path,mode) as fp1:
        fp1.write(content)
 
def read(file_path,mode):
    with open(file_path,mode) as fp2:
        print fp2.read()
 
kd2.py:
#encoding=utf-8
from kd import *
 
with open("e:\\test4\\data.txt") as fp:
    for i in fp:
        if i.find(",")!=-1:
            prams=i.strip().split(",")
            if len(prams)==4:
                command=prams[0]+"(\""+prams[1]+"\",\""+prams[2]+"\",\""+prams[3]+"\")"
                print command
                eval(command)
 
            if len(prams)==3:
                command=prams[0]+"(\""+prams[1]+"\",\""+prams[2]+"\")"
                print command
                eval(command)
        else:
            prams=i.strip()
            command=prams+"()"
            print command
            eval(command)
 
data.txt:
op
write,e:\\a.txt,w,glory road is good!
read,e:\\a.txt,r
 
1.txt:
Process-2:2018-03-31 15:02:31
glory road is good!
 

5、使用自动化的一些典型场景:
(1)大量的回归测试
(2)注入测试数据
(3)敏捷开发的TDD模式,行为驱动开发模式
(4)机械并繁琐的测试
(5)业务监控
6、自动化术语:
(1)框架:整个或部分系统的可重用设计,可以看做是一种应用骨架
(2)关键字驱动的自动化测试:主要包括被操作对象、操作和值

【Python】UI自动化-1的更多相关文章

  1. (appium+python)UI自动化_09_unittest批量运行测试用例&生成测试报告

    前言 上篇文章[(appium+python)UI自动化_08_unittest编写测试用例]讲到如何使用unittets编写测试用例,并执行测试文件.接下来讲解下unittest如何批量执行测试文件 ...

  2. Python—UI自动化完整实战

    实战项目 均来源于互联网 测试报告2017年11月29日优化后的测试报告:https://github.com/defnngj/HTMLTestRunner 1.项目概述: 本实战已126邮箱为例子进 ...

  3. (appium+python)UI自动化_07_app UI自动化实例【叮咚搜索加车为例】

    前言 初学UI自动化的小伙伴,在配置好appium+python自动化环境后,往往不知道如何下手实现自动化.小编在初期学习的时候也有这种疑惑,在此以叮咚买菜app-搜索加车为实例,展示下appium是 ...

  4. (appium+python)UI自动化_01_自动化环境搭建【MAC版】

    Appium简介 Appium是一个开源的.跨平台的测试框架,主要用来进行app UI自动化,适用于原生应用.混合应用和移动网页应用(H5页面).目前支持Python.JavaScript.Objec ...

  5. python UI自动化之切换iframe

    python+selenium写UI自动化的时候,经常会遇到需要切换iframe的情况,这里介绍几种切换iframe的方式 1.使用id定位 driver.switch_to.frame(" ...

  6. Python UI自动化

    Python3--Uiautomator2--Pytest--Alure使用 官方源码GitHub地址:https://github.com/openatx/uiautomator2 介绍 uiaut ...

  7. (appium+python)UI自动化_03_元素定位工具

    前言 在UI自动化过程中,需要对手机app上的元素进行定位,然后进一步编写自动化脚本操作app.定位元素首先需要定位工具来辅助查看页面元素.小编常用的定位工具有2种,分别是uiautomatorvie ...

  8. python ui自动化之元素定位和常用操作

    做ui自动化的最基础的就是页面元素定位了,如果连页面元素都定位不到,自动化从何谈起呢?接下来我们就看看页面元素定位的方法吧!(这里就用百度页面来进行演示) 一.最通用的几种定位方式: 1.通过id定位 ...

  9. (appium+python)UI自动化_02_appium启动手机app

    前提:需先安装配置好appium+python自动化环境,已配置好环境的小伙伴可以参考以下步骤启动Android app,具体步骤如下: 一.USB连接手机 (1)手机USB连接电脑 (2)手机打开开 ...

  10. python UI自动化实战记录三:pageobject-基类

    脚本思路: 使用pageobject模式,写一个basepage基类,所有页面的通用方法封装到基类中.比如打开页面,关闭页面,等待时间,鼠标移到元素上,获取单个元素,获取一组元素,获取元素的子元素,截 ...

随机推荐

  1. Oracle 三大范式

    范式:数据库设计对数据的存储性能,还有开发人员对数据的操作都有莫大的关系.所以建立科学的,规范的的数据库是需要满足一些.规范的来优化数据数据存储方式.在关系型数据库中这些规范. 第一范式:数据库表中的 ...

  2. Oracle11g温习-第十八章:role管理

    2013年4月27日 星期六 10:52 role 的功能:简化用户的权限管理 建立角色——给角色授权——将角色授予用户/角色 2.查看系统建立的role SYS @ prod >  selec ...

  3. application使用@符合问题:'@' that cannot start any token. (Do not use @ for indentation)

    在application配置文件中使用@出现异常: Exception in thread "main" while scanning for the next token fou ...

  4. Python---字典常用方法总结

    字典是一种key-value的数据类型,字典里必须写Key和value,字典的优点是取数方便和速度快.字典的特性: 1.字典是无序的,因为它没有下标,用key来当索引,所以是无序的 2.字典的key必 ...

  5. Oracle Shared Pool之Library Cache

    1. Shared Pool组成 Shared Pool由许多区间(Extent)组成,这些区间又由多个连续的内存块(Chunk)组成,这些内存块大小不一.从逻辑功能角度,Shared pool主要包 ...

  6. 使用VAE、CNN encoder+孤立森林检测ssl加密异常流的初探——真是一个忧伤的故事!!!

    ssl payload取1024字节,然后使用VAE检测异常的ssl流. 代码如下: from sklearn.model_selection import train_test_split from ...

  7. 微信小程序生成二维码

    微信小程序客户端生成二维码的方法, 请参考这里: https://github.com/demi520/wxapp-qrcode  代码片段如下: const QR = require(". ...

  8. python 关闭垃圾回收

    import gc gc.disable() http://blog.csdn.net/aixiaohei/article/details/6446869

  9. 通过AssemblyResolve事件打包合并exe和dll文件

    使用WPF开发的安装包,在创建快捷方式的时候,需要用到COM程序集Windows Script Host Object Model,引用COM程序集后,会在debug目录生成Interop.IWshR ...

  10. 基于Quartz.NET 实现可中断的任务(转)

    Quartz.NET 是一个开源的作业调度框架,非常适合在平时的工作中,定时轮询数据库同步,定时邮件通知,定时处理数据等. Quartz.NET 允许开发人员根据时间间隔(或天)来调度作业.它实现了作 ...