| 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
 | 'use strict';
describe('boolean attr directives', function() {
  var element;
  afterEach(function() {
    dealoc(element);
  });
  it('should bind href', inject(function($rootScope, $compile) {
    element = $compile('<a ng-href="{{url}}"></a>')($rootScope)
    $rootScope.url = 'http://server'
    $rootScope.$digest();
    expect(element.attr('href')).toEqual('http://server');
  }));
  it('should bind disabled', inject(function($rootScope, $compile) {
    element = $compile('<button ng-disabled="{{isDisabled}}">Button</button>')($rootScope)
    $rootScope.isDisabled = false;
    $rootScope.$digest();
    expect(element.attr('disabled')).toBeFalsy();
    $rootScope.isDisabled = true;
    $rootScope.$digest();
    expect(element.attr('disabled')).toBeTruthy();
  }));
  it('should bind checked', inject(function($rootScope, $compile) {
    element = $compile('<input type="checkbox" ng-checked="{{isChecked}}" />')($rootScope)
    $rootScope.isChecked = false;
    $rootScope.$digest();
    expect(element.attr('checked')).toBeFalsy();
    $rootScope.isChecked=true;
    $rootScope.$digest();
    expect(element.attr('checked')).toBeTruthy();
  }));
  it('should bind selected', inject(function($rootScope, $compile) {
    element = $compile('<select><option value=""></option><option ng-selected="{{isSelected}}">Greetings!</option></select>')($rootScope)
    jqLite(document.body).append(element)
    $rootScope.isSelected=false;
    $rootScope.$digest();
    expect(element.children()[1].selected).toBeFalsy();
    $rootScope.isSelected=true;
    $rootScope.$digest();
    expect(element.children()[1].selected).toBeTruthy();
  }));
  it('should bind readonly', inject(function($rootScope, $compile) {
    element = $compile('<input type="text" ng-readonly="{{isReadonly}}" />')($rootScope)
    $rootScope.isReadonly=false;
    $rootScope.$digest();
    expect(element.attr('readOnly')).toBeFalsy();
    $rootScope.isReadonly=true;
    $rootScope.$digest();
    expect(element.attr('readOnly')).toBeTruthy();
  }));
  it('should bind multiple', inject(function($rootScope, $compile) {
    element = $compile('<select ng-multiple="{{isMultiple}}"></select>')($rootScope)
    $rootScope.isMultiple=false;
    $rootScope.$digest();
    expect(element.attr('multiple')).toBeFalsy();
    $rootScope.isMultiple='multiple';
    $rootScope.$digest();
    expect(element.attr('multiple')).toBeTruthy();
  }));
  it('should bind src', inject(function($rootScope, $compile) {
    element = $compile('<div ng-src="{{url}}" />')($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) {
    element = $compile('<a ng-href="{{url}}" rel="{{rel}}"></a>')($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, $rootScope) {
    forEach(['checked', 'disabled', 'multiple', 'readonly', 'selected'], function(name) {
      element = $compile('<div ng-' + name + '="some"></div>')($rootScope)
      $rootScope.$digest();
      expect(element.attr(name)).toBe(name);
      dealoc(element);
    });
    element = $compile('<div ng-src="some"></div>')($rootScope)
    $rootScope.$digest();
    expect(element.attr('src')).toEqual('some');
    dealoc(element);
    element = $compile('<div ng-href="some"></div>')($rootScope)
    $rootScope.$digest();
    expect(element.attr('href')).toEqual('some');
    dealoc(element);
  }));
});
 |