2015-10-28 13:28:15 -04:00
|
|
|
import * as Dom from '../../src/js/utils/dom';
|
2015-03-25 21:43:41 -07:00
|
|
|
import Player from '../../src/js/player.js';
|
|
|
|
import document from 'global/document';
|
|
|
|
|
2016-08-03 15:27:03 -04:00
|
|
|
const TestHelpers = {
|
|
|
|
makeTag() {
|
|
|
|
const videoTag = document.createElement('video');
|
|
|
|
|
2013-06-24 12:47:47 -07:00
|
|
|
videoTag.id = 'example_1';
|
2018-10-10 15:30:20 -04:00
|
|
|
videoTag.className = 'video-js';
|
2013-06-24 12:47:47 -07:00
|
|
|
return videoTag;
|
|
|
|
},
|
2015-03-25 21:43:41 -07:00
|
|
|
|
2019-04-23 10:42:52 -07:00
|
|
|
makePlayer(playerOptions, videoTag) {
|
2015-03-25 21:43:41 -07:00
|
|
|
videoTag = videoTag || TestHelpers.makeTag();
|
2013-06-24 12:47:47 -07:00
|
|
|
|
2016-08-03 15:27:03 -04:00
|
|
|
const fixture = document.getElementById('qunit-fixture');
|
|
|
|
|
2013-06-24 12:47:47 -07:00
|
|
|
fixture.appendChild(videoTag);
|
|
|
|
|
|
|
|
playerOptions = playerOptions || {};
|
2016-08-03 15:27:03 -04:00
|
|
|
playerOptions.techOrder = playerOptions.techOrder || ['techFaker'];
|
2013-06-24 12:47:47 -07:00
|
|
|
|
2019-04-23 10:42:52 -07:00
|
|
|
return new Player(videoTag, playerOptions);
|
2015-03-25 21:43:41 -07:00
|
|
|
},
|
2014-10-16 12:59:41 -07:00
|
|
|
|
2016-08-03 15:27:03 -04:00
|
|
|
getComputedStyle(el, rule) {
|
2015-05-16 15:59:46 -07:00
|
|
|
if (document.defaultView && document.defaultView.getComputedStyle) {
|
|
|
|
return document.defaultView.getComputedStyle(el, null).getPropertyValue(rule);
|
|
|
|
}
|
2014-10-16 12:59:41 -07:00
|
|
|
|
2018-03-23 13:25:12 -04:00
|
|
|
return '';
|
2015-10-28 13:28:15 -04:00
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Runs a range of assertions on a DOM element.
|
|
|
|
*
|
|
|
|
* @param {QUnit.Assert} assert
|
|
|
|
* @param {Element} el
|
|
|
|
* @param {Object} spec
|
|
|
|
* An object from which assertions are generated.
|
|
|
|
*
|
|
|
|
* @param {Object} [spec.attrs]
|
|
|
|
* An object mapping attribute names (keys) to strict values.
|
|
|
|
*
|
|
|
|
* @param {Array} [spec.classes]
|
|
|
|
* An array of classes that are expected on the element.
|
|
|
|
*
|
2018-09-28 14:58:15 -04:00
|
|
|
* @param {string} [spec.innerHTML]
|
2015-10-28 13:28:15 -04:00
|
|
|
* A string of text/html that is expected as the content of element.
|
|
|
|
* Both values will be trimmed, but remains case-sensitive.
|
|
|
|
*
|
|
|
|
* @param {Object} [spec.props]
|
|
|
|
* An object mapping property names (keys) to strict values.
|
|
|
|
*
|
2018-09-28 14:58:15 -04:00
|
|
|
* @param {string} [spec.tagName]
|
2015-10-28 13:28:15 -04:00
|
|
|
* A string (case-insensitive) representing that element's tagName.
|
|
|
|
*
|
|
|
|
* @return {Function}
|
|
|
|
* Invoke the returned function to run the assertions. This
|
|
|
|
* function has a `count` property which can be used to
|
|
|
|
* reference how many assertions will be run (e.g. for use
|
|
|
|
* with `assert.expect()`).
|
|
|
|
*/
|
2016-08-03 15:27:03 -04:00
|
|
|
assertEl(assert, el, spec) {
|
|
|
|
const attrs = spec.attrs ? Object.keys(spec.attrs) : [];
|
|
|
|
const classes = spec.classes || [];
|
|
|
|
const innerHTML = spec.innerHTML ? spec.innerHTML.trim() : '';
|
|
|
|
const props = spec.props ? Object.keys(spec.props) : [];
|
|
|
|
const tagName = spec.tagName ? spec.tagName.toLowerCase() : '';
|
2015-10-28 13:28:15 -04:00
|
|
|
|
|
|
|
// Return value is a function, which runs through all the combined
|
|
|
|
// assertions. This is done so that the count can be attached dynamically
|
|
|
|
// and run whenever desired.
|
2016-08-03 15:27:03 -04:00
|
|
|
const run = () => {
|
2015-10-28 13:28:15 -04:00
|
|
|
if (tagName) {
|
2016-08-03 15:27:03 -04:00
|
|
|
const elTagName = el.tagName.toLowerCase();
|
|
|
|
const msg = `el should have been a <${tagName}> and was a <${elTagName}>`;
|
|
|
|
|
2015-10-28 13:28:15 -04:00
|
|
|
assert.strictEqual(elTagName, tagName, msg);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (innerHTML) {
|
2016-08-03 15:27:03 -04:00
|
|
|
const elInnerHTML = el.innerHTML.trim();
|
|
|
|
const msg = 'el should have expected HTML content';
|
|
|
|
|
2015-10-28 13:28:15 -04:00
|
|
|
assert.strictEqual(elInnerHTML, innerHTML, msg);
|
|
|
|
}
|
|
|
|
|
|
|
|
attrs.forEach(a => {
|
2016-08-03 15:27:03 -04:00
|
|
|
const actual = el.getAttribute(a);
|
|
|
|
const expected = spec.attrs[a];
|
|
|
|
const msg = `el should have the "${a}" attribute with ` +
|
|
|
|
`the value "${expected}" and it was "${actual}"`;
|
|
|
|
|
2015-10-28 13:28:15 -04:00
|
|
|
assert.strictEqual(actual, expected, msg);
|
|
|
|
});
|
|
|
|
|
|
|
|
classes.forEach(c => {
|
2016-08-03 15:27:03 -04:00
|
|
|
const msg = `el should have the "${c}" class in its ` +
|
|
|
|
`className, which is "${el.className}"`;
|
|
|
|
|
2017-01-19 16:01:56 -05:00
|
|
|
assert.ok(Dom.hasClass(el, c), msg);
|
2015-10-28 13:28:15 -04:00
|
|
|
});
|
|
|
|
|
|
|
|
props.forEach(p => {
|
2016-08-03 15:27:03 -04:00
|
|
|
const actual = el[p];
|
|
|
|
const expected = spec.props[p];
|
|
|
|
const msg = `el should have the "${p}" property with the ` +
|
|
|
|
`value "${expected}" and it was "${actual}"`;
|
|
|
|
|
2015-10-28 13:28:15 -04:00
|
|
|
assert.strictEqual(actual, expected, msg);
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
// Include the number of assertions to run, so it can be used to set
|
|
|
|
// expectations (via `assert.expect()`).
|
2016-08-03 15:27:03 -04:00
|
|
|
run.count = Number(!!tagName) +
|
2015-10-28 13:28:15 -04:00
|
|
|
Number(!!innerHTML) +
|
|
|
|
classes.length +
|
|
|
|
attrs.length +
|
|
|
|
props.length;
|
|
|
|
|
|
|
|
return run;
|
2016-11-23 19:54:48 +01:00
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
2019-07-29 23:45:40 +02:00
|
|
|
* Creates an event.
|
2016-11-23 19:54:48 +01:00
|
|
|
*
|
2019-07-29 23:45:40 +02:00
|
|
|
* @param {string} eventType
|
2016-11-23 19:54:48 +01:00
|
|
|
*/
|
2019-07-29 23:45:40 +02:00
|
|
|
createEvent(eventType) {
|
2016-12-02 14:17:36 -05:00
|
|
|
let event;
|
|
|
|
|
|
|
|
if (document.createEvent) {
|
|
|
|
event = document.createEvent('HTMLEvents');
|
|
|
|
event.initEvent(eventType, true, true);
|
|
|
|
} else {
|
|
|
|
event = document.createEventObject();
|
|
|
|
event.eventType = eventType;
|
|
|
|
}
|
|
|
|
|
|
|
|
event.eventName = eventType;
|
|
|
|
|
2019-07-29 23:45:40 +02:00
|
|
|
return event;
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Triggers an event on a DOM node natively.
|
|
|
|
*
|
|
|
|
* @param {Element} element
|
|
|
|
* @param {string} eventType
|
|
|
|
*/
|
|
|
|
triggerDomEvent(element, eventType) {
|
|
|
|
const event = TestHelpers.createEvent(eventType);
|
|
|
|
|
2016-12-02 14:17:36 -05:00
|
|
|
if (document.createEvent) {
|
|
|
|
element.dispatchEvent(event);
|
|
|
|
} else {
|
|
|
|
element.fireEvent('on' + event.eventType, event);
|
2016-11-23 19:54:48 +01:00
|
|
|
}
|
2014-10-16 12:59:41 -07:00
|
|
|
}
|
|
|
|
};
|
2015-03-25 21:43:41 -07:00
|
|
|
|
2015-05-03 16:12:38 -07:00
|
|
|
export default TestHelpers;
|