<day002>Selenium基本操作+unittest测试框架
任务1:Selenium基本操作
from selenium import webdriver
# 通用选择
from selenium.webdriver.common.by import By
# 动作
from selenium.webdriver import ActionChains from selenium.webdriver.common.keys import Keys
# 抛出异常
from selenium.webdriver.support import expected_conditions as EC
# 异常处理 超时和为发现元素
from selenium.common.exceptions import TimeoutException,NoSuchElementException
from selenium.webdriver.support.wait import WebDriverWait
import time # 申明驱动浏览器对象,支持Android,BlackBerry等手机端浏览器
browser = webdriver.Chrome()
# browser = webdriver.PhantomJS # 设置浏览器窗口大小
browser.set_window_size(1400, 900) try:
# 必须输入完整URL,直接输入www.baidu.com不行
# 打开URL为XXX的网页
browser.get('http://www.baidu.com')
# 开启新选项卡(开启新窗口)
browser.execute_script('window.open()')
# 打印当前所有句柄
print(browser.window_handles)
# 切换句柄(选项卡)
browser.switch_to.window(browser.window_handles[1])
# switch_to_window被switch_to.window代替,用法一致
# browser.switch_to_window(browser.window_handles[1])
# 在新的选项卡中打开XXX网页
browser.get('https://www.taobao.com/')
# 切回第一个选项卡
browser.switch_to.window(browser.window_handles[0])
# 直接通过id查找
input1 = browser.find_element_by_id('kw')
# 通过css选择器查找,直接在检查中Cope→Cope selector
input2 = browser.find_element_by_css_selector('#kw')
# 通过Xpath选择器查找,可以直接在Cope→Cope xpath
input3 = browser.find_element_by_xpath('//*[@id="kw"]') # 通用选择,需要先引入By from selenium.webdriver.common.by import By
# By后面可以跟ID,CSS_SELECTOR,XPATH等,第二个参数就上面括号内的参数
input4 = browser.find_element(By.ID, 'kw') # 多个节点也是按照上面进行查找,只是element后面加个s,find_elements
time.sleep(1)
# 输入框键入'xx'
input1.send_keys('美女')
# 清空文字
# input1.clear()
# 直接敲击键盘Enter键
# input.send_keys(Keys.ENTER)
# 通过找到id为su的搜索键,鼠标单击
browser.find_element_by_id('su').click() time.sleep(1)
browser.execute_script('window.open()')
browser.switch_to.window(browser.window_handles[2])
browser.get('http://www.runoob.com/try/try.php?filename=jqueryui-api-droppable')
# 切换到子Frame 通常节点名字叫iframe
browser.switch_to.frame('iframeResult')
# 切换回父Frame
# browser.switch_to.parent_frame()
# 找到2个标签
source = browser.find_element(By.CSS_SELECTOR, '#draggable')
target = browser.find_element(By.CSS_SELECTOR, '#droppable')
# 动作链必须先引入 from selenium.webdriver import ActionChains
action = ActionChains(browser)
# 执行拖拽动作
# action.drag_and_drop(source, target)
# 有action 必须有perform方法
action.perform() browser.execute_script('window.open()')
browser.switch_to.window(browser.window_handles[3])
browser.get('https://www.taobao.com/')
browser.execute_script('window.scrollTo(0,document.body.scrollHeight)')
logo = browser.find_element(By.CSS_SELECTOR,'#q')
print(logo)
# 获取输入框属性值
print(logo.get_attribute('aria-label'))
# 获取搜索按钮的文字
input5 = browser.find_element(By.XPATH,'//*[@id="J_TSearchForm"]/div[1]/button')
# 文字
print(input5.text)
# 标签名
print(input5.tag_name)
# id
print(input5.id)
# 在页面中的相对位置
print(input5.location)
# 节点大小
print(input5.size) # 显式等待(等待直到标签出现或超过最大等待时间)
# 设置最大等待时间是10秒
# 报错先引入 from selenium.webdriver.support import expected_conditions as EC
wait = WebDriverWait(browser,10)
# 等待直到id为q的标签出现
input6 = wait.until(EC.presence_of_element_located((By.ID,'q')))
# 等待直到按钮可以被点击
input7 = wait.until(EC.element_to_be_clickable((By.CSS_SELECTOR,'.btn-search'))) browser.switch_to.window(browser.window_handles[0])
# 前进和后退
browser.back()
time.sleep(3)
browser.forward() # 增加一个cookie
browser.add_cookie({'name':'xiaohei','age':'123'})
# 删除 cookie
# browser.delete_cookie()
# browser.delete_all_cookies() # 当前URL
print(browser.current_url)
# Cookie
print(browser.get_cookies())
# 源代码
# print(browser.page_source)
except NoSuchElementException:
print("No Element") # 一定会做的事情
finally:
# 关闭浏览器
pass
# browser.close()
任务2:unittest测试框架(斗鱼的例子)
'''
Ajax含有很多加密参数,我们无法直接进行爬取,只能借助Selenium
'''
#!/usr/bin/env python
# -*- coding:utf-8 -*-
import unittest
from selenium import webdriver
from bs4 import BeautifulSoup as bs
import time class douyu(unittest.TestCase):
# 初始化方法,必须是setUp()
def setUp(self):
# self.driver = webdriver.Chrome()
self.driver = webdriver.PhantomJS()
self.num = 0
self.count = 0 # 测试方法必须有test字样开头
def testDouyu(self):
self.driver.get("https://www.douyu.com/directory/all") while True:
soup = bs(self.driver.page_source, "lxml")
# 房间名, 返回列表
names = soup.find_all("h3", {"class": "DyListCover-intro"})
# 直播间热度, 返回列表
numbers = soup.find_all("span", {"class": "DyListCover-hot"}) for name, number in zip(names, numbers):
self.num += 1
print(
u"直播间热度: -" + number.get_text().strip() + u"-\t房间名: " + name.get_text().strip() + u'-\t直播数量' + str(
self.num))
result = u"直播间热度: -" + number.get_text().strip() + u"-\t房间名: " + name.get_text().strip() + u'-\t直播数量' + str(
self.num)
with open('123.txt','a',encoding='utf-8') as f:
f.write(result) # self.count += int(number.get_text().strip()) # 如果在页面源码里找到"下一页"为隐藏的标签,就退出循环
if self.driver.page_source.find("dy-Pagination-disabled dy-Pagination-next") != -1:
break # 一直点击下一页
self.driver.find_element_by_class_name("dy-Pagination-next").click()
time.sleep(1) # 测试结束执行的方法
def tearDown(self):
# 退出PhantomJS()浏览器
print("当前网站直播人数" + str(self.num))
print("当前网站总热度" + str(self.count))
self.driver.quit() if __name__ == "__main__":
# 启动测试模块
unittest.main()
<day002>Selenium基本操作+unittest测试框架的更多相关文章
- Selenium之unittest测试框架详谈及实操
申明:本文是基于python3.x及selenium3.x. unittest,也可以称为PyUnit,可以用来创建全面的测试套件,可以用于单元自动化测试(模块).功能自动化测试(UI)等等. 官方文 ...
- Python 下的unittest测试框架
unittest测试框架,直接上图吧: data:数据:主要格式为CSV:读取方式:csv.reade: public:封装的模块:通用的模块单独封装,所需参数设置为变量: testcase:测试用例 ...
- Selenium关键字驱动测试框架Demo(Java版)
Selenium关键字驱动测试框架Demo(Java版)http://www.docin.com/p-803493675.html
- python利用unittest测试框架组织测试用例的5种方法
利用unittest测试框架可以编写测试用例,执行方式分两大类:利用main方法和利用testsuite,其中利用测试套件来组织测试用例可以有4种写法. 在此之前,先了解几个概念 TestCase:所 ...
- Python接口测试实战3(下)- unittest测试框架
如有任何学习问题,可以添加作者微信:lockingfree 课程目录 Python接口测试实战1(上)- 接口测试理论 Python接口测试实战1(下)- 接口测试工具的使用 Python接口测试实战 ...
- Selenium WebDriver 数据驱动测试框架
Selenium WebDriver 数据驱动测试框架,以QQ邮箱添加联系人为示例,测试框架结构如下图,详细内容请阅读吴晓华编著<Selenium WebDiver 实战宝典>: Obje ...
- 基于Python的接口自动化-unittest测试框架和ddt数据驱动
引言 在编写接口自动化用例时,我们一般针对一个接口建立一个.py文件,一条接口测试用例封装为一个函数(方法),但是在批量执行的过程中,如果其中一条出错,后面的用例就无法执行,还有在运行大量的接口测试用 ...
- Selenium系列之--测试框架断言【转】
selenium提供了三种模式的断言:assert .verify.waitfor 1)Assert(断言) 失败时,该测试将终止. 2)Verify(验证) 失败时,该测试将继续执行,并将错误记入日 ...
- unittest测试框架详解
单元测试的定义 1. 什么是单元测试? 单元测试是指,对软件中的最小可测试单元在与程序其他部分相隔离的情况下进行检查和验证的工作,这里的最小可测试单元通常是指函数或者类,一般是开发来做的,按照测试 ...
随机推荐
- thinkphp Widget扩展
Widget扩展一般用于页面组件的扩展.大理石平台规格 举个例子,我们在页面中实现一个分类显示的Widget,首先我们要定义一个Widget控制器层 CateWidget,如下: namespace ...
- Java中获取前一天和后一天时间
今天在开发项目的时候遇到一个问题就是怎么获取当前时间的前一天和后一天,这个实现的逻辑并不复杂,自己要写的话的也不是难事,但是貌似感觉没必要自己写这样的方法,想想Java中的Calendar类应该有这样 ...
- NX二次开发-char*转换成CString,多字节转换成Unicode使用方法
//定义一个结构体记录 struct group { CString text; //定义一个CString std::vector<tag_t> boudaries; std::vect ...
- flutter 显示HTML代码
需求是后台返回的是富文本,所以需要吧富文本转成flutter 能识别的内容 找了几个插件只有这个比较好用写下来 dependencies: flutter_html: ^0.9.8 安装 下剩下的就比 ...
- 【Android】Retrofit网络请求参数注解,@Path、@Query、@QueryMap.
对Retrofit已经使用了一点时间了,是时候归纳一下各种网络请求的service了. 下面分为GET.POST.DELETE还有PUT的请求,说明@Path.@Query.@QueryMap.@Bo ...
- OSI七层网络模型分别是哪七层?各运行那些协议?
本文摘自:https://blog.csdn.net/JeremyZJM/article/details/78184775 应用层 DHCP · DNS · FTP · Gopher · HTTP · ...
- python初探爬虫
python爬虫初探 爬取前50名豆瓣电影: 废话少说,直接上代码! import reimport requestsfrom bs4 import BeautifulSoupdef get_co ...
- sklearn提供的自带数据集
sklearn 的数据集有好多个种 自带的小数据集(packaged dataset):sklearn.datasets.load_<name> 可在线下载的数据集(Downloaded ...
- libevent的使用 32位 64位
前段时间一个项目需要用到高并发的服务,想着自己应该可以写一个,windwos 上使用完成端口实现,写完之后,测试感觉没什么问题,可是一上线各种各样的问题,初步怀疑是底层网路库的问题,于是决定更换网络库 ...
- HTTP协议:响应消息
一.请求消息:客户端发送给服务器端的数据 数据格式: 1.请求行 2.请求头 3.请求空行 4.请求体 二.响应消息:服务器端发送给客户的数据 数据格式: 1.响应行: 1.组成:协议/版本 响应状态 ...