前提:robotframework 与抓包工具已安装
在平时接口测试过程会存在一些重定向的接口(状态码为302),比如某些登录的接口需要一次甚至多次的重定向才能实现最终的登录,这样的情况下,我们就需要对这多次重定向的请求进行分析,分析这些请求的联系,以便在调试的时候摸清规律。针对登录接口的情况,主要关注下前后几个接口的联系,主要关注以下内容:Response Headers,Request Headers 、以及接口的返回内容,关注前面接口的Response header 和返回内容是否与下面接口的 Request Headers存在联系。
对于登录接口而言,一般情况下以上三者多少会存在点联系,这我们就需要借助抓包工具进行观察,个人偏好fiddler,可以比较清楚的看见重定向接口之间联系。
在调试过程中主要用到的库RequestsLibrary,YamlLibrary、Collections以及String等Python的第三库。
对于需要多个重定向接口才能实现的登录状态,主要的难点在于如何在调试过程抓到重定向接口的Response Headers。对于fiddler等的抓包而言,只要在登录界面进行一次登录就可以看到完整的接口重定向过程以及各个接口的Response Headers。但是在RF中,在注意的情况下直接调用登录接口是不可能实现的。在调状态码为302的接口时,RF执行的结果也是重定向至下一个接口,即返回码为200。
针对上述的情况,RequestsLibrary库提供了Get Request 关键字可以对重定向接口进行操作以及取Response Headers。在使用Get Request 关键字时,最需要注意的是重定向的参数,需要将参数设置为false,调用结果的状态码为302,即在调试的时候不会发生跳转。
默认情况下allow_redirects为none,在重定向去情况下传入的参数须为false。
具体使用如下所示:
在传入${false}时,可以使用evaluate 关键字对${false}进行初始化
在传入${false}时,有可以不用进行初始化,直接传allow_redirects=${false}。
在调302接口之后,需关注下接口Response Headers的Location部分,一般Location的URL都是重定向的地址,可以用${addr.headers['location']}进行跳转地址的提取,这部分的URL一般都会包含跳转的地址和参数,取出URL即可再用RF针对此URL进行请求,若是多个302的重定向接口之后才会实现登录,只需按照上面所述的多次进行即可。
总结:利用RF调用重定向接口,主要技巧是在于如何对重定向进行拦截,若是对allow_redirects参数不进行设置进行直接调用接口,则会直接跳转至重定向之后的接口,则很难抓到接口之间所需要的联系。其次,对于多个接口实现登录的,则需在调用之前了解接口之前的联系,一般情况下上一接口的Response Headers 以及返回内容和下一接口的Request Headers、请求参数或者请求地址存在某种联系,具体的阐述不在此再进行展开说明,根据实际情况而定。