AngularJS - Как макет контроллера для шаблона? - PullRequest
0 голосов
/ 11 сентября 2018

У меня есть шаблон с поведением, которое я хочу протестировать, но он вызывает контроллер с кодом, которого я хотел бы избежать, и я бы предпочел внедрить его в макет. Как мне это сделать?

Я использую Angular 1.7, Карму и Жасмин.

Шаблон:

<div ng-controller="MyController">
    <span ng-if="(a && b) || (b && !c) || (!a && d)">
        {{ (b || a) + (d || c) }}
    </span>
</div>

Контроллер:

app.controller('MyController', function($scope, MyService) {
    $scope.a = (MyService.a || -MyService.d)
    $scope.b = (MyService.b + MyService.c) || MyService.a
    $scope.c = -MyService.c || (MyService.a + MyService.d)
    $scope.d = -(MyService.a + MyService.d) - MyService.b
    someOtherCode.IdontWantTo.exec()
})
describe('MyTemplate', () => {
    let compile, $rootScope

    beforeEach(inject(function($compile, $templateCache, _$rootScope_) {
        compile = $compile($templateCache.get('MyTemplate.html'))
        $rootScope = _$rootScope_
    }))

    it('should behave a certain way', () => {
        const $scope = $rootScope.new()
        const element = compile($scope)
        $scope.a = 0
        $scope.d = 3
        $scope.$digest
        expect(element.text()).toEqual('3')
    })

})

1 Ответ

0 голосов
/ 11 сентября 2018

Я обнаружил, что могу использовать $controllerProvider.register для переопределения контроллера.

beforeEach(module('App', function($controllerProvider) {
    $controllerProvider.register('MyController', function($scope) {
        $scope.mocked = true
    })
}))
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...