UNPKG

5.57 kBJavaScriptView Raw
1
2var tf = new TableFilter('demo', {
3 base_path: '../dist/tablefilter/',
4 btn_reset: true
5});
6tf.init();
7
8var clearButton = tf.feature('clearButton');
9module('Sanity checks');
10test('Clear button component', function() {
11 deepEqual(typeof clearButton, 'object', 'ClearButton instanciated');
12 notEqual(clearButton.container, null, 'container property');
13 notEqual(clearButton.element, null, 'element property');
14});
15
16module('Feature interface');
17test('Properties', function() {
18 deepEqual(
19 clearButton.tf instanceof TableFilter, true, 'TableFilter instance');
20 deepEqual(clearButton.feature, 'btnReset', 'Feature name');
21 deepEqual(clearButton.enabled, true, 'Feature enabled');
22 deepEqual(clearButton.initialized, true, 'Feature enabled');
23 deepEqual(typeof clearButton.emitter, 'object',
24 'Feature has emitter instance');
25 deepEqual(typeof clearButton.config, 'object', 'TF configuration object');
26 deepEqual(typeof clearButton.init, 'function', 'Feature init method');
27 deepEqual(typeof clearButton.destroy, 'function', 'Feature destroy method');
28 deepEqual(typeof clearButton.reset, 'function', 'Feature reset method');
29 deepEqual(typeof clearButton.enable, 'function', 'Feature enable method');
30 deepEqual(typeof clearButton.disable, 'function', 'Feature enable method');
31 deepEqual(typeof clearButton.isEnabled, 'function',
32 'Feature enable method');
33});
34test('Can destroy', function() {
35 clearButton.destroy();
36 deepEqual(clearButton.initialized, false, 'not initialised');
37});
38test('Can reset', function() {
39 clearButton.reset();
40 deepEqual(clearButton.enabled, true, 'enabled');
41});
42test('Can disable', function() {
43 clearButton.disable();
44 deepEqual(clearButton.enabled, false, 'disabled');
45});
46test('Can enable', function() {
47 clearButton.enable();
48 deepEqual(clearButton.enabled, true, 'enabled');
49});
50test('Can init', function() {
51 clearButton.destroy();
52 clearButton.enable();
53 clearButton.init();
54 deepEqual(clearButton.enabled, true, 'enabled');
55});
56test('Can check is enabled', function() {
57 clearButton.isEnabled();
58 deepEqual(clearButton.enabled, true, 'enabled');
59});
60
61module('Behaviour');
62test('Cannot init if already initialised', function() {
63 // setup
64 clearButton.initialized = true;
65 var emit = clearButton.emitter.emit;
66 var hit = 0;
67 clearButton.emitter.emit = function() {
68 hit++;
69 };
70
71 // act
72 clearButton.init();
73
74 // assert
75 deepEqual(hit, 0, 'does not initialise');
76
77 clearButton.emitter.emit = emit;
78});
79
80test('onClick does nothing if not enabled', function() {
81 // setup
82 clearButton.disable();
83 var clearFilters = clearButton.tf.clearFilters;
84 var hit = 0;
85 clearButton.tf.clearFilters = function() {
86 hit++;
87 };
88
89 // act
90 clearButton.onClick();
91
92 // assert
93 deepEqual(hit, 0, 'onClick does nothing');
94
95 clearButton.tf.clearFilters = clearFilters;
96});
97
98test('onClick calls clearFilters if enabled', function() {
99 // setup
100 clearButton.enable();
101 var clearFilters = clearButton.tf.clearFilters;
102 var hit = 0;
103 clearButton.tf.clearFilters = function() {
104 hit++;
105 };
106
107 // act
108 clearButton.onClick();
109
110 // assert
111 deepEqual(hit, 1, 'onClick calls clearFilters');
112
113 clearButton.tf.clearFilters = clearFilters;
114});
115
116module('UI elements');
117test('ClearButton UI elements', function() {
118 var container = clearButton.container;
119 var element = clearButton.element;
120 deepEqual(container.nodeName, 'SPAN', 'Clear button container');
121 deepEqual(element.nodeName, 'INPUT', 'Clear button element');
122});
123
124module('Destroy and re-init');
125test('Remove UI', function() {
126 clearButton.destroy();
127 var btnResetEl = tf.feature('clearButton').element;
128 deepEqual(btnResetEl, null, 'Clear button is removed');
129});
130
131test('Re-set UI with no icons and text button', function() {
132 clearButton.destroy();
133 tf.enableIcons = false;
134 clearButton.html = null;
135 clearButton.text = 'Clear';
136 clearButton.init();
137
138 var btnResetEl = clearButton.element;
139 deepEqual(btnResetEl.nodeName, 'A', 'Clear button tag changed');
140 deepEqual(btnResetEl.innerText, 'Clear', 'Clear button text');
141});
142
143test('Destroy and init with text button and icons enabled', function() {
144 tf.destroy();
145 tf = new TableFilter('demo', {
146 base_path: '../dist/tablefilter/',
147 btn_reset: {
148 text: 'Clear all'
149 }
150 });
151 tf.init();
152
153 clearButton = tf.feature('clearButton');
154
155 var btnResetEl = clearButton.element;
156 deepEqual(btnResetEl.nodeName, 'A', 'Clear button tag changed');
157 deepEqual(btnResetEl.innerText, 'Clear all', 'Clear button text');
158});
159
160test('Destroy and init in external container', function() {
161 tf.destroy();
162 tf = new TableFilter('demo', {
163 base_path: '../dist/tablefilter/',
164 btn_reset: {
165 target_id: 'external-container'
166 }
167 });
168 tf.init();
169
170 clearButton = tf.feature('clearButton');
171
172 deepEqual(clearButton.element.nodeName, 'INPUT', 'Clear button tag');
173 deepEqual(clearButton.container.parentNode.id, 'external-container',
174 'container id');
175});
176
177module('Tear-down');
178test('can destroy TableFilter DOM elements', function() {
179 tf.destroy();
180 deepEqual(tf.isInitialized(), false, 'Filters removed');
181});