我想在 API 请求正文中传递值。我为此尝试了以下代码
var options = { method: 'POST',
url: 'https://ssgpreprod.serviceurl.in/gonogo-api/atm/tw/cro-approval',
headers:
{ 'Postman-Token': '9d6a0ad1-c3a1-402f-b845-b6416f49df6b',
'cache-control': 'no-cache',
'Content-Type': 'application/json' },
body:
{ oHeader:
{ sReqType: 'application/json',
sAppSource: 'WEB 2.02.01',
sSourceID: 'GONOGO_HDBFS',
sAppID: 610961419000670,
dtSubmit: '',
sCroId: 'HDB_TW_CRO@cell.com',
sDsaId: 'default',
sInstID: 4019,
sUserName: 'CHDBTWCRO',
sProduct: 'TW',
sDealerId: '61096' },
sRefID:testData.twPreIpa.twReferenceId,
sAppStat: testData.twCroDetails.twCroDecision,
aCroJustification: [ { sRemark: testData.twCroDetails.twRemark, sSubTo: testData.twCroDetails.twSubjectTo} ],
bApprAmtExist: true,
dApprAmt: testData.twApplyDetails.twLoanAmount,
dItrRt: testData.twCroDetails.twRoi,
dLtv: testData.twCroDetails.twLtv,
aDedupeRefID: [] },
json: true };
request(options, function (error, response, body) {
if (error) throw new Error(error);
browser.logger.info(JSON.stringify(body));
browser.logger.info(JSON.stringify(response));
browser.logger.info('status code is : ' + response.statusCode);
expect(response.statusCode).toBe(200).then(function () {
browser.logger.info('case is approved');
this.logOut(testData);
})
});
我正在从 xlsx 文件传递值,即测试数据.twPreIpa.twReferenceId,但我收到 422 状态代码及以下输出
[2019-05-28 15:42:10.403] [信息] : - {"title":"转换失败","状态":422,"详细信息":"您发送的内容可能格式不正确。
另外,当我添加 - browser.logger.info("已批准"(时; 在var选项上方,它会在控制台上打印。 但是当我添加 - browser.logger.info(testData.twPreIpa.twReferenceId(;
它给了我错误..输出显示 -
失败:无法读取未定义的属性"twReferenceId"类型错误: 无法读取未定义的属性"twReferenceId">
虽然这可能不会直接回答您的问题,但它应该对您有所帮助。我开发了一个与(我假设(你的框架类似的框架,一些 api 和一些 UI 验证。
我有一个单独的类用于我的 API 调用,它返回了一些值,有时是整个响应正文。我允许自己能够传入我需要的任何主体作为参数。
这是我采取的方法的一个例子。
module.exports = class Endpoints {
addSomethingToUser(bearerToken, userId, JSONbody) {
//Function will preform a POST request and return the status code if successful
//Else if will return the body of the response
let endpoint = 'http://myApp.com:9090/api/users/' + userId;
return new Promise((resolve, reject) => {
let options = {
method: "POST",
headers: {
'Content-Type': 'application/json',
'Authorization': 'Bearer ' + token,
},
body: JSON.stringify(JSONbody),
};
request(
endpoint,
options ,
function (error, response, body) {
if (!error && (response.statusCode >= 200 && response.statusCode < 300)) {
resolve(response.statusCode);
} else {
console.log('error:', error, response && response.statusCode);
reject(JSON.stringify(response, undefined, 2));
};
}
);
});
};
}
它被称为像
let apiCallsFile = require('../apiCalls/restCalls');
let apiCalls = new apiCallsFile();
it('simple test', async function(){
let requiredBody = {
"NAME": "Test Name",
"GENDER": "MALE",
};
let apiResult = await apiCalls.addSomethingToUser(bearerToken, userId, requiredBody );
expect(apiResult).toBe('201');
}
您的问题似乎与您从 excel 使用的实际值有关。在尝试发送请求之前,应尝试打印出值,以确保它们都存在且格式符合预期。