From 9ee2cdff44e7d496774b340de816344126c457b3 Mon Sep 17 00:00:00 2001 From: Misko Hevery Date: Tue, 22 Nov 2011 21:28:39 -0800 Subject: refactor(directives): connect new compiler - turn everything into a directive --- test/markupSpec.js | 72 +++++++++++++++++++++++++++++------------------------- 1 file changed, 39 insertions(+), 33 deletions(-) (limited to 'test/markupSpec.js') diff --git a/test/markupSpec.js b/test/markupSpec.js index 0dcbbfe9..6f8e518e 100644 --- a/test/markupSpec.js +++ b/test/markupSpec.js @@ -1,33 +1,38 @@ 'use strict'; describe("markups", function() { + var element; + + afterEach(function() { + dealoc(element); + }); it('should translate {{}} in text', inject(function($rootScope, $compile) { - var element = $compile('
hello {{name}}!
')($rootScope) - expect(sortedHtml(element)).toEqual('
hello !
'); + element = $compile('
hello {{name}}!
')($rootScope) + $rootScope.$digest(); + expect(sortedHtml(element)).toEqual('
hello !
'); $rootScope.name = 'Misko'; $rootScope.$digest(); - expect(sortedHtml(element)).toEqual('
hello Misko!
'); + expect(sortedHtml(element)).toEqual('
hello Misko!
'); })); it('should translate {{}} in terminal nodes', inject(function($rootScope, $compile) { - var element = $compile('')($rootScope) + element = $compile('')($rootScope) $rootScope.$digest(); expect(sortedHtml(element).replace(' selected="true"', '')). toEqual(''); $rootScope.name = 'Misko'; $rootScope.$digest(); expect(sortedHtml(element).replace(' selected="true"', '')). toEqual(''); })); it('should translate {{}} in attributes', inject(function($rootScope, $compile) { - var element = $compile('
')($rootScope) - expect(element.attr('ng:bind-attr')).toEqual('{"src":"http://server/{{path}}.png"}'); + element = $compile('
')($rootScope) $rootScope.path = 'a/b'; $rootScope.$digest(); expect(element.attr('src')).toEqual("http://server/a/b.png"); @@ -56,36 +61,38 @@ describe("markups", function() { it('should populate value attribute on OPTION', inject(function($rootScope, $compile) { - var element = $compile('')($rootScope) + element = $compile('')($rootScope) expect(element).toHaveValue('abc'); })); it('should ignore value if already exists', inject(function($rootScope, $compile) { - var element = $compile('')($rootScope) + element = $compile('')($rootScope) expect(element).toHaveValue('abc'); })); it('should set value even if newlines present', inject(function($rootScope, $compile) { - var element = $compile('')($rootScope) + element = $compile('')($rootScope) expect(element).toHaveValue('\nabc\n'); })); it('should set value even if self closing HTML', inject(function($rootScope, $compile) { // IE removes the \n from option, which makes this test pointless if (msie) return; - var element = $compile('')($rootScope) + element = $compile('')($rootScope) expect(element).toHaveValue('\n'); })); }); it('should bind href', inject(function($rootScope, $compile) { - var element = $compile('')($rootScope) - expect(sortedHtml(element)).toEqual(''); + element = $compile('')($rootScope) + $rootScope.url = 'http://server' + $rootScope.$digest(); + expect(element.attr('href')).toEqual('http://server'); })); it('should bind disabled', inject(function($rootScope, $compile) { - var element = $compile('')($rootScope) + element = $compile('')($rootScope) $rootScope.isDisabled = false; $rootScope.$digest(); expect(element.attr('disabled')).toBeFalsy(); @@ -95,7 +102,7 @@ describe("markups", function() { })); it('should bind checked', inject(function($rootScope, $compile) { - var element = $compile('')($rootScope) + element = $compile('')($rootScope) $rootScope.isChecked = false; $rootScope.$digest(); expect(element.attr('checked')).toBeFalsy(); @@ -105,7 +112,7 @@ describe("markups", function() { })); it('should bind selected', inject(function($rootScope, $compile) { - var element = $compile('')($rootScope) + element = $compile('')($rootScope) jqLite(document.body).append(element) $rootScope.isSelected=false; $rootScope.$digest(); @@ -116,7 +123,7 @@ describe("markups", function() { })); it('should bind readonly', inject(function($rootScope, $compile) { - var element = $compile('')($rootScope) + element = $compile('')($rootScope) $rootScope.isReadonly=false; $rootScope.$digest(); expect(element.attr('readOnly')).toBeFalsy(); @@ -126,7 +133,7 @@ describe("markups", function() { })); it('should bind multiple', inject(function($rootScope, $compile) { - var element = $compile('')($rootScope) + element = $compile('')($rootScope) $rootScope.isMultiple=false; $rootScope.$digest(); expect(element.attr('multiple')).toBeFalsy(); @@ -136,38 +143,37 @@ describe("markups", function() { })); it('should bind src', inject(function($rootScope, $compile) { - var element = $compile('
')($rootScope) + element = $compile('
')($rootScope) $rootScope.url = 'http://localhost/'; $rootScope.$digest(); expect(element.attr('src')).toEqual('http://localhost/'); })); it('should bind href and merge with other attrs', inject(function($rootScope, $compile) { - var element = $compile('')($rootScope) - expect(sortedHtml(element)).toEqual(''); + element = $compile('')($rootScope); + $rootScope.url = 'http://server'; + $rootScope.rel = 'REL'; + $rootScope.$digest(); + expect(element.attr('href')).toEqual('http://server'); + expect(element.attr('rel')).toEqual('REL'); })); - it('should bind Text with no Bindings', inject(function($compile) { - var $rootScope; - function newScope (){ - return $rootScope = angular.injector(['ng']).get('$rootScope'); - } + it('should bind Text with no Bindings', inject(function($compile, $rootScope) { forEach(['checked', 'disabled', 'multiple', 'readonly', 'selected'], function(name) { - var element = $compile('
')(newScope()) - expect(element.attr('ng:bind-attr')).toBe('{"' + name +'":"some"}'); + element = $compile('
')($rootScope) $rootScope.$digest(); expect(element.attr(name)).toBe(name); dealoc(element); }); - var element = $compile('
')(newScope()) + element = $compile('
')($rootScope) $rootScope.$digest(); - expect(sortedHtml(element)).toEqual('
'); + expect(element.attr('src')).toEqual('some'); dealoc(element); - var element = $compile('
')(newScope()) + element = $compile('
')($rootScope) $rootScope.$digest(); - expect(sortedHtml(element)).toEqual('
'); + expect(element.attr('href')).toEqual('some'); dealoc(element); })); }); -- cgit v1.2.3