0
0
mirror of https://github.com/twbs/bootstrap.git synced 2025-01-28 20:52:21 +01:00

fix(selector-engine): increase coverage for selector engine

This commit is contained in:
Johann-S 2018-06-16 22:20:27 +02:00 committed by XhmikosR
parent 4510e7e61d
commit 096413a994
5 changed files with 86 additions and 3 deletions

View File

@ -3,7 +3,7 @@ import Util from '../util'
/**
* --------------------------------------------------------------------------
* Bootstrap (v4.0.0-beta): dom/selectorEngine.js
* Bootstrap (v4.1.1): dom/selectorEngine.js
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
* --------------------------------------------------------------------------
*/
@ -69,6 +69,10 @@ const SelectorEngine = (() => {
},
closest(element, selector) {
if (typeof selector !== 'string') {
return null
}
return closest(element, selector)
},

View File

@ -119,6 +119,7 @@
<script src="unit/dom/eventHandler.js"></script>
<script src="unit/dom/manipulator.js"></script>
<script src="unit/dom/data.js"></script>
<script src="unit/dom/selectorEngine.js"></script>
<script src="unit/alert.js"></script>
<script src="unit/button.js"></script>
<script src="unit/carousel.js"></script>

View File

@ -15,7 +15,8 @@
"Simulator": false,
"Toast": false,
"EventHandler": false,
"Manipulator": false
"Manipulator": false,
"SelectorEngine": false
},
"parserOptions": {
"ecmaVersion": 5,

View File

@ -1,7 +1,7 @@
$(function () {
'use strict'
QUnit.module('event handler')
QUnit.module('eventHandler')
QUnit.test('should be defined', function (assert) {
assert.expect(1)

View File

@ -0,0 +1,77 @@
$(function () {
'use strict'
QUnit.module('selectorEngine')
QUnit.test('should be defined', function (assert) {
assert.expect(1)
assert.ok(SelectorEngine, 'Manipulator is defined')
})
QUnit.test('should determine if an element match the selector', function (assert) {
assert.expect(2)
$('<input type="checkbox" /> <button class="btn"></button>').appendTo('#qunit-fixture')
assert.ok(!SelectorEngine.matches($('#qunit-fixture')[0], '.btn'))
assert.ok(SelectorEngine.matches($('.btn')[0], '.btn'))
})
QUnit.test('should find the selector, according to an element or not', function (assert) {
assert.expect(3)
$('<input type="checkbox" /> <button class="btn"></button>').appendTo('#qunit-fixture')
var btn = $('.btn').first()[0]
assert.strictEqual(SelectorEngine.find($('.btn')), null)
assert.equal(SelectorEngine.find('.btn')[0], btn)
assert.equal(SelectorEngine.find('.btn', $('#qunit-fixture')[0])[0], btn)
})
QUnit.test('should find the first element which match the selector, according to an element or not', function (assert) {
assert.expect(3)
$('<button class="btn">btn1</button> <button class="btn">btn2</button>').appendTo('#qunit-fixture')
var btn = $('.btn').first()[0]
assert.strictEqual(SelectorEngine.findOne($('.btn')), null)
assert.equal(SelectorEngine.findOne('.btn'), btn)
assert.equal(SelectorEngine.findOne('.btn', $('#qunit-fixture')[0]), btn)
})
QUnit.test('should find children', function (assert) {
assert.expect(2)
$('<button class="btn">btn1</button> <button class="btn">btn2</button> <input type="text" />').appendTo('#qunit-fixture')
assert.strictEqual(SelectorEngine.children($('.btn')), null)
assert.equal(SelectorEngine.children($('#qunit-fixture')[0], '.btn').length, 2)
})
QUnit.test('should find the selector in parents', function (assert) {
assert.expect(2)
$('<input type="text" />').appendTo('#qunit-fixture')
assert.strictEqual(SelectorEngine.parents($('.container')[0], {}), null)
assert.strictEqual(SelectorEngine.parents($('input')[0], 'body').length, 1)
})
QUnit.test('should find the closest element according to the selector', function (assert) {
assert.expect(2)
var html =
'<div class="test">' +
' <button class="btn"></button>' +
'</div>'
$(html).appendTo('#qunit-fixture')
assert.strictEqual(SelectorEngine.closest($('.btn')[0], {}), null)
assert.strictEqual(SelectorEngine.closest($('.btn')[0], '.test'), $('.test')[0])
})
QUnit.test('should fin previous element', function (assert) {
assert.expect(2)
var html =
'<div class="test"></div>' +
'<button class="btn"></button>'
$(html).appendTo('#qunit-fixture')
assert.strictEqual(SelectorEngine.prev($('.btn')[0], {}), null)
assert.strictEqual(SelectorEngine.prev($('.btn')[0], '.test')[0], $('.test')[0])
})
})