aboutsummaryrefslogtreecommitdiffstats
path: root/tests/unit/form-reset-mixin/core.js
blob: 4dbd7ac4255692d1a5a1b95446fd5580ee8ec6f3 (plain)
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
define( [
	"jquery",
	"lib/common",
	"ui/widget",
	"ui/form-reset-mixin"
], function( $, common ) {

module( "widget factory", {
	setup: function() {
		$.widget( "ui.testWidget", [ $.ui.formResetMixin, {
			_create: function() {
				this._bindFormResetHandler();
			},
			_destroy: function() {
				this._unbindFormResetHandler();
			},
			refresh: function() {
				$.ui.testWidget.refreshed.push( this.element.attr( "id" ) );
			}
		} ] );

		$.ui.testWidget.refreshed = [];
	},

	teardown: function() {
		delete $.ui.testWidget;
		delete $.fn.testWidget;
	}
} );

common.testJshint( "form-reset-mixin" );

asyncTest( "form reset", function() {
	expect( 2 );

	var form = $( "#main" );
	var inputs = form.find( "input" );

	inputs.testWidget();
	form.on( "reset", function() {
		setTimeout( function() {
			deepEqual( $.ui.testWidget.refreshed, [ "input1", "input2", "input3", "input4" ],
				"All widgets are refreshed on form reset" );
			equal( form.data( "ui-form-reset-instances" ).length, 4,
				"All widget instances are tracked against the form" );
			start();
		} );
	} );
	form[ 0 ].reset();
} );

asyncTest( "destroy", function() {
	expect( 2 );

	var form = $( "#main" );
	var inputs = form.find( "input" );

	inputs
		.testWidget()
		.eq( 1 )
			.testWidget( "destroy" );

	form.on( "reset", function() {
		setTimeout( function() {
			deepEqual( $.ui.testWidget.refreshed, [ "input1", "input3", "input4" ],
				"All widgets are refreshed on form reset" );
			deepEqual( form.data( "ui-form-reset-instances" ).length, 3,
				"All widget instances are tracked against the form" );
			start();
		} );
	} );
	form[ 0 ].reset();
} );

asyncTest( "destroy all", function() {
	expect( 2 );

	var form = $( "#main" );

	form.find( "input" )
		.testWidget()
		.testWidget( "destroy" );

	form.on( "reset", function() {
		setTimeout( function() {
			deepEqual( $.ui.testWidget.refreshed, [], "No widgets are refreshed after destroy" );
			strictEqual( form.data( "ui-form-reset-instances" ), undefined,
				"Form data is removed when the last widget instance is destroyed" );
			start();
		} );
	} );
	form[ 0 ].reset();
} );

} );