4
私のコードは次のとおりです。カルマと嘲笑された約束をどのように試すことができますか?
$scope.openModal = openModal;
function openModal(data){
var info = data || {}
ModalService.showModal({
templateUrl: ENVApp+"/myview.html",
controller: "ModalController",
inputs: {
icon : "",
title: "Additional",
data : info
}
}).then(function (modal) {
modal.element.modal();
modal.close.then(function (res) {
if(res.data != 'cancel'){
if(!res.data.id){
create(res)
}else{
update(res)
}
}
});
});
}
カルマでこれをテストするための適切な方法は何ですか?私の実際のテストでは
this.ModalService = {
showModal: function(obj) {
var deferred = $q.defer();
deferred.resolve({
element: {
modal: jasmine.createSpy(),
close: function() {
var deferred2 = $q.defer();
return deferred2.promise;
}
}
});
return deferred.promise;
}
};
this.UserService = {
user: {
id: 2
},
updateCategory: function(data, type) {
var deferred = $q.defer();
deferred.resolve({
data: {
rows: 'response'
}
});
return deferred.promise;
}
}
this.controller = $controller('ProfileAdditionalController', {
'$scope': this.scope,
'$rootScope': this.rootScope,
'$state': this.state,
"$stateParams": this.stateParams,
'ModalService': this.ModalService,
'UserService': this.UserService,
'ResourceService': this.ResourceService,
'$upload': this.upload,
'userData': this.userData
});
:私のbeforeEach
で
:ここでは、私がこれまで持っているものだ
it('should open a modal when requested', function() {
this.scope.openModal();
expect(this.ModalService.showModal)
});
しかし、それは意味の全体の多くを作成しません。思考?
'openModal'は' showModal'から使用している約束を返せますか?私は最近あなたのコードがやっていることに似た何かをするGUIウィジェットをテストしていました。メソッドAはメソッドBを呼び出していました。そして、BはAが使っていた約束を返しました。私はAがB(+ハンドラー)から得た約束を返すように決めました。テストを単純化しました。 – Louis