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

举报
梦想橡皮擦 发表于 2021/08/19 22:03:59 2021/08/19
【摘要】 今天是持续写作的第 29 / 100 天。如果你有想要交流的想法、技术,欢迎在评论区留言。学习编程就是为了解决问题,接下来本系列的文章都将以项目的形式展现,为你打开项目之门。 做测试项目之前的准备工作项目需求分析制定项目计划制定测试用例开始测试上述的前 3 个步骤,咱们一概不讲,直接从第 4 步开始走起。 自动化测试之途牛搜机票本次案例对应的网站为:https://flight.tuniu....

今天是持续写作的第 29 / 100 天。
如果你有想要交流的想法、技术,欢迎在评论区留言。

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

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

  1. 项目需求分析
  2. 制定项目计划
  3. 制定测试用例
  4. 开始测试

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

自动化测试之途牛搜机票

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

逐个元素获取

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

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

from selenium import webdriver
import time
driver = 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 webdriver
import time
from selenium.webdriver.common.action_chains import ActionChains
driver = 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:梦想橡皮擦,希望大家点赞评论收藏

【版权声明】本文为华为云社区用户原创内容,未经允许不得转载,如需转载请自行联系原作者进行授权。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。