selenium3与Python3实战 web自动化测试框架

selenium3与Python3实战 web自动化测试框架 学习 教程

一、环境搭建

1、selenium环境搭建

Client:

  •  pycharm
  •  python3.6

Driver:

  •  Chrome → ChromeDriver
  •  Firefox  → FirefoxDriver
  •  IE         → InternetExplorerDriver

Selenium

1.1、Selenium安装

pip install selenium  # 安装
from selenium import webdriver  # 导入
driver = webdriver.Chrome()  # 启动谷歌浏览器
driver.get("http://www.baidu.com")  # 打开百度网址
# 注意:启动谷歌浏览器前需要配置好谷歌浏览器中间件 ,从网上下载chromedriver.exe ,将其放置到python的安装目录下

1.2、使用脚本启动不同浏览器

启动浏览器前需配置好浏览器对应driver:

  • Chrome --chromedriver.exe :谷歌浏览器调试驱动插件
  • Firefox --geckodrive.exe : 火狐浏览器调试驱动插件
  • IE --MicrosoftWebDriver.exe : IE浏览器调试驱动插件

将上面三个exe文件下载后放置到python目录下

1)启动谷歌浏览器

from selenium import webdriver

driver = webdriver.Chrome()

driver.get('http://www.baidu.com')

2)启动火狐浏览器:

from selenium import webdriver

driver = webdriver.Firefox()

driver.get('http://www.baidu.com')

3)启动IE浏览器

from selenium import webdriver

driver = webdriver.Ie()

# driver = webdriver.Edge()  # win 10版本启动IE浏览器,使用此行代码

driver.get('http://www.baidu.com')

2、使用expected_condition下的 title_contains判断页面标题是否与我们想要的一致,如判断页面标题是否有‘注册’字眼:

from selenium import webdriver

from selenium.webdriver.support import expected_conditions

import time

driver = webdriver.Chrome()

# driver = webdriver.Edge()  # win 10版本启动IE浏览器,使用此行代码

driver.get('http://www.5itest.cn/register')

time.sleep(5)

is_live = expected_conditions.title_contains('注册')  # 判断页面的标题中是否有注册两字

print('is_live:',is_live)

返回结果:

is_live: <selenium.webdriver.support.expected_conditions.title_contains object at 0x000000000354DEF0>  # 存在

3、使用不同方式进行定位

访问注册链接:http://www.5itest.cn/register ,进行测试

 

from selenium import webdriver

driver = webdriver.Chrome()

driver.get('http://www.5itest.cn/register')

driver.find_element_by_id('register_email').send_keys("nan@163.com")  # 填写邮箱

user_name_node = driver.find_elements_by_class_name('controls')[1]  # 使用classname进行定义,需要细心处理

user_name_node.find_element_by_class_name('form-control').send_keys('Eric_nan')  # 填写用户名

driver.find_element_by_name('password').send_keys('111111')  # 填写密码

driver.find_element_by_xpath('//*[@id="captcha_code"]').send_keys('2222')  # 填写验证码

脚本控制启动浏览器并访问注册页面,同时自动输入我们设定的值:

 

4、使用expected_conditions判断元素是否可见

from selenium import webdriver

from selenium.webdriver.support import expected_conditions

from selenium.webdriver.support.wait import WebDriverWait

from selenium.webdriver.common.by import By

driver = webdriver.Chrome()

locator = (By.CLASS_NAME,'controls')  # 通过classname的方式 找到 controls

WebDriverWait(driver,1).until(expected_conditions.visibility_of_element_located(locator))

# WebDriverWait: 传入两个参数,一个是driver,另一个是超时时间(int类型)

# visibility_of_element_located:只在可见的元素里找对应的元素。如有返回内存地址

 5、如何解决验证码自动输入

1)将注册页面全屏截图保存(使用driver.save_screenhot方法),再将验证码部分区域截图保存下来

打开本地图片、截取部分区域需要用到PIL ,安装:pip install -i

base_dir = os.path.dirname(os.path.dirname(os.path.abspath(__file__))) # 项目首路径

image_path = os.path.join(base_dir,'Image','imooc.png')  # 图片路径,用于保存全屏截图后的图片

code_path = os.path.join(base_dir,'Image','code.png')  # 验证码图片保存路径

driver.get('http://www.5itest.cn/register')

driver.save_screenshot(image_path)  # 全屏截图

code_element = driver.find_element_by_id("getcode_num") # 定位到验证码所在的文字

# print(code_element.location)   # 获取该元素(图片)左上角的(x,y)坐标

# print(code_element.size)   # 获取该元素(图片)长度、宽度

left_x = code_element.location['x'] # 左上角x值

top_y = code_element.location['y'] # 左上角y值

