【发布时间】:2017-03-18 15:50:47
【问题描述】:
我正在测试一个回调函数,它接受一个响应对象作为它的唯一参数。该对象是在其他地方发出的 HTTP 请求的响应,因此我不想在此测试中使用 $httpBackend,因为该请求与此函数无关。
它在 home.js 中,它是我的应用主页的控制器。
这是正在测试的函数:
function submitLogin() {
LoginService.login(loginPost, ctrl.username, ctrl.password, successCallback, errorCallback);
}
// gets called in LoginService if login reponse is 201, otherwise errorCallback called
function successCallback(response) {
// get details needed to determine correct forms for user
var sessionData = {
token: response.data.token,
user_id: response.data.user_id,
institution_name: response.data.institution_name,
status: response.data.status,
form_uri: getFormURI(response.data.forms) //extracts form URI for list of available forms for particular app
};
ctrl.formCheckInProgress = true;
// update users forms from backend and cache them
FormFetcherService.updateCachedForms(sessionData.user_id, sessionData.form_uri).then(function (response) {
if (response == 'updated') {
toastr.success('Your forms have been updated to the newest version', 'Forms Updated');
}
else {
toastr.success('Your forms are already up-to-date', 'No Update Required');
}
});
}
登录服务:
angular.module('appName').service('LoginService', ['$http', function ($http) {
this.login = function (url, username, password, successCallback, errorCallback) {
var data = {
username: username,
password: password
};
$http.post(url, $.param(data), {
headers: {
'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8'
},
timeout: 10000
}
).then(successCallback, errorCallback);
}
}]);
我想加载一个对象来代替传递给函数的“响应”对象。
有什么方法可以将 .json 文件放在我的 /tests 目录中,加载 JSON 并将其解析为 Javascript 对象,然后在我的单元测试中使用该对象?
我已经四处搜索,大多数解决方案都假设正在测试的功能中发出请求 - 这里不是这种情况。
干杯,
院长
【问题讨论】:
-
显示你的控制器的代码,你可以模拟
$http服务 -
已编辑以显示正在测试的控制器的功能。
-
显示该函数在代码中的引用位置
-
现在显示
LoginService.login:) -
完成 - 如果响应代码为 201,则从 LoginService 调用 successCallback。响应对象从 LoginService 内部传递给 successCallback。因此,要测试successCallback,只需传递从本地.json文件加载和解析的对象会更容易。
标签: javascript angularjs unit-testing jasmine karma-runner