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
|
/* bender-tags: editor */
/* bender-ckeditor-plugins: dialog,button,forms,htmlwriter,toolbar */
/* bender-include: _helpers/tools.js */
/* global formsTools */
var assertRequiredAttribute = formsTools.assertRequiredAttribute;
bender.editor = {
config: {
autoParagraph: false
}
};
bender.test( {
'test fill fields': function() {
var bot = this.editorBot;
bot.dialog( 'radio', function( dialog ) {
dialog.setValueOf( 'info', 'name', 'name' );
dialog.setValueOf( 'info', 'value', 'value' );
dialog.setValueOf( 'info', 'checked', 'checked' );
dialog.setValueOf( 'info', 'required', 'checked' );
dialog.getButton( 'ok' ).click();
assert.areSame( '<input checked="checked" name="name" required="required" type="radio" value="value" />', bot.getData( false, true ) );
} );
},
'test empty fields': function() {
var bot = this.editorBot;
bot.setHtmlWithSelection( '[<input checked="checked" name="name" required="required" type="radio" value="value" />]' );
// We need to add attribute 'checked', after adding radio input to editable.
// From uknown reason IE omits this attribute when add radio input element to DOM tree.
if ( CKEDITOR.env.ie ) {
this.editor.editable().findOne( 'input' ).setAttribute( 'checked', 'checked' );
}
bot.dialog( 'radio', function( dialog ) {
assert.areSame( 'name', dialog.getValueOf( 'info', 'name' ) );
assert.areSame( 'value', dialog.getValueOf( 'info', 'value' ) );
assert.areSame( true, dialog.getValueOf( 'info', 'checked' ) );
assert.areSame( true, dialog.getValueOf( 'info', 'required' ) );
dialog.setValueOf( 'info', 'name', '' );
dialog.setValueOf( 'info', 'value', '' );
dialog.setValueOf( 'info', 'checked', '' );
dialog.setValueOf( 'info', 'required', '' );
dialog.getButton( 'ok' ).click();
// IE is problematic: you cannot remove `value` from the input.
// This customization should be removed if #844 will be fixed.
if ( CKEDITOR.env.ie ) {
assert.areSame( '<input type="radio" value="value" />', bot.getData( false, true ) );
} else {
assert.areSame( '<input type="radio" />', bot.getData( false, true ) );
}
} );
},
'test required attribute collapsed': assertRequiredAttribute( {
html: '[<input type="checkbox" required />]',
type: 'checkbox',
expected: true
} ),
'test required attribute without value': assertRequiredAttribute( {
html: '[<input type="checkbox" required="" />]',
type: 'checkbox',
expected: true
} ),
'test required attribute with value `required`': assertRequiredAttribute( {
html: '[<input type="checkbox" required="required" />]',
type: 'checkbox',
expected: true
} ),
'test required attribute absent': assertRequiredAttribute( {
html: '[<input type="checkbox" />]',
type: 'checkbox',
expected: false
} ),
'test required attribute with invalid value': assertRequiredAttribute( {
html: '[<input type="checkbox" required="any value other than empty string or required" />]',
type: 'checkbox',
expected: true
} )
} );
|