javascript-将本地JSON加载到AngularJS中的Jasmine / Karma单元测试中
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了javascript-将本地JSON加载到AngularJS中的Jasmine / Karma单元测试中,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2529字,纯文字阅读大概需要4分钟。
内容图文
我正在测试一个回调函数,该函数接受一个响应对象作为唯一参数.该对象是在其他地方发出的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对象,然后在单元测试中使用该对象?
我四处搜索,大多数解决方案都假定正在测试的函数中正在发出请求-此处并非如此.
干杯,
院长
解决方法:
您可以这样做:
var LoginService, $controller;
var formFetcherService = {
updateCachedForms: jasmine.createSpy('sessionData');
}
var response = {
data: {
user_id: 4,
forms: 'some'
}
}
beforeEach(module(function($provide) {
$provide.value('LoginService', {
login: function(url, username, password, successCallback, errorCallback) {
successCallback(response);
}
});
$provide.value('FormFetcherService', formFetcherService);
}))
beforeEach(inject(function(_$controller_) {
$controller = _$controller_;
});
it('should create sessionData', function() {
var controller = $controller('HomeController');
controller.submitLogin();
expect(formFetcherService.updateCachedForms).toHaveBeenCalledWith(response.user_id, response.form_uri);
});
内容总结
以上是互联网集市为您收集整理的javascript-将本地JSON加载到AngularJS中的Jasmine / Karma单元测试中全部内容,希望文章能够帮你解决javascript-将本地JSON加载到AngularJS中的Jasmine / Karma单元测试中所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。