我想在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文件传递值,即testData.twPreIpa.twReferenceId,但是我得到了422状态代码,并且在输出以下
[2019-05-28 15:42:10.403] [INFO]:-{“标题”:“转换失败”,“状态”:422,“详细信息”:“您发送的内容可能格式错误。”}
此外,当我添加-browser.logger.info('approved');上面的var选项会在控制台上打印。.但是当我添加-browser.logger.info(testData.twPreIpa.twReferenceId);
它给我错误..输出显示-
失败:无法读取未定义的属性'twReferenceId' TypeError:无法读取未定义的属性“ twReferenceId”
答案 0 :(得分:0)
虽然这可能无法直接回答您的问题,但对您有帮助。 我在与您的外观(我假设)类似的框架上进行了一些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使用的实际值有关。在尝试发送请求之前,您应该尝试打印出您的值,以确保它们全部存在并且以您期望的格式显示。