美文网首页软件测试
轻松自动化---selenium-webdriver(pytho

轻松自动化---selenium-webdriver(pytho

作者: A丶咔咔 | 来源:发表于2020-06-24 16:53 被阅读0次

    为什么选python?

    目前所测的产品部分基本上都是python写的,而且很多团队也都在推广python ,其实就测试人员来说,python是相当受欢迎的。易学,易用。翻翻各测试招聘,python出现的概率也颇高。

    第一个脚本:

    下面看看python 穿上selenium webdriver 是多么的性感:

    # coding = utf-8

    from selenium import webdriver

    browser = webdriver.Firefox()

    browser.get("http://www.baidu.com")

    browser.find_element_by_id("kw").send_keys("selenium")

    browser.find_element_by_id("su").click()

    browser.quit()

    怎么样?相信不懂代码的人都能看懂,但还是请容我在这里啰嗦一下每一句的含义:

    # coding = utf-8

    可加可不加,开发人员喜欢加一下,防止乱码嘛。

    from selenium import webdriver

    要想使用selenium的webdriver 里的函数,首先把包导进来嘛

    browser = webdriver.Firefox() 

    我们需要操控哪个浏览器呢?Firefox ,当然也可以换成Ie 或 Chrome 。browser可以随便取,但后面要用它操纵各种函数执行。

    browser.find_element_by_id("kw").send_keys("selenium")

    一个控件有若干属性id 、name、(也可以用其它方式定位),百度输入框的id 叫kw ,我要在输入框里输入 selenium 。多自然语言呀!

    browser.find_element_by_id("su").click()

    搜索的按钮的id 叫su ,我需要点一下按钮( click() )。

    browser.quit()

    退出并关闭窗口的每一个相关的驱动程序,它还有个类似的表弟。

    browser.close()

    关闭当前窗口 ,用哪个看你的需求了。

    添加休眠

    什么?你说刚才太快没看清浏览器的操作过程。请time出马,让他跑慢点。

    # coding = utf-8

    from selenium import webdriver

    import  time  #调入time函数

    browser = webdriver.Firefox()

    browser.get("http://www.baidu.com")

    time.sleep(0.3)  #休眠0.3秒

    browser.find_element_by_id("kw").send_keys("selenium")

    browser.find_element_by_id("su").click()

    time.sleep(3)  # 休眠3秒

    browser.quit()

    time.sleep() 函数随意插,哪里太快插哪里,再也不用担心看不清脚本的运行过程了。

    其实,这个函数的真正用途不是给我们看脚本的运行过程的,有时候网络原因,或页面加载慢。假设搜索框输入框输入了selenium ,搜索按钮还没加载出来,那么脚本就报错。在适当的位置加入time.sleep()有助于减少网络原因造成的脚本执行失败;

    输出

    什么?在运行脚本的时候,上了个厕所,你都不知道刚才的脚本是否运行成功了。把刚才访问页面的title 打印出来。

    # coding = utf-8

    from selenium import webdriver

    driver = webdriver.Chrome()

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

    print driver.title  # 把页面title 打印出来

    driver.quit()

    虽然我没看到脚本的执行过程,但我在执行结果里看到了

    >>>

    百度一下,你就知道

    说明页面正确被我打开了。

    打印URL

    前到,可以将浏览器的title打印出来,这里再讲个简单的,把当前URL打印出来。其实也没啥大用,可以做个凑数的用例。

    #coding=utf-8

    from selenium import webdriver

    import time

    browser = webdriver.Firefox()

    url= 'http://www.baidu.com'

    #通过get方法获取当前URL打印

    print "now access %s" %(url)

    browser.get(url)

    time.sleep(2)

    browser.find_element_by_id("kw").send_keys("selenium")

    browser.find_element_by_id("su").click()

    time.sleep(3)

    browser.quit()

    其实,我们可以把这用户登录成功后的URL打印,用于验证用户登录成功。

    又或者,我们打印其它信息,比如,一般的登录成功页会出现“欢迎+用户名”,可以将这个信息打印表明用户登录成功。(如何实现,你自己琢磨一下吧~!)

    将浏览器最大化

    我们知道调用启动的浏览器不是全屏的,这样不会影响脚本的执行,但是有时候会影响我们“观看”脚本的执行

    #coding=utf-8

    from selenium import webdriver

    import time

    browser = webdriver.Firefox()

    browser.get("http://www.baidu.com")

    time.sleep(2)

    print "浏览器最大化"

    browser.maximize_window()  #将浏览器最大化显示

    time.sleep(2)

    browser.find_element_by_id("kw").send_keys("selenium")

    browser.find_element_by_id("su").click()

    time.sleep(3)

    browser.quit()

    设置浏览器固定宽、高

    最大化还是不够灵活,能不能随意的设置浏览的宽、高显示?当然是可以的。

    #coding=utf-8

    from selenium import webdriver

    import time

    browser = webdriver.Firefox()

    browser.get("http://m.mail.10086.cn")

    time.sleep(2)

    print "设置浏览器宽480、高800显示"

    browser.set_window_size(480, 800)  #参数数字为像素点

    time.sleep(3)

    browser.quit()

    这个需求也还是有的,比如我们通过PC浏览器在访问一下手机网站时,调整浏览器为手机屏幕的宽、高,容易发现一些显示问题。(上面的手机邮箱网站就是笔者测试过的一个产品)

    操控浏览器前进、后退

    浏览器上有一个后退、前进按钮,对于浏览网页的人是比较方便的;对于做web自动化测试的同学来说应该算是一个比较难模拟的问题;其实很简单,下面看看python的实现方式

    #coding=utf-8

    from selenium import webdriver

    import time

    browser = webdriver.Firefox()

    #访问百度首页

    first_url= 'http://www.baidu.com'

    print "now access %s" %(first_url)

    browser.get(first_url)

    time.sleep(2)

    #访问新闻页面

    second_url='http://news.baidu.com'

    print "now access %s" %(second_url)

    browser.get(second_url)

    time.sleep(2)

    #返回(后退)到百度首页

    print "back to  %s "%(first_url)

    browser.back()

    time.sleep(1)

    #前进到新闻页

    print "forward to  %s"%(second_url)

    browser.forward()

    time.sleep(2)

    browser.quit()

    为了使过程让你看得更清晰,在每一步操作上都加了print 和sleep 。

    说实话,这两个功能平时不太常用,所能想到的场景就是几个页面来回跳转,但又不想用get url的情况下。

    笔者这边创建了一个软件测试交流群1125760266,欢迎大家加入共同学习探讨!

    相关文章

      网友评论

        本文标题:轻松自动化---selenium-webdriver(pytho

        本文链接:https://www.haomeiwen.com/subject/xazrfktx.html