1
0
mirror of synced 2024-11-22 21:16:10 +03:00
select2/tests/results/option-tests.js
2019-08-21 21:44:25 -04:00

117 lines
3.2 KiB
JavaScript

QUnit.module('Results - option');
var $ = require('jquery');
var Options = require('select2/options');
var Results = require('select2/results');
QUnit.test('disabled property on option is respected - enabled', function (assert) {
var results = new Results($('<select></select>'), new Options({}));
var $option = $('<option></option>');
var option = results.option({
element: $option[0]
});
assert.notEqual(option.getAttribute('aria-disabled'), 'true');
});
QUnit.test('disabled property on option is respected - disabled', function (assert) {
var results = new Results($('<select></select>'), new Options({}));
var $option = $('<option disabled></option>');
var option = results.option({
element: $option[0]
});
assert.equal(option.getAttribute('aria-disabled'), 'true');
});
QUnit.test('disabled property on enabled optgroup is respected', function (assert) {
var results = new Results($('<select></select>'), new Options({}));
var $option = $('<optgroup></optgroup>');
var option = results.option({
element: $option[0]
});
assert.notEqual(option.getAttribute('aria-disabled'), 'true');
});
QUnit.test('disabled property on disabled optgroup is respected', function (assert) {
var results = new Results($('<select></select>'), new Options({}));
var $option = $('<optgroup disabled></optgroup>');
var option = results.option({
element: $option[0]
});
assert.equal(option.getAttribute('aria-disabled'), 'true');
});
QUnit.test('option in disabled optgroup is disabled', function (assert) {
var results = new Results($('<select></select>'), new Options({}));
var $option = $('<optgroup disabled><option></option></optgroup>')
.find('option');
var option = results.option({
element: $option[0]
});
assert.equal(option.getAttribute('aria-disabled'), 'true');
});
QUnit.test('options are not selected by default', function (assert) {
var results = new Results($('<select></select>'), new Options({}));
var $option = $('<option></option>');
var option = results.option({
id: 'test',
element: $option[0]
});
assert.equal(option.getAttribute('aria-selected'), 'false');
});
QUnit.test('options with children are given the group role', function(assert) {
var results = new Results($('<select></select>'), new Options({}));
var $option = $('<optgroup></optgroup>');
var option = results.option({
children: [{
id: 'test'
}],
element: $option[0]
});
assert.equal(option.getAttribute('role'), 'group');
});
QUnit.test('options with children have the aria-label set', function (assert) {
var results = new Results($('<select></select>'), new Options({}));
var $option = $('<optgroup></optgroup>');
var option = results.option({
children: [{
id: 'test'
}],
element: $option[0],
text: 'test'
});
assert.equal(option.getAttribute('aria-label'), 'test');
});
QUnit.test('non-group options are given the option role', function (assert) {
var results = new Results($('<select></select>'), new Options({}));
var $option = $('<option></option>');
var option = results.option({
id: 'test',
element: $option[0]
});
assert.equal(option.getAttribute('role'), 'option');
});