mirror of
https://github.com/status-im/consul.git
synced 2025-01-09 21:35:52 +00:00
c532e53d9a
Move all the dom-things to use the dom service in tabular-collection, feedback-dialog, list-collection and node show. Move get-component-factory into utils/dom and use dom.root() in a few more places This includes an additional `dom.components` method which gives you a list of components matching the selector instead of just one.
49 lines
1.3 KiB
JavaScript
49 lines
1.3 KiB
JavaScript
import getComponentFactory from 'consul-ui/utils/dom/get-component-factory';
|
|
import { module, test } from 'qunit';
|
|
|
|
module('Unit | Utility | dom/get component factory');
|
|
|
|
test("it uses lookup to locate the instance of the component based on the DOM element's id", function(assert) {
|
|
const expected = 'name';
|
|
let getComponent = getComponentFactory({
|
|
lookup: function() {
|
|
return { id: expected };
|
|
},
|
|
});
|
|
assert.equal(typeof getComponent, 'function', 'returns a function');
|
|
const actual = getComponent({
|
|
getAttribute: function(name) {
|
|
return 'id';
|
|
},
|
|
});
|
|
assert.equal(actual, expected, 'performs a lookup based on the id');
|
|
});
|
|
test("it returns null if it can't find it", function(assert) {
|
|
const expected = null;
|
|
let getComponent = getComponentFactory({
|
|
lookup: function() {
|
|
return { id: '' };
|
|
},
|
|
});
|
|
const actual = getComponent({
|
|
getAttribute: function(name) {
|
|
return 'non-existent';
|
|
},
|
|
});
|
|
assert.equal(actual, expected);
|
|
});
|
|
test('it returns null if there is no id', function(assert) {
|
|
const expected = null;
|
|
let getComponent = getComponentFactory({
|
|
lookup: function() {
|
|
return { id: '' };
|
|
},
|
|
});
|
|
const actual = getComponent({
|
|
getAttribute: function(name) {
|
|
return;
|
|
},
|
|
});
|
|
assert.equal(actual, expected);
|
|
});
|