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
|
/* bender-tags: editor */
/* bender-ckeditor-plugins: dialog,button,forms,toolbar */
/* bender-include: _helpers/tools.js */
/* global formsTools */
var assertRequiredAttribute = formsTools.assertRequiredAttribute;
bender.editor = {
config: {
autoParagraph: false
}
};
bender.test( {
'test fill fields (text) ': function() {
var bot = this.editorBot;
bot.setData( '', function() {
bot.dialog( 'textfield', function( dialog ) {
dialog.setValueOf( 'info', '_cke_saved_name', 'name' );
dialog.setValueOf( 'info', 'value', 'value' );
dialog.setValueOf( 'info', 'required', 'checked' );
dialog.getButton( 'ok' ).click();
assert.areSame( '<input name="name" required="required" type="text" value="value" />', bot.getData( true ) );
} );
} );
},
'test fill fields (password)': function() {
var bot = this.editorBot;
bot.setData( '', function() {
bot.dialog( 'textfield', function( dialog ) {
dialog.setValueOf( 'info', 'type', 'password' );
dialog.setValueOf( 'info', '_cke_saved_name', 'name' );
dialog.setValueOf( 'info', 'value', 'value' );
dialog.setValueOf( 'info', 'required', 'checked' );
dialog.getButton( 'ok' ).click();
assert.areSame( '<input name="name" required="required" type="password" value="value" />', bot.getData( true ) );
} );
} );
},
'test empty fields': function() {
var bot = this.editorBot;
bot.setHtmlWithSelection( '[<input name="name" type="text" value="value" required="required" />]' );
bot.dialog( 'textfield', function( dialog ) {
assert.areSame( 'name', dialog.getValueOf( 'info', '_cke_saved_name' ) );
assert.areSame( 'value', dialog.getValueOf( 'info', 'value' ) );
assert.areSame( true, dialog.getValueOf( 'info', 'required' ) );
dialog.setValueOf( 'info', '_cke_saved_name', '' );
dialog.setValueOf( 'info', 'value', '' );
dialog.setValueOf( 'info', 'required', '' );
dialog.getButton( 'ok' ).click();
assert.areSame( '<input type="text" />', bot.getData( false, true ) );
} );
},
'test read attributes (email)': function() {
var bot = this.editorBot;
bot.setHtmlWithSelection( '[<input name="name" type="email" value="test@host.com" />]' );
bot.dialog( 'textfield', function( dialog ) {
assert.areSame( 'name', dialog.getValueOf( 'info', '_cke_saved_name' ) );
assert.areSame( 'email', dialog.getValueOf( 'info', 'type' ) );
assert.areSame( 'test@host.com', dialog.getValueOf( 'info', 'value' ) );
dialog.setValueOf( 'info', 'type', 'text' );
dialog.getButton( 'ok' ).click();
assert.areSame( '<input name="name" type="text" value="test@host.com" />', bot.getData( true ) );
} );
},
'test required attribute collapsed': assertRequiredAttribute( {
html: '[<input type="text" required />]',
type: 'textfield',
expected: true
} ),
'test required attribute without value': assertRequiredAttribute( {
html: '[<input type="text" required="" />]',
type: 'textfield',
expected: true
} ),
'test required attribute with value `required`': assertRequiredAttribute( {
html: '[<input type="text" required="required" />]',
type: 'textfield',
expected: true
} ),
'test required attribute absent': assertRequiredAttribute( {
html: '[<input type="text" />]',
type: 'textfield',
expected: false
} ),
'test required attribute with invalid value': assertRequiredAttribute( {
html: '[<input type="text" required="any value other than empty string or required" />]',
type: 'textfield',
expected: true
} )
} );
|