right_x = left_x + code_element.size['width']  # 右下角x值

right_y = top_y + code_element.size['height']  # 右下角y值

im = Image.open(image_path) # 使用PIL下的Image打开下载的imooc.png图片

img = im.crop((left_x,top_y,right_x,right_y))  # 将指定的某部分裁剪出来

img.save(code_path) # 保存

2)使用 showapiRequest解决图片验证码识别

①、使用pytesseract识别图片中得问题

  安装:pip install pytesseract

import pytesseract

from PIL import Image

image = Image.open("E:/imooc2.png")

text = pytesseract.image_to_string(image) # 将图片文字转换成字符串

print(text)

# 缺点:机械性读取,无法读取图片中不规则的字体,不适合于干扰性比较强的验证码图片文字读取

选择:验证码识别英数_文件 ,找到请求示例,下载SDK:ShowapiRequest.py

 

将 ShowapiRequest.py文件放到项目中,新建read_code_img.py文件,用于读取图片中的验证码:

 验证码:

from setting.ShowapiRequest import ShowapiRequest

from setting import setting

r = ShowapiRequest("http://route.showapi.com/184-4","62666","d61950be50dfgjnr9969f741b8e730f5" )

# ShowapiRequest 的第一个参数是万维易源网的url ,第二个参数是易源网上你个人的appId , 第三个参数是易源网上的密钥

r.addBodyPara("typeId", "35")  #typeId:表示识别几位数的图片验证码 ;35:'3'表示英数结合的验证码,'5'表示5位数的验证码   ; 31:一位数的验证码

r.addBodyPara("convert_to_jpg", "0")

r.addFilePara("image", setting.code_path) # 添加要识别验证码的图片

res = r.post()

print(res.text)  # {"showapi_res_error":"","showapi_res_id":"6f0e4cdb977141b293ea12178ad3d37e","showapi_res_code":0,"showapi_res_body":{"Id":"5bac83cc-5637-4e2d-bc91-25a78b527241","Result":"ANLZZ","ret_code":0}}

text = res.json()['showapi_res_body']['Result']# 以json格式读取:showapi_res_body 下 Result 的值

print(text) # 返回信息:ANLZZ (识别正确)

注:这种方式识别准确率比较高

将注册相关代码封装起来-初次封装

注册自动输入对应信息

 6、封装读取配置文件方法

新建int配置文件:

#localElement.ini文件

[RegisterElement]

user_email=id>register_email

user_email_error=id>register_email-error

user_name=id>register_nickname

user_name_error=id>register_nickname-error

password=id>register_password

password_error=id>register_password-error

code_image=id>getcode_num

code_text=id>captcha_code

code_text_error=id>captcha_code-error

register_button=id>register-btn

使用python3自带 configparser模块, 用于读取配置文件信息:

from setting.setting import config_ini_dir

import configparser

class Read_Ini(object): # 初始化

def __init__(self,node = None):

if node:

self.node = node

else:

self.node = 'RegisterElement'  # 配置文件中的某个节点

self.cf = self.load_ini()

def load_ini(self):  # 加载文件

cf = configparser.ConfigParser()  # 使用 configparser模块读取配置文件信息

cf.read(config_ini_dir)  # 配置文件所在路径

return cf

def get_value(self,key): # 获取配置文件中key的value值

data = self.cf.get(self.node,key)

return data

# if __name__ == '__main__':

#     read_init = Read_Ini()

#     print(read_init.get_value('user_name'))  # 结果:id>register_nickname

7、封装定位元素类

# find_element.py

from util.read_ini import Read_Ini

class FindElement(object):

def __init__(self,driver):

self.driver = driver

def get_element(self,key):

read_ini = Read_Ini()

data = read_ini.get_value(key)

by,value = data.split('>')

try:

if by == 'id':

return self.driver.find_element_by_id(value)

elif by == 'name':

return self.driver.find_element_by_name(value)

elif by == 'className':

return self.driver.find_element_by_class_name(value)

elif by == 'xpath':

return self.driver.find_element_by_xpath(value)

else:

return self.driver.find_element_by_css(value)

except Exception as e:

print("find_element错误信息:",e)

return None

* 注册完整流程

1、配置文件

1)LocalElement.ini:存定位元素信息

LocalElement.ini

2)setting.py:

setting.py

3)read_ini.py:读取配置文件LocalElement.py的配置信息

read_ini.py

4)find_element.py:获取元素定位信息

find_element.py

5)register_function.py:注册测试主程序

register_function.py

