Wordpress/tests/qunit/wp-admin/js/customize-controls-utils.js

109 lines
3.8 KiB
JavaScript
Raw Normal View History

/* global wp */
jQuery( function( $ ) {
var trueMockEvent, falseMockEvent, mockElementLists, $firstMockElement, $secondMockElement, $thirdMockElement,
BubbleTester, BubbleTesterTwoValues, bubbleTesterParent, firstBubbleTester, secondBubbleTester;
QUnit.module( 'Customizer Model Utility functions' );
trueMockEvent = {
type : 'keydown',
which : 14
};
falseMockEvent = {
type : 'keydown',
which : 13
};
QUnit.test( 'isKeydownButNotEnterEvent returns true', function( assert ) {
assert.ok( wp.customize.utils.isKeydownButNotEnterEvent( trueMockEvent ) );
});
QUnit.test( 'isKeydownButNotEnterEvent returns false', function( assert ) {
assert.equal( wp.customize.utils.isKeydownButNotEnterEvent( falseMockEvent ) , false );
});
$firstMockElement = $( '<div id="foo"></div>' );
$secondMockElement = $( '<li id="bar"></li>' );
$thirdMockElement = $( '<div id="thirdElement"></div>' );
mockElementLists = {
first : [ $firstMockElement , $secondMockElement ],
second : [ $secondMockElement ],
firstInReverseOrder : [ $secondMockElement , $firstMockElement ],
third : [ $firstMockElement, $secondMockElement ],
thirdButLonger : [ $firstMockElement, $secondMockElement, $thirdMockElement ]
};
QUnit.test( 'areElementListsEqual returns true', function( assert ) {
assert.ok( wp.customize.utils.areElementListsEqual( mockElementLists.first , mockElementLists.first ) );
});
QUnit.test( 'areElementListsEqual returns false', function( assert ) {
assert.equal( wp.customize.utils.areElementListsEqual( mockElementLists.first , mockElementLists.second ) , false );
});
QUnit.test( 'areElementListsEqual: lists have same values, but in reverse order', function( assert ) {
assert.equal( wp.customize.utils.areElementListsEqual( mockElementLists.first , mockElementLists.firstInReverseOrder ) , false );
});
QUnit.test( 'areElementListsEqual: lists have same values, but one is longer', function( assert ) {
assert.equal( wp.customize.utils.areElementListsEqual( mockElementLists.third , mockElementLists.thirdButLonger ) , false );
});
bubbleTesterParent = function() {
this.trigger = function( event , instance ) {
this.wasChangeTriggered = true;
this.instancePassedInTrigger = instance;
};
this.wasChangeTriggered = false;
this.instancePassedInTrigger = {};
};
BubbleTester = wp.customize.Class.extend(
{
parent : new bubbleTesterParent(),
fooValue : new wp.customize.Value()
},
{
staticProperty : 'propertyValue'
}
);
QUnit.test( 'bubbleChildValueChanges notifies parent of change', function( assert ) {
firstBubbleTester = new BubbleTester();
wp.customize.utils.bubbleChildValueChanges( firstBubbleTester , [ 'fooValue' ] );
firstBubbleTester.fooValue.set( 'new value' );
assert.ok( firstBubbleTester.parent.wasChangeTriggered );
});
QUnit.test( 'bubbleChildValueChanges passes a reference to its instance', function( assert ) {
assert.ok( firstBubbleTester.parent.instancePassedInTrigger instanceof BubbleTester );
});
BubbleTesterTwoValues = wp.customize.Class.extend(
{
parent : new bubbleTesterParent(),
exampleValue : new wp.customize.Value(),
barValue : new wp.customize.Value()
},
{
staticProperty : 'propertyValue'
}
);
secondBubbleTester = new BubbleTesterTwoValues();
wp.customize.utils.bubbleChildValueChanges( secondBubbleTester , [ 'exampleValue' , 'barValue' ] );
secondBubbleTester.barValue.set( 'new value' );
QUnit.test( 'bubbleChildValueChanges notifies parent of change when two values are bound', function( assert ) {
assert.ok( secondBubbleTester.parent.wasChangeTriggered );
});
QUnit.test( 'bubbleChildValueChanges passes a reference to its instance when two values are bound', function( assert ) {
assert.ok( secondBubbleTester.parent.instancePassedInTrigger instanceof BubbleTesterTwoValues );
});
});