forked from ExactTarget/fuelux
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsearch-test.js
116 lines (80 loc) · 3.84 KB
/
search-test.js
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
112
113
114
115
116
/*global QUnit:false, module:false, test:false, asyncTest:false, expect:false*/
/*global start:false, stop:false ok:false, equal:false, notEqual:false, deepEqual:false*/
/*global notDeepEqual:false, strictEqual:false, notStrictEqual:false, raises:false*/
define(function(require){
var $ = require('jquery');
var html = require('text!test/markup/search-markup.html');
require('bootstrap');
require('fuelux/search');
module("Fuel UX Search");
test("should be defined on jquery object", function () {
ok($().search, 'search method is defined');
});
test("should return element", function () {
var $search = $(html);
ok($search.search() === $search, 'search has been initialized');
});
test("should ignore empty search", function () {
var $search = $(html);
$search.search();
$search.find('button').click();
equal($search.find('.glyphicon').attr('class'), 'glyphicon glyphicon-search', 'search icon has not changed');
});
test("should ignore disabled button click", function () {
var $search = $(html);
$search.find('button').addClass('disabled');
$search.search();
$search.find('input').val('search text');
$search.find('button').click();
equal($search.find('.glyphicon').attr('class'), 'glyphicon glyphicon-search', 'search icon has not changed');
});
test("should process valid search", function () {
var $search = $(html);
var searchText = '';
$search.search().on('searched.fu.search', function (e, text) { searchText = text; });
$search.find('input').val('search text');
$search.find('button').click();
equal($search.find('.glyphicon').attr('class'), 'glyphicon glyphicon-remove', 'search icon has changed');
equal(searchText, 'search text', 'search text was provided in event');
});
test("should allow search to be cleared", function () {
var $search = $(html);
var clearedEventFired = false;
$search.search().on('cleared.fu.search', function (e, text) { clearedEventFired = true; });
$search.find('input').val('search text');
$search.find('button').click();
$search.find('button').click();
equal($search.find('.glyphicon').attr('class'), 'glyphicon glyphicon-search', 'search icon has returned');
equal($search.find('input').val(), '', 'search text has been cleared');
equal(clearedEventFired, true, 'cleared event was fired');
});
test("should process sequential searches", function () {
var $search = $(html);
var searchText = '';
$search.search().on('searched.fu.search', function (e, text) { searchText = text; });
$search.find('input').val('search text');
$search.find('button').click();
equal($search.find('.glyphicon').attr('class'), 'glyphicon glyphicon-remove', 'search icon has changed');
equal(searchText, 'search text', 'search text was provided in event');
$search.find('input').val('search text 2').keyup();
equal($search.find('.glyphicon').attr('class'), 'glyphicon glyphicon-search', 'search icon has returned');
$search.find('button').click();
equal($search.find('.glyphicon').attr('class'), 'glyphicon glyphicon-remove', 'search icon has changed');
equal(searchText, 'search text 2', 'search text was provided in event');
});
test("should correctly respond to disable and enable methods", function () {
var $search = $(html);
$search.search();
$search.search('disable');
equal($search.find('input').attr('disabled'), 'disabled', 'input was disabled');
equal($search.find('button').hasClass('disabled'), true, 'button was disabled');
$search.search('enable');
equal($search.find('input').attr('disabled'), undefined, 'input was enabled');
equal($search.find('button').hasClass('disabled'), false, 'button was enabled');
});
test("should destroy control", function () {
var $el = $(html).search();
equal(typeof( $el.search('destroy')) , 'string', 'returns string (markup)');
equal( $el.parent().length, false, 'control has been removed from DOM');
});
});