javascript - jasmine http接口测试始终提示“SESSION_INVALID”

查看:138
本文介绍了javascript - jasmine http接口测试始终提示“SESSION_INVALID”的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

问 题

1.背景
背景:测试使用jasmine测试框架,每个测试案例编写成js文件来集成调用测试接口。


2.遇到的问题
需要测试某个 卖家获取用户信息的http接口,测试的前置条件是卖家需要有登录状态,卖家id从cookie中取。
当通过登录接口模拟登录成功后,访问获取用户信息的http接口时,始终提示 Response=[{"message":"Session失效","returnCode":"SESSION_INVALID","success":false}]

测试部分代码如下:

describe("得到买家的用户信息",function (){
    var restful = new RestfulUtils();
    restful.setRequestDataType("json");
    var cookies;

    beforeEach(function () {
        restful.setFormData(true);
        restful.setRequestDataType("x-www-form-urlencoded");
        restful.setHttpMethod("POST");
        restful.setServerURL("http://portal.XXX.com/api/login/login");
        restful.setRequestDataFile(PWD+"\/json/cookies.json");
        expect(restful.execute()).toEqual(true);
        cookies = restful.getResponseCookies();

        print ("cookies =" + cookies);

    });

    afterEach(function () {

    });
         
    it("case 1: 正常",function (){
        print ('****** case 1 ******');
        restful.setHttpMethod("GET");
        restful.setServerURL("http://imkf.XXX.com/ajax/baseInfo/1?userId=offline0066");
        restful.setRequestCookies(cookies);


        expect(restful.execute()).toEqual(true);
        cookies1 = restful.getResponseCookies();

3.尝试的方法
a.尝试将登录操作后的cookie和请求测试接口后的cookie进行比对,结果一致,没有丢失;
b.在线上环境进行了同样的请求,能正常返回接口数据;


4.可能的定位点
线上进行登录请求和获取用户信息请求后,两步请求中uuid(用户唯一标识符)是一致的,但在测试环境这两步请求中的uuid(用户唯一标识符)是始终是不一致,不知道是否是这个原因造成的,求教?!

解决方案

上周三已解决。


原因
restful是全局变量,在beforeEach的函数中被设置变量值后(setFormData、setRequestDataType),在it中再次被使用时,需要根据请求的实际情况重新设置变量值。

解决方案
问题中的例子,在setHttpMethod前新增restful.setFormData(false);即可。

这篇关于javascript - jasmine http接口测试始终提示“SESSION_INVALID”的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