【发布时间】:2015-05-02 05:09:07
【问题描述】:
我在 Angular JS 中定义了以下控制器,它使用来自 Angular Material 的服务:
angular.module('leopDirective', [])
.controller('MenuCtrl', function ($scope, $timeout, $mdSidenav, $log)
{
$scope.mdSidenav = $mdSidenav;
$scope.close = function () {
$mdSidenav('left').close().then(function () {
$log.debug("close LEFT is done");
$scope.closed = true;
});
};
});
这取决于我试图用我自己的工厂对象模拟的服务 $mdSidenav:
describe('Controller: MenuCtrl', function() {
var $rootScope, $scope, $controller, $q, menuCtrl,
mock__mdSidenav = function(component) {
return {
isMock: true,
component: component,
close: function () {}
}
};
beforeEach(function () {
module('leopDirective', function($provide) {
$provide.value('$mdSidenav', mock__mdSidenav);
});
inject(function ($injector) {
$rootScope = $injector.get('$rootScope');
$controller = $injector.get('$controller');
$q = $injector.get('$q');
$scope = $rootScope.$new();
});
menuCtrl = $controller("MenuCtrl", { $scope: $scope });
});
it('should create the $mdSidenav object', function () {
expect($scope.mdSidenav).toBeDefined();
});
describe('managing $mdSidenav', function () {
it('should close the menu', function () {
var data, deferred = $q.defer(), promise = deferred.promise;
mock__mdSidenav.close = function() {
return promise.then(function (response) {
data = response.success;
});
$rootScope.$digest();
$scope.close();
};
});
});
我的代码在下面plnkr。
显然,它唯一不起作用的是我在测试的第二个“描述”块中将 $promise 分配给 close() 。执行此测试返回以下错误:
TypeError: Cannot read property 'then' of undefined
TypeError: Cannot read property 'then' of undefined
at Scope.$scope.close (app.js:7:35)
是什么让我认为工厂本身或 promise 函数没有正确模拟。
- 这是模拟工厂的正确方法吗?
- 这是创建返回承诺的方法的正确方法吗?
【问题讨论】:
标签: javascript angularjs unit-testing jasmine factory