51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

查看: 1858|回复: 1
打印 上一主题 下一主题

Selenium WebDriver的工作原理

[复制链接]
  • TA的每日心情
    无聊
    前天 09:06
  • 签到天数: 530 天

    连续签到: 2 天

    [LV.9]测试副司令

    跳转到指定楼层
    1#
    发表于 2018-12-12 17:44:18 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
    先通过一个简单的类比说个好理解的,这个比喻是我从美版知乎Quora上看到的,觉得比较形象、好理解拿来用用。

    我们可以把WebDriver驱动浏览器类比成出租车司机开出租车。

    在开出租车时有三个角色:

    乘客:他/她告诉出租车司机去哪里,大概怎么走
    出租车司机:他按照乘客的要求来操控出租车
    出租车:出租车按照司机的操控完成真正的行驶,把乘客送到目的地
    在WebDriver中也有类似的三个角色:

    工程师写的自动化测试代码:自动化测试代码发送请求给浏览器的驱动(比如火狐驱动、谷歌驱动)
    浏览器的驱动:它来解析这些自动化测试的代码,解析后把它们发送给浏览器
    浏览器:执行浏览器驱动发来的指令,并最终完成工程师想要的操作。
    所以在这个类比中:

    1. 工程师写的自动化测试代码就相当于是乘客

    2. 浏览器的驱动就相当于是出租车司机

    3. 浏览器就相当于是出租车



    下面再从技术上解释下WebDriver的工作原理:

    从技术上讲,也同样是上面的三个角色:

    1. WebDriver API(基于Java、Python、C#等语言)

    对于java语言来说,就是下载下来的selenium的Jar包,比如selenium-java-3.8.1.zip包,代表Selenium3.8.1的版本

    2. 浏览器的驱动(browser driver)

    每个浏览器都有自己的驱动,均以exe文件形式存在

    比如谷歌的chromedriver.exe、火狐的geckodriver.exe、IE的IEDriverServer.exe

    3. 浏览器

    浏览器当然就是我们很熟悉的常用的各种浏览器。

    那在WebDriver脚本运行的时候,它们之间是如何通信的呢?为什么同一个browser driver即可以处理java语言的脚本,也可以处理python语言的脚本呢?让我们来看一下,一条Selenium脚本执行时后端都发生了哪些事情:

    对于每一条Selenium脚本,一个http请求会被创建并且发送给浏览器的驱动
    浏览器驱动中包含了一个HTTP Server,用来接收这些http请求
    HTTP Server接收到请求后根据请求来具体操控对应的浏览器
    浏览器执行具体的测试步骤
    浏览器将步骤执行结果返回给HTTP Server
    HTTP Server又将结果返回给Selenium的脚本,如果是错误的http代码我们就会在控制台看到对应的报错信息。
    为什么使用HTTP协议呢?

    因为HTTP协议是一个浏览器和Web服务器之间通信的标准协议,而几乎每一种编程语言都提供了丰富的http libraries,这样就可以方便的处理客户端Client和服务器Server之间的请求request及响应response,WebDriver的结构中就是典型的C/S结构,WebDriver API相当于是客户端,而小小的浏览器驱动才是服务器端。

    那为什么同一个浏览器驱动即可以处理Java语言的脚本,也可以处理Python语言的脚本呢?

    这就要提到WebDriver基于的协议:JSON Wire protocol。

    JSON Wire protocol是在http协议基础上,对http请求及响应的body部分的数据的进一步规范。

    我们知道在HTTP请求及响应中常常包括以下几个部分:http请求方法、http请求及响应内容body、http响应状态码等。

    常见的http请求方法:

    GET:用来从服务器获取信息。比如获取网页的标题信息

    POST:向服务器发送操作请求。比如findElement,Click等

    http响应状态码:

    在WebDriver中为了给用户以更明确的反馈信息,提供了更细化的http响应状态码,比如:

    7: NoSuchElement

    11:ElementNotVisible

    200:Everything OK

    现在到了最关键的http请求及响应的body部分了:

    body部分主要传送具体的数据,在WebDriver中这些数据都是以JSON的形式存在并进行传送的,这就是JSON Wire protocol。

    JSON是一种数据交换的格式,是对XML的升级与替代,下面是一个JSON文件的例子:
    1. {

    2.     "firstname": "Alex",
    3.     "lastname": "Smith",
    4.     "moble": "13300000000"
    5.   }
    复制代码
    下面的例子是WebDriver中在成功找到一个元素后JSON Wire Protocol的返回:
    1. {"status" : 0, "value" : {"element" : "123422"}}
    复制代码
    所以在Client和Server之间,只要是基于JSON Wire Protocol来传递数据,就与具体的脚本语言无关了,这样同一个浏览器的驱动就即可以处理Java语言的脚本,也可以处理Python语言的脚本了。


    分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

  • TA的每日心情
    奋斗
    2019-12-31 08:59
  • 签到天数: 975 天

    连续签到: 1 天

    [LV.10]测试总司令

    2#
    发表于 2020-12-29 08:57:59 | 只看该作者
    比喻很生动,容易理解
    回复 支持 反对

    使用道具 举报

    本版积分规则

    关闭

    站长推荐上一条 /1 下一条

    小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

    GMT+8, 2024-11-23 03:47 , Processed in 0.072221 second(s), 22 queries .

    Powered by Discuz! X3.2

    © 2001-2024 Comsenz Inc.

    快速回复 返回顶部 返回列表