4

我有以下组件:

angular.module('foo')
    .component('searchInput', {
        bindings: {
            text: "<query"
        },
        templateUrl: 'components/searchInput/searchInput.html',
        controller: 'SearchInputCtrl'
    });

为了通过以下内容:

expect(component.text).toBe('bar');

我必须使用以下代码:

    var component = $componentController('searchInput',
        {$scope: {}},
        {
            text: 'bar'
        }
    );

但是,我想测试绑定到“文本”的值是否来自“查询”。这不起作用

    var component = $componentController('searchInput',
        {$scope: {}},
        {
            query: 'bar'
        }
    );
4

1 回答 1

7

您可以通过编译组件来测试这种事情。例如

inject(function($compile, $rootScope) {
    var parentScope = $rootScope.$new();
    parentScope.myVar = 'test';

    var element = angular.element('<search-input query="myVar"></search-input>');

    var compiledElement = $compile(element)(parentScope);
    parentScope.$digest();

    var scope = compiledElement.isolateScope();

    expect(scope.$ctrl.text).toBe('test');
});
于 2016-04-05T16:51:44.097 回答