Я тестирую модуль, который вызывает метод $ rootScope с другого контроллера. Есть ли способ добавить эту функцию в $ rootScope контроллера, который я пытаюсь проверить? Я использую тестовую среду, включающую Jasmine, Karma, PhantomJS и т.д.
Поскольку $ rootScope является общим для всех ваших контроллеров, вы можете определить свою функцию непосредственно в объекте $ rootScope, подумайте о том, чтобы определить определение функции в обработчике app.run, в противном случае вы должны убедиться, что ваш контроллер загружен для функции, которая будет определена, приведенный ниже пример показывает оба метода:
<div ng-app="myApp">
<div ng-controller="Ctrl1">
<h1>Controller 1</h1>
<button ng-click="myFunc()">Test $rootScope.myFunc()</button>
<button ng-click="toBeDefniendinCtrl1()">Test $rootScope.toBeDefniendinCtrl1()</button>
</div>
<div ng-controller="Ctrl2">
<h1>Controller 2</h1>
<button ng-click="myFunc()">Test $rootScope.myFunc()</button>
<button ng-click="toBeDefniendinCtrl1()">Test $rootScope.toBeDefniendinCtrl1()</button>
</div>
</div>
<script>
var app = angular.module('myApp', []);
app.run(function($rootScope){
$rootScope.myFunc = function (){ alert("hi"); }
$rootScope.toBeDefniendinCtrl1 = null;
})
app.controller('Ctrl1', function($scope, $rootScope) {
$rootScope.toBeDefniendinCtrl1 = function (){ alert("hello from Ctrl1"); }
});
app.controller('Ctrl2', function($scope, $rootScope) {
});
</script>
см. рабочий пример: http://jsbin.com/xiyozitage/edit?html,output
Если вы хотите вручную добавить этот метод в тест, вы можете использовать Jasmine beforeEach() для настройки методов mocks/implement до запуска ваших тестов, поэтому с помощью функции inject()
вы можете перейти в $rootScope
и установить свой метод
$rootScope
является анти-паттерном. Вам следует рассмотреть возможность создания службы для совместно используемой функции.