使用Angular v1.2.25和rails资产管道,我试图测试指令的隔离范围确实已经更新.由于isolateScope()返回undefined我得到预期未定义的定义…’
原文链接:https://www.f2er.com/angularjs/141540.htmldescribe("cool directive",function() { beforeEach(module('necessaryModule')); var scope,$rootScope,$compile,elem,baseElement = '<div auto="mock_a" inc="mock_p" method="mock_m" reset-method="mock_r"></div>'; beforeEach(inject(function( _$rootScope_,_$compile_,_$httpBackend_,$http){ $compile = _$compile_; $rootScope = _$rootScope_; scope = $rootScope.$new(); angular.extend(scope,{ mock_a: [ {name: "example1"},{name: "example2"} ],mock_m: function(){ return $http.get('/mockBackend',{ params:{ page: scope.mockPage } }); },mock_r: function() { scope.page = 1; scope.list = []; load(); },mock_p: 1 }); $httpListGet = _$httpBackend_; $httpListGet.whenPOST('/api/something').respond({}); $httpListGet.whenGET('/mockBackend').respond({name: "example3"}); $httpListGet.whenGET('/mockBackend?page=1').respond({name: "example3"}); $httpListGet.whenGET('/mockBackend?page=2').respond({name: "example4"}); })); var create = function() { elem = angular.element(baseElement); compiledElement = $compile(elem)(scope); elem.scope().$apply(); return compiledElement; }; it("has 'list' defined",function() { var compiledElem = create(); var isolateElemScope = compiledElem.isolateScope(); $rootScope.$apply(); console.log('isolateElemScope',isolateElemScope); expect(isolateElemScope.list).toBeDefined(); });
我期望指令范围是可访问和可测试的,但是当我测试它时我得到了未定义.谢谢.