1

我正在用 Jasmine 测试一些 Angular.js 代码。为此,我需要一个 Angular 注入器:

var injector = angular.injector(['ng', 'ngRoute', 'mainModule']);

这很好用,但是当我开始测试使用 $location 的控制器时,我必须将其添加到注入器中:

var injector = angular.injector(['ng', 'ngRoute', 'location', 'mainModule']);

现在这会引发错误:

Error: Error: [$injector:modulerr] Failed to instantiate module location due to:
Error: [$injector:nomod] Module 'location' is not available! You either misspelled the module name or forgot to load it. If registering a module ensure that you specify the dependencies as the second argument.

我如何在其中包含 $location 服务?谢谢。

- - - - - - - 编辑 - - - - - - - - -

由于答案不多,我想我会添加一些细节。

这是我正在尝试测试的控制器(或它的定义,我不会粘贴所有代码):

var app = angular.module('mainModule');

app.controller('appController', ['$window', '$scope', '$location', '$wsService', '$userService', '$labelService', function ($window, $scope, $location, $wsService, $userService, $labelService) {
    //body of the controller
}]);

您已经在原始帖子的单元测试中看到了我是如何创建注入器的,以下是我如何使用注入器创建控制器:

var scope;
var controller;
var getController = function() {
    injector.invoke( ['$rootScope', '$controller', function ($rootScope, $controller) {
        scope      = $rootScope.$new();
        controller = $controller('appController', {$scope: scope});
    }]);
};

希望这将有助于产生一些潜在的答案。谢谢

4

1 回答 1

2

回答我自己的问题。以下是如何测试以下控制器:

var app = angular.module('mainModule');

app.controller('appController', ['$window', '$scope', '$location', '$userService', function ($window, $scope, $location, $userService) {
    //body of the controller
}]);

1在单元测试中创建注入器:

var injector = angular.injector(['ng', 'ngRoute', 'mainModule']);

2需要调用服务:

injector.invoke( ['$userService',  function ($userService) {
    service     = $userService;
}]);

3模拟定位服务:

var mockLocation = {
    path : ""
};

我只需要path我正在测试的控制器,因此我没有模拟其他任何东西,而是模拟你需要的任何其他东西。

4调用控制器:

var scope;
var controller;
var getController = function() {
    injector.invoke( ['$rootScope', '$controller', function ($rootScope, $controller) {
        scope      = $rootScope.$new();
        controller = $controller('appController', {$scope: scope, $location: mockLocation});
    }]);
};

现在控制器可以用于单元测试。
这确实消除了与位置服务相关的“未知提供商”和其他错误。
这篇博文帮我解答了,感谢作者。

于 2014-04-30T10:37:41.197 回答