zoukankan      html  css  js  c++  java
  • Python+Selenium基础篇之5-第一个完整的自动化测试脚本

    分类专栏: Python+Selenium自动化测试从零到框架设计系列

    作者 | Anthony_tester,300w+访问量博主,Oracle测试开发工程师。

    地址 | https://blog.csdn.net/u011541946/article/details/68484368

    声明 | 本文是 Anthony 原创,已获授权发布,未经原作者允许请勿转载

          前面文章,我们介绍了如何采用XPath表达式去定位网页元素,在掌握了如何抓取或者如何书写精确的XPath表达式后,我们可以开始写自己的第一个真正意义上的webui 自动化测试脚本,就相当于,你在学习Python,如何在控制台打印Hello,Python!一样。

          我们的测试用例是:打开百度首页,搜索Selenium,然后检查搜索列表,有没有Selenium这个官网链接选项。

          在写自动化脚本之前,需要明确手动脚本的步骤,然后去拆分到具体没一个步骤做什么,考虑好了之后,才开始动手去写脚本。我把这个测试场景分拆如下步骤:

    1) 启动后浏览器,这里我们用Chrome

    2) 打开百度首页,https://www.baidu.com

    3) 定位搜索输入框,记录下输入框元素的xpath表达式://*[@id='kw']

    4) 定位搜索提交按钮(百度一下这个按钮),获取xpath表达式://*[@id='su']

    5) 在搜索输入框输入“Selenium”,点击百度一下这个按钮。

    6) 在搜索结果列表去判断是否存在Selenium官网这个链接。

    7) 退出浏览器,结束测试。

    如果,还不会通过火狐浏览器上插件firepath获取元素的表达式,请看上一篇文章。如果你没有安装Chrome,那就用Firefox。

    1) 桌面新建一个记事本,命名并保存为FirstScript.py

    2) 输入如下代码片段到FirstScript.py,保存

    3) 打开cmd窗口,切换到桌面路径下,然后通过python FirstScript.py 来执行脚本。

    FirstScript.py脚本如下

    # coding=utf-8import timefrom selenium import webdriverdriver = webdriver.Chrome() # 打开chrome,如果没有安装chrome,换成webdriver.Firefox()driver.maximize_window()    # 最大化浏览器窗口driver.implicitly_wait(8)   # 设置隐式时间等待driver.get("https://www.baidu.com")  # 地址栏输入百度地址driver.find_element_by_xpath("//*[@id='kw']").send_keys("selenium")  # 搜索输入框输入Seleniumdriver.find_element_by_xpath("//*[@id='su']").click()  #点击百度一下按钮# 导入time模块,等待2秒time.sleep(2)# 这里通过元素XPath表达式来确定该元素显示在结果列表,从而判断Selenium官网这个链接显示在结果列表。# 这里采用了相对元素定位方法/../# 通过selenium方法is_displayed() 来判断我们的目标元素是否在页面显示。driver.find_element_by_xpath("//div/h3/a[text()='官网']/../a/em[text()='Selenium']").is_displayed()driver.quit()

    第二种断言写法:

    # coding=utf-8import timefrom selenium import webdriverdriver = webdriver.Chrome()driver.maximize_window()driver.implicitly_wait(8)driver.get("https://www.baidu.com")driver.find_element_by_xpath("//*[@id='kw']").send_keys("selenium")driver.find_element_by_xpath("//*[@id='su']").click()time.sleep(2)# 第二个判断方法ele_string = driver.find_element_by_xpath("//div/h3/a[text()='官网']/../a").textif (ele_string == u"Selenium - Web Browser Automation"):print "测试成功,结果和预期结果匹配!"driver.quit()

          这里只利用 两个等号(==)来判断两个字符串是否完全相同,有时候我们还需要对得到的字符串进行切割操作,才能进行去匹配,以后再介绍字符串切割处理在自动化测试结果判断中的使用。自动化测试最难的在于如何去写断言,如何判断测试结果是否通过。

    - To Be Continued -


    欢迎关注公众号:测试开发社区
    640?wx_fmt=jpeg
    微信扫描二维码,关注我的公众号

  • 相关阅读:
    Eclipse中插件的运用
    AES加密解密 Java中运用
    DES加密解密 Java中运用
    Chrome中的插件运用
    JqueryEasyUI教程入门篇
    SEO入门教程
    屏幕取色工具
    gif处理
    java 实现序列化的两种方式
    重定向输出 > 1>&2 2>&1
  • 原文地址:https://www.cnblogs.com/finer/p/11894991.html
Copyright © 2011-2022 走看看