selenium3与Python3实战 web自动化测试框架 ☝☝☝的更多相关文章

  1. selenium3与Python3实战 web自动化测试框架✍✍✍

    selenium3与Python3实战 web自动化测试框架  整个课程都看完了,这个课程的分享可以往下看,下面有链接,之前做java开发也做了一些年头,也分享下自己看这个视频的感受,单论单个知识点课 ...

  2. web自动化 基于python+Selenium+PHP+Ftp实现的轻量级web自动化测试框架

    基于python+Selenium+PHP+Ftp实现的轻量级web自动化测试框架   by:授客 QQ:1033553122     博客:http://blog.sina.com.cn/ishou ...

  3. 【python3+request】python3+requests接口自动化测试框架实例详解教程

    转自:https://my.oschina.net/u/3041656/blog/820023 [python3+request]python3+requests接口自动化测试框架实例详解教程 前段时 ...

  4. Windows环境搭建Web自动化测试框架Watir

    Windows环境搭建Web自动化测试框架Watir 一.前言     Web自动化测试一直是一个比较迫切的问题,对于现在web开发的敏捷开发,却没有相对应的敏捷测试,故开此主题,一边研究,一边将We ...

  5. Web 自动化测试框架 sweetest 介绍

    项目开源: https://github.com/tonglei100/sweetest 文章转载:https://segmentfault.com/a/1190000011612061 介绍 swe ...

  6. Web自动化测试框架Watir(基于Ruby) - 第2章 使用Watir写自动化测试脚本

    一.先来看一个小DEMO 通过上一篇博文<Web自动化测试框架Watir(基于Ruby) - 第1章 Windows下安装与部署>的介绍,我们已经有了完整Watir运行环境,现在我们可以来 ...

  7. Web自动化测试框架Watir(基于Ruby) - 第1章 Windows下安装与部署

    一.前言 Web自动化测试一直是一个比较迫切的问题,对于现在web开发的敏捷开发,却没有相对应的敏捷测试,故开此主题,一边研究,一边将Web自动化测试应用于工作中,进而形成能够独立成章的博文,希望能够 ...

  8. web自动化测试框架总结

    web自动化测试框架总结: https://www.processon.com/mindmap/5bdab924e4b0878bf41e9e09

  9. Web自动化测试框架改进

    Web自动化测试框架(WebTestFramework)是基于Selenium框架且采用PageObject设计模式进行二次开发形成的框架. 一.适用范围:传统Web功能自动化测试.H5功能自动化测试 ...

随机推荐

  1. 英文写作report

    Writting Attached Files   Maybe you might want to get familiar about how to write the Final report. ...

  2. Http和Https相关问题

    Http和Https Http(默认端口号80) 超文本传输协议(Http,HyperText Transfer Protocol)是互联网上使用最为广泛的一种网络协议(应用层).设计Http最初的目 ...

  3. [0]尝试用Unity3d制作一个王者荣耀(持续更新)->游戏规划

    太得闲了于是想写个农药,虽然可能会失败但是还是要试一试. 因为是自学的不是Unity专业的可能表达语言会有些不标准!望见谅! 结构: 以组件式(比如说摇杆控制和玩家部分的编写是分离的,可以自由拼装)作 ...

  4. Elastic Stack 笔记(二)Elasticsearch5.6 安装 IK 分词器和 Head 插件

    博客地址:http://www.moonxy.com 一.前言 Elasticsearch 作为开源搜索引擎服务器,其核心功能在于索引和搜索数据.索引是把文档写入 Elasticsearch 的过程, ...

  5. 一个基于vue的时钟

    前两天写了一个基于vue的小钟表,给大家分享一下. 其中时针和分针使用的是图片,结合transform制作:表盘刻度是通过transform和transformOrigin配合画的:外面的弧形框框,啊 ...

  6. c语言的数据类型,运算符,存储类型

    [1词法符号]1. 关键字:32个1) 存储类型:决定(设备)变量的存储位置auto(自动型).extern(外部引用) static(静态型) register(寄存器类型)2) 数据类型:决定设备 ...

  7. 手把手教你使用Java实现一个神经网络

    首先看一下运行效果: 下面是项目整体目录: 0.实现神经网络总览 神经网络由层.神经元.权重.激活函数和偏置组成.每层都有一个或者多个神经元,每一个神经元都和神经输入/输出连接,这些连接就是权重. 需 ...

  8. CentOS7下LVM的基本操作

    CentOS7下LVM的基本操作-创建LVM 环境 物理主机:windows10 虚拟软件:VMWare14 虚拟机:CentOS Linux release 7.6.1810 (Core) 软件环境 ...

  9. 判断java中最多的词组

    其中的难点,是空格,以及如果第一个是空格怎么办,虽然事后看着很简单,但是做的时候却十分的困难! static void Daunyu()throws IOException {     Word wo ...

  10. Java查询判断素数实验报告

    实验源代码: package sushu; import java.util.Scanner; public class First { int size=2; int data[]=new int[ ...