123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395 |
- 'use strict';
- require('jsdom-global')();
- const chai = require('chai');
- const dom = require('../mock/dom');
- const mixitup = require('../../dist/mixitup.js');
- chai.use(require('chai-shallow-deep-equal'));
- chai.use(require('chai-as-promised'));
- describe('mixitup.Mixer', () => {
- describe('#insert()', () => {
- it('should accept an element as an argument', () => {
- let container = dom.getContainer();
- let mixer = mixitup(container);
- let newTarget = dom.getTarget();
- return mixer.insert(newTarget)
- .then(state => {
- chai.assert.equal(state.show[0].id, 7);
- mixer.destroy();
- });
- });
- it('should accept an element and an index as arguments', () => {
- let container = dom.getContainer();
- let mixer = mixitup(container);
- let newTarget = dom.getTarget();
- return mixer.insert(newTarget, 3)
- .then(state => {
- chai.assert.equal(state.show[3].id, 7);
- mixer.destroy();
- });
- });
- it('should accept an html string as an argument', () => {
- let container = dom.getContainer();
- let mixer = mixitup(container);
- let newTarget = dom.getTarget();
- return mixer.insert(newTarget.outerHTML)
- .then(state => {
- chai.assert.equal(state.show[0].id, 7);
- mixer.destroy();
- });
- });
- it('should accept an html and an index as arguments', () => {
- let container = dom.getContainer();
- let mixer = mixitup(container);
- let newTarget = dom.getTarget();
- return mixer.insert(newTarget.outerHTML, 5)
- .then(state => {
- chai.assert.equal(state.show[5].id, 7);
- mixer.destroy();
- });
- });
- it('should accept accept an element collection as an argument', () => {
- let container = dom.getContainer();
- let mixer = mixitup(container);
- let newTarget1 = dom.getTarget();
- let newTarget2 = dom.getTarget();
- newTarget2.id = '8';
- return mixer.insert([newTarget1, newTarget2])
- .then(state => {
- chai.assert.equal(state.show[0].id, 7);
- chai.assert.equal(state.show[1].id, 8);
- mixer.destroy();
- });
- });
- it('should accept accept a document fragment as an argument', () => {
- let container = dom.getContainer();
- let mixer = mixitup(container);
- let newTarget = dom.getTarget();
- let frag = document.createDocumentFragment();
- frag.appendChild(newTarget);
- return mixer.insert(frag)
- .then(state => {
- chai.assert.equal(state.show[0].id, 7);
- mixer.destroy();
- });
- });
- it('should accept accept an element collection and an index as an argument', () => {
- let container = dom.getContainer();
- let mixer = mixitup(container);
- let newTarget1 = dom.getTarget();
- let newTarget2 = dom.getTarget();
- newTarget2.id = '8';
- return mixer.insert([newTarget1, newTarget2], 4)
- .then(state => {
- chai.assert.equal(state.show[4].id, 7);
- chai.assert.equal(state.show[5].id, 8);
- mixer.destroy();
- });
- });
- it('should throw an error if an element, index and sibling are passed simultaneously', () => {
- let container = dom.getContainer();
- let mixer = mixitup(container);
- let newTarget = dom.getTarget();
- let sibling = container.children[4];
- chai.assert.throws(() => {
- mixer.insert(newTarget, 4, sibling);
- }, Error, mixitup.messages.errorInsertInvalidArguments());
- });
- it('should accept an element and sibling reference to insert before', () => {
- let container = dom.getContainer();
- let mixer = mixitup(container);
- let newTarget = dom.getTarget();
- let sibling = container.children[4];
- return mixer.insert(newTarget, sibling)
- .then(state => {
- chai.assert.equal(state.show[4].id, '7');
- mixer.destroy();
- });
- });
- it('should accept an element, sibling reference and position string', () => {
- let container = dom.getContainer();
- let mixer = mixitup(container);
- let newTarget = dom.getTarget();
- let sibling = container.children[4];
- return mixer.insert(newTarget, sibling, 'after')
- .then(state => {
- chai.assert.equal(state.show[5].id, '7');
- mixer.destroy();
- });
- });
- it('should insert at end if the insertion index is above range', () => {
- let container = dom.getContainer();
- let mixer = mixitup(container);
- let newTarget = dom.getTarget();
- return mixer.insert(newTarget, 10)
- .then(state => {
- chai.assert.equal(state.show[6].id, '7');
- mixer.destroy();
- });
- });
- it('should insert at start if the insertion index is below range', () => {
- let container = dom.getContainer();
- let mixer = mixitup(container);
- let newTarget = dom.getTarget();
- return mixer.insert(newTarget, -2)
- .then(state => {
- chai.assert.equal(state.show[0].id, '7');
- mixer.destroy();
- });
- });
- it('should throw an error if the element to insert already exists', () => {
- let container = dom.getContainer();
- let mixer = mixitup(container);
- let newTarget = container.children[1];
- chai.assert.throws(() => {
- mixer.insert(newTarget);
- }, Error, mixitup.messages.errorInsertPreexistingElement());
- });
- it('should allow no elements to be inserted with a warning', () => {
- let container = dom.getContainer();
- let totalTargets = container.children.length;
- let mixer = mixitup(container);
- return mixer.insert()
- .then(state => {
- chai.assert.equal(state.totalShow, totalTargets);
- mixer.destroy();
- });
- });
- it('should accept a callback function which is invoked after insertion', () => {
- let container = dom.getContainer();
- let mixer = mixitup(container);
- let newTarget = dom.getTarget();
- let promise = new Promise(resolve => mixer.insert(newTarget, resolve));
- chai.assert.isFulfilled(promise);
- return promise
- .then(() => {
- chai.assert.equal(newTarget.parentElement, container);
- mixer.destroy();
- });
- });
- it('should accept a boolean allowing toggling off of animation', () => {
- let container = dom.getContainer();
- let mixer = mixitup(container);
- let newTarget = dom.getTarget();
- return mixer.insert(newTarget, false)
- .then(() => {
- chai.assert.equal(newTarget.parentElement, container);
- mixer.destroy();
- });
- });
- it('should accept a HTML with padding whitespace as an argument', () => {
- let container = dom.getContainer();
- let mixer = mixitup(container);
- let newTarget = ' ' + dom.getTarget().outerHTML + ' ';
- return mixer.insert(newTarget)
- .then(state => {
- chai.assert.equal(state.show[0].id, 7);
- mixer.destroy();
- });
- });
- });
- describe('#prepend()', () => {
- it('should insert an element at the start', () => {
- let container = dom.getContainer();
- let mixer = mixitup(container);
- let newTarget = dom.getTarget();
- return mixer.prepend(newTarget)
- .then(state => {
- chai.assert.equal(state.show[0].id, 7);
- mixer.destroy();
- });
- });
- it('should insert a collection of elements at the start', () => {
- let container = dom.getContainer();
- let mixer = mixitup(container);
- let newTarget1 = dom.getTarget();
- let newTarget2 = dom.getTarget();
- newTarget2.id = '8';
- return mixer.prepend([newTarget1, newTarget2])
- .then(state => {
- chai.assert.equal(state.show[0].id, 7);
- chai.assert.equal(state.show[1].id, 8);
- mixer.destroy();
- });
- });
- });
- describe('#append()', () => {
- it('should insert an element at the end', () => {
- let container = dom.getContainer();
- let mixer = mixitup(container);
- let newTarget = dom.getTarget();
- return mixer.append(newTarget)
- .then(state => {
- chai.assert.equal(state.show[6].id, 7);
- mixer.destroy();
- });
- });
- it('should insert a collection of elements at the end', () => {
- let container = dom.getContainer();
- let mixer = mixitup(container);
- let newTarget1 = dom.getTarget();
- let newTarget2 = dom.getTarget();
- newTarget2.id = '8';
- return mixer.append([newTarget1, newTarget2])
- .then(state => {
- chai.assert.equal(state.show[6].id, 7);
- chai.assert.equal(state.show[7].id, 8);
- mixer.destroy();
- });
- });
- it('should accept accept a document fragment as an argument to append', () => {
- let container = dom.getContainer();
- let mixer = mixitup(container);
- let newTarget = dom.getTarget();
- let frag = document.createDocumentFragment();
- frag.appendChild(newTarget);
- return mixer.append(frag)
- .then(state => {
- chai.assert.equal(state.show[6].id, 7);
- mixer.destroy();
- });
- });
- });
- describe('#insertBefore()', () => {
- it('should insert an element before the referenced element', () => {
- let container = dom.getContainer();
- let mixer = mixitup(container);
- let newTarget = dom.getTarget();
- let sibling = container.children[3];
- return mixer.insertBefore(newTarget, sibling)
- .then(state => {
- chai.assert.equal(state.show[3].id, 7);
- mixer.destroy();
- });
- });
- it('should insert a collection of elements before the referenced element', () => {
- let container = dom.getContainer();
- let mixer = mixitup(container);
- let newTarget1 = dom.getTarget();
- let newTarget2 = dom.getTarget();
- let sibling = container.children[3];
- newTarget2.id = '8';
- return mixer.insertBefore([newTarget1, newTarget2], sibling)
- .then(state => {
- chai.assert.equal(state.show[3].id, 7);
- chai.assert.equal(state.show[4].id, 8);
- mixer.destroy();
- });
- });
- });
- describe('#insertAfter()', () => {
- it('should insert an element after the referenced element', () => {
- let container = dom.getContainer();
- let mixer = mixitup(container);
- let newTarget = dom.getTarget();
- let sibling = container.children[3];
- return mixer.insertAfter(newTarget, sibling)
- .then(state => {
- chai.assert.equal(state.show[4].id, 7);
- mixer.destroy();
- });
- });
- it('should insert a collection of elements after the referenced element', () => {
- let container = dom.getContainer();
- let mixer = mixitup(container);
- let newTarget1 = dom.getTarget();
- let newTarget2 = dom.getTarget();
- let sibling = container.children[3];
- newTarget2.id = '8';
- return mixer.insertAfter([newTarget1, newTarget2], sibling)
- .then(state => {
- chai.assert.equal(state.show[4].id, 7);
- chai.assert.equal(state.show[5].id, 8);
- mixer.destroy();
- });
- });
- });
- });
|