(function (Ply) { module('Ply.effects'); test('core', function () { Ply.effects.defaults = { duration: 300, open: {}, close: {} }; deepEqual(Ply.effects.get(), { open: { layer: { duration: 300 }, overlay: { duration: 300 } }, close: { layer: { duration: 300 }, overlay: { duration: 300 } }, duration: 300 }, 'def'); deepEqual(Ply.effects.get(['fade-in', 'fade-out']), { open: { layer: { name: 'fade-in', duration: 300 }, overlay: { name: 'fade-in', duration: 300 } }, close: { layer: { name: 'fade-out', duration: 300 }, overlay: { name: 'fade-out', duration: 300 } }, duration: 300 }, "['fade-in', 'fade-out']"); deepEqual(Ply.effects.get(['fade-in', 'fade-out:100']), { open: { layer: { name: 'fade-in', duration: 300 }, overlay: { name: 'fade-in', duration: 300 } }, close: { layer: { name: 'fade-out', duration: 100 }, overlay: { name: 'fade-out', duration: 100 } }, duration: 300 }, "['fade-in', 'fade-out:100']"); deepEqual(Ply.effects.get('fade:100'), { open: { layer: { name: 'fade-in', duration: 100 * 0.8 }, overlay: { name: 'fade-in', duration: 100 } }, close: { layer: { name: 'fade-out', duration: 100 * 0.6 }, overlay: { name: 'fade-out', duration: 100 * 0.6 } }, duration: 100 }, 'fade:100'); deepEqual(Ply.effects.get({ open: 'slide-in', close: 'slide-out' }), { open: { layer: { name: 'slide-in', duration: 300 }, overlay: { duration: 300 } }, close: { layer: { name: 'slide-out', duration: 300 }, overlay: { duration: 300 } }, duration: 300 }, 'slide-in-out'); Ply.effects.setup({ open: 'fade-in' }); deepEqual(Ply.effects.get(), { open: { layer: { name: 'fade-in', duration: 300 }, overlay: { duration: 300 } }, close: { layer: { duration: 300 }, overlay: { duration: 300 } }, duration: 300 }, 'open.fade-in'); Ply.effects.setup({ open: { overlay: 'fade-in' } }); deepEqual(Ply.effects.get({ open: 'slide-in', close: 'slide-out' }), { open: { layer: { name: 'slide-in', duration: 300 }, overlay: { name: 'fade-in', duration: 300 } }, close: { layer: { name: 'slide-out', duration: 300 }, overlay: { duration: 300 } }, duration: 300 }); Ply.effects.setup('fade:400'); deepEqual(Ply.effects.get({ open: 'slide-in', close: 'slide-out' }), { open: { layer: { name: 'slide-in', duration: 400 }, overlay: { name: 'fade-in', duration: 400 } }, close: { layer: { name: 'slide-out', duration: 400 }, overlay: { name: 'fade-out', duration: 400 * 0.6 } }, duration: 400 }, 'fade:400'); }); test('effects[args]:duration', function () { Ply.effects.defaults = { duration: 300, open: {}, close: {} }; deepEqual(Ply.effects.get('scale[0.5,0.3]'), { open: { args: 0.5, layer: { name: 'scale-in', duration: 300 }, overlay: { name: 'fade-in', duration: 300 } }, close: { args: 0.3, layer: { name: 'scale-out', duration: 300 }, overlay: { name: 'fade-out', duration: 300 } }, duration: 300 }); deepEqual(Ply.effects.get(['scale["foo"]', 'fall[{"bar":"baz"}]']), { open: { args: 'foo', layer: { name: 'scale-in', duration: 300 }, overlay: { name: 'fade-in', duration: 300 } }, close: { args: {bar:'baz'}, layer: { name: 'fall-out', duration: 300 }, overlay: { name: 'fade-out', duration: 300 } }, duration: 300 }); }); test('stress', function () { try { Ply.effects.get(null); Ply.effects.get(void 0); Ply.effects.get(Math.random()); Ply.effects.get('---'); Ply.effects.get(123); Ply.effects.get('\n'); Ply.effects.get([null, null]); Ply.effects.get([void 0, void 0]); Ply.effects.get(['\n', '\t']); ok(true); } catch (err) { equal([err, err.stack], null); } }); promiseTest('fade', function () { var log = { open: [], close: [] }, type = 'open', pid, i, layer = new Ply('fade', { effect: 'fade' }) ; pid = setInterval(function () { log[type].push( parseFloat(Ply.css(layer.overlayEl, 'opacity')) ); }, 50); return layer.open().then(function () { type = 'close'; ok(layer.layerEl.offsetHeight > 0, '> 0'); return layer.close(); }).then(function () { ok(layer.layerEl.offsetHeight == 0, '== 0'); if (Ply.support.transition) { ok(log.open.length > 2, 'open'); ok(log.close.length > 2, 'close'); for (i = 1; i < log.open.length; i++) { if (log.open[i] < log.open[i-1]) { equal(log.open, null, 'open: ' + i); break; } } for (i = 1; i < log.close.length; i++) { if (log.close[i] > log.close[i-1]) { equal(log.close, null, 'close: ' + i); break; } } } clearInterval(pid); }); }); promiseTest('other', function () { expect(0); var queue = Ply.promise(function (resolve) { resolve() }); Ply.each('scale fall slide 3d-flip 3d-sign'.split(' '), function (name) { queue = queue.then(function () { return new Ply(name, { effect: name + ':50' }).open().then(function (layer) { return layer.close(); }); }); }); return queue; }); })(Ply);