写点什么

用 Selenium 搞定自动化测试项目,途牛搜机票。

发布于: 2021 年 02 月 26 日
用 Selenium 搞定自动化测试项目,途牛搜机票。

今天是持续写作的第 <font color="red">29</font> / 100 天。

如果你有想要交流的想法、技术,欢迎在评论区留言。


学习编程就是为了解决问题,接下来本系列的文章都将以项目的形式展现,为你打开项目之门。


做测试项目之前的准备工作


  1. 项目需求分析

  2. 制定项目计划

  3. 制定测试用例

  4. 开始测试


上述的前 3 个步骤,咱们一概不讲,直接从第 4 步开始走起。


自动化测试之途牛搜机票


本次案例对应的网站为:https://flight.tuniu.com/ 需要完成下述图片内容的自动写入,然后在点击搜索操作。看似一个非常小的案例,学过之后你会发现 Selenium 在自动化操作中其实一直在重复一个动作,就是查找元素。



逐个元素获取


在 Selenium 中获取网页各元素是最重要的操作,只要能获取到,就能对其下手。


优先设置出发地和到达地。


from selenium import webdriverimport timedriver = webdriver.Firefox()driver.maximize_window()
driver.get('https://flight.tuniu.com/')
# 定义好出发和到达的城市from_city = "石家庄"to_city = "三亚"
driver.find_element_by_id("J_FormDepartCity").send_keys(from_city)driver.find_element_by_id("J_FormDestCity").send_keys(to_city)
复制代码


接下来设置时间,发现一些小问题,直接使用下述代码,无法设置。


from_date = "2021-01-01"
driver.find_element_by_id("J_FormDepartCity").send_keys(from_city)driver.find_element_by_id("J_FormDestCity").send_keys(to_city)# 设置时间driver.find_element_by_id("J_FormDepartDate").send_keys(from_date)
复制代码


问题出在,时间控件的网页参数为 readonly,就是只读的,所以设置不了。

执行一段 JS 脚本,删除掉只读操作。


# 删除时间控件的只读属性driver.execute_script("document.getElementById('J_FormDepartDate').removeAttribute('readonly')")# 设置时间driver.find_element_by_id("J_FormDepartDate").clear()driver.find_element_by_id("J_FormDepartDate").send_keys(from_date)
复制代码


代码再次运行,又一次发现问题,实际编程中我们也是不断的在发现问题解决问题的路上。直接通过 Selenium 输入的程序,系统无法自动检索,需要实现对城市的查找,点选操作。如下图所示。

对于元素的点选,多次尝试之后(此处反复的寻找获取标签的方法即可),最终得到下述代码。


# 定义好出发和到达的城市from_city = "SJZ"to_city = "SY"from_date = "2021-01-01"
driver.find_element_by_id("J_FormDepartCity").send_keys(from_city)time.sleep(2)driver.find_element_by_xpath("//div[@class='autocomplete-suggestions'][1]/div[1]").click()
driver.find_element_by_id("J_FormDestCity").send_keys(to_city)time.sleep(2)driver.find_element_by_xpath("//div[@class='autocomplete-suggestions'][2]/div[2]").click()
复制代码


截止到现在,所有的元素已经获取完毕,实现最后一步点击操作,即可实现查询。本阶段完整代码如下。


from selenium import webdriverimport timefrom selenium.webdriver.common.action_chains import ActionChainsdriver = webdriver.Firefox()driver.maximize_window()
driver.get('https://flight.tuniu.com/')
# 定义好出发和到达的城市from_city = "SJZ"to_city = "SY"from_date = "2021-01-01"
driver.find_element_by_id("J_FormDepartCity").send_keys(from_city)time.sleep(2)driver.find_element_by_xpath("//div[@class='autocomplete-suggestions'][1]/div[1]").click()
driver.find_element_by_id("J_FormDestCity").send_keys(to_city)time.sleep(2)driver.find_element_by_xpath("//div[@class='autocomplete-suggestions'][2]/div[2]").click()
# 删除时间控件的只读属性driver.execute_script("document.getElementById('J_FormDepartDate').removeAttribute('readonly')")# 设置时间driver.find_element_by_id("J_FormDepartDate").clear()driver.find_element_by_id("J_FormDepartDate").send_keys(from_date)
# 点击一下其他位置,清除浮窗ActionChains(driver).move_by_offset(0,10).click().perform()
# 点击搜索按钮time.sleep(1)driver.find_element_by_id("J_Search").click()
复制代码


最终得到的效果如下。


后续内容


以上代码其实已经演示了一个自动化测试项目的主要流程,因为途牛网站并不是咱们自己开发的,所以多次访问之后会被限制访问,绕过限制属于爬虫类的知识了,本项目只展示自动化相关内容,其它部分不再扩展。


后续在跳转页面,获取元素与上文相关代码一致,都是采用相同的办法,而且没有固定解,使用 Selenium 特别像是一个开卷编程,所有人实现同一功能所用的代码可能不一致。


本案例采用的是一个线性代码项目,即从上到下依次执行,后续几篇博客将对本项目进行修改,编程上专业术语叫做重构。


写在后面


学习是为了使用和解决问题,所以你有想要完成的任务吗?学习到这里,可以看看是否可以用 Selenium 解决呢?




博主 ID:梦想橡皮擦,希望大家<font color="red">点赞</font>、<font color="red">评论</font>、<font color="red">收藏</font>。


发布于: 2021 年 02 月 26 日阅读数: 15
用户头像

爬虫 100 例作者,蓝桥签约作者,博客专家 2021.02.06 加入

6 年产品经理+教学经验,3 年互联网项目管理经验; 互联网资深爱好者; 沉迷各种技术无法自拔,导致年龄被困在 25 岁; CSDN 爬虫 100 例作者。 个人公众号“梦想橡皮擦”。

评论

发布
暂无评论
用 Selenium 搞定自动化测试项目,途牛搜机票。