ジャスミンとカルマテストランナーで単体テストしようとしているディレクティブでコントローラにアクセスする際に、いくつか問題があります。ディレクティブは次のようになります。AngularJsディレクティブコントローラへのアクセス
テストケースファイル:
ディレクティブ
angular.module('Common.accountSearch',['ngRoute'])
.directive('accountSearch', [function() {
return {
controllerAs: 'ctrl',
controller: function ($scope, $element, $routeParams, $http) {
this.setAccount = function() {
var response = { AccountId : $scope.ctrl.searchedAccount.AccountId }
$scope.callback(response)
}
this.getAccounts = function(searchText){
return $http.get('/api/CRMAccounts', {
params: {
retrievalLimit: 10,
search: searchText
}
}).then(function(response){
return response.data;
});
}
},
scope : {
config : '=',
values : '=',
callback : '='
},
templateUrl : '/common/components/account-search/account-search.html',
restrict : 'EAC'
}
}]);
ここでこれはこれまでのところ、私はすべてのため、正しい(私は願っています)であると信じてテストケースファイルです
describe("Account search directive logic tests", function(){
var element,$scope,scope,controller,template
beforeEach(module("Common.accountSearch"))
beforeEach(inject(function (_$compile_, _$rootScope_,_$controller_,$templateCache) {
template = $templateCache.get("components/account-search/account-search.html")
$compile = _$compile_;
$rootScope = _$rootScope_;
$controller = _$controller_;
scope = $rootScope.$new();
element = $compile(template)(scope)
ctrl = element.controller
scope.$digest();
// httpBackend = _$httpBackend_;
}));
it(" sets the account and calls back.", inject(function() {
console.log(ctrl)
expect(ctrl).toBeDefined()
}));
//httpBackend.flush()
});
私は、次のあいまいなメッセージを返すコンソールに指示文のコントローラーを印刷することができました。
LOG: function (arg1, arg2) { ... }
ディレクティブのすべての機能やプロパティにアクセスすることができません。すべてが「未定義」を返していますが、何が間違っていますか?
だろうあなたは、私はあなたがおそらくディレクティブ – Kliment
のようにアクセスすることができますscope.ctrlを試してみました、それは私がやった拳のものの1つでした。それはうまくいきませんでした。 – Maccurt
のコンテキストなしで簡単にテストすることができること、それはコントローラの簡単には、それが自分のファイルで見つけるこの 'scope.ctrl' – nagrom97