De promotiewebsite die de reguliere site vervangt tijdens de Kick-In. https://join.harambee.utwente.nl
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
kick-in-promo-site/tests/unit/callbacks.js

416 lines
18 KiB

// onSlideLeave
// ---------------------------------------
QUnit.test('Testing onSlideLeave callback fullpage-moveSlideRight', function(assert) {
var id = '#fullpage-moveSlideRight';
var FP = initFullpageNew(id, Object.assign({}, sectionsAndSlidesCallbacks, {scrollingSpeed: 50, v2compatible:true}));
var done = assert.async(3);
var i;
var cont = 0;
for(i = 0; i < 3; i++, cont++){
setTimeout(afterMove.bind(null, i), cont * 100);
}
function afterMove(i){
FP.moveSlideRight();
assert.equal(onSlideLeave, 'null, 1, '+ i +', right, ' + (i+1) + '', 'We expect the right values for the callback');
done();
}
});
QUnit.test('Testing onSlideLeave callback fullpage-moveSlideRight with anchors', function(assert) {
var id = '#fullpage-moveSlideRight';
var FP = initFullpageNew(id, Object.assign({scrollingSpeed: 50}, allBasicOptions, sectionsAndSlidesCallbacks, {v2compatible:true}));
var done = assert.async(3);
var i;
var cont = 0;
for(i = 0; i < 3; i++, cont++){
setTimeout(afterMove.bind(null, i), cont * 100);
}
function afterMove(i){
FP.moveSlideRight();
assert.equal(onSlideLeave, 'page1, 1, '+ i +', right, ' + (i+1) + '', 'We expect the right values for the callback');
done();
}
});
QUnit.test('Testing onSlideLeave callback fullpage-moveSlideLeft', function(assert) {
var id = '#fullpage-moveSlideLeft';
var FP = initFullpageNew(id, Object.assign({}, sectionsAndSlidesCallbacks, {scrollingSpeed: 50, v2compatible:true}));
var done = assert.async(3);
var i;
var cont = 0;
for(i = 2; i >= 0; i--, cont++){
setTimeout(afterMove.bind(null, i), cont * 100);
}
function afterMove(i){
FP.moveSlideLeft();
assert.equal(onSlideLeave, 'null, 1, '+ (i+1) +', left, ' + i + '', 'We expect the right values for the callback');
done();
}
});
QUnit.test('Testing onSlideLeave from last slide to first with loopHorizontal', function(assert) {
var id = '#fullpage-moveSlideLeft';
var FP = initFullpageNew(id, Object.assign({scrollingSpeed: 50}, sectionsAndSlidesCallbacks, {loopHorizontal: true, v2compatible:true}));
FP.moveSlideRight();
assert.equal(onSlideLeave, 'null, 1, 3, right, 0', 'We expect the right values for the callback');
});
QUnit.test('Testing onSlideLeave from 1st slide to last', function(assert) {
var id = '#fullpage-moveSlideRight';
var FP = initFullpageNew(id, Object.assign({}, sectionsAndSlidesCallbacks, {loopHorizontal: true, v2compatible:true}));
FP.moveSlideLeft();
assert.equal(onSlideLeave, 'null, 1, 0, left, 3', 'We expect the right values for the callback');
});
// afterSlideLoad
// ---------------------------------------
QUnit.test('Testing afterSlideLoad callback', function(assert) {
var id = '#fullpage-moveSlideRight';
var FP = initFullpageNew(id, Object.assign({}, sectionsAndSlidesCallbacks, {scrollingSpeed: 50, v2compatible:true}));
var done = assert.async(1);
FP.moveSlideRight();
assert.equal(slideLoaded[0], false, 'We expect slide 1.1 to not be loaded');
assert.equal(slideLoaded[1], false, 'We expect slide 1.2 to not be loaded');
assert.equal(areOthersLoaded(slideLoaded), 0, 'We expect 0 slides to be loaded');
setTimeout(function(){
assert.equal(slideLoaded[1], true, 'We expect slide 1.2 to be loaded');
assert.equal(areOthersLoaded(slideLoaded), 1, 'We expect only 1 slide to be loaded');
assert.equal(afterSlideLoad, 'null, 1, slide2, 1', 'We expect the right values for the callback');
done();
}, 100);
});
QUnit.test('Testing afterSlideLoad callback with anchors', function(assert) {
var id = '#fullpage-moveSlideRight';
var FP = initFullpageNew(id, Object.assign({scrollingSpeed:50}, allBasicOptions, sectionsAndSlidesCallbacks, {v2compatible:true}));
var done = assert.async(1);
FP.moveSlideRight();
setTimeout(function(){
assert.equal(afterSlideLoad, 'page1, 1, slide2, 1', 'We expect the right values for the callback');
done();
}, 100);
});
//this test should be reviewed.
//at the moment the afterSlideLoad callback doesn't get fired on page load, no matter what
//section is active by default. But... Probably it should...
QUnit.test('Testing afterSlideLoad callback with active 2nd section and 1st slide active', function(assert) {
var id = '#fullpage-first-slide-active-in-2nd-active-section';
var FP = initFullpageNew(id, Object.assign({}, sectionsAndSlidesCallbacks, {scrollingSpeed: 50, v2compatible:true}));
assert.equal(slideLoaded[1], false, 'We expect section 2 to not be loaded');
assert.equal(areOthersLoaded(slideLoaded), 0, 'We expect 0 slides to be loaded');
assert.equal(afterSlideLoad, '', 'We expect no values for the callback');
});
//this test should be reviewed.
//at the moment the afterSlideLoad callback doesn't get fired on page load, no matter what
//section is active by default. But... Probably it should...
QUnit.test('Testing afterSlideLoad callback with active 2nd section and middle slide active', function(assert) {
var id = '#fullpage-middle-slide-active-in-2nd-active-section';
var FP = initFullpageNew(id, Object.assign({}, sectionsAndSlidesCallbacks, {scrollingSpeed: 50, v2compatible:true}));
assert.equal(slideLoaded[1], false, 'We expect middle slide to not be loaded');
assert.equal(areOthersLoaded(slideLoaded), 0, 'We expect 0 slides to be loaded');
assert.equal(afterSlideLoad, '', 'We expect no values for the afterSlideLoad callback');
});
//this test should be reviewed.
//at the moment the afterSlideLoad callback doesn't get fired on page load, no matter what
//section is active by default. But... Probably it should...
QUnit.test('Testing afterSlideLoad callback with active 2nd section and single slide active', function(assert) {
var id = '#fullpage-single-slide-in-second-section';
var FP = initFullpageNew(id, Object.assign({}, sectionsAndSlidesCallbacks, {scrollingSpeed: 50, v2compatible:true}));
assert.equal(slideLoaded[0], false, 'We expect the single slide to not be loaded');
assert.equal(areOthersLoaded(slideLoaded), 0, 'We expect 0 sections to be loaded');
assert.equal(afterSlideLoad, '', 'We expect no values for the callback');
});
// afterRender
// ---------------------------------------
QUnit.test('Testing afterRender callback with section', function(assert) {
var id = '#fullpage';
var FP = initFullpageNew(id, Object.assign({}, sectionsAndSlidesCallbacks, {scrollingSpeed: 50, v2compatible:true}));
assert.equal(sectionLoaded[0], true, 'We expect section 1 be loaded');
assert.equal(areOthersLoaded(sectionLoaded), 1, 'We expect only 1 section to be loaded');
});
QUnit.test('Testing afterRender callback with slides', function(assert) {
var id = '#fullpage-moveSlideRight';
var FP = initFullpageNew(id, Object.assign({}, sectionsAndSlidesCallbacks, {scrollingSpeed: 50, v2compatible:true}));
assert.deepEqual(afterRender, [0, 0], 'We expect Section 0.0 be loaded');
});
QUnit.test('Testing afterRender callback on fullpage-2nd-active-section', function(assert) {
var id = '#fullpage-2nd-active-section';
var FP = initFullpageNew(id, Object.assign({}, sectionsAndSlidesCallbacks, {scrollingSpeed: 50, v2compatible:true}));
assert.deepEqual(afterRender, [1, -1], 'We expect Section 1 be loaded');
});
QUnit.test('Testing afterRender callback on fullpage-middle-slide-active-in-2nd-active-section', function(assert) {
var id = '#fullpage-2nd-active-section';
var FP = initFullpageNew(id, Object.assign({}, sectionsAndSlidesCallbacks, {scrollingSpeed: 50, v2compatible:true}));
assert.deepEqual(afterRender, [1, -1], 'We expect Section 1.1 be loaded');
});
QUnit.test('Testing afterRender callback on fullpage-first-slide-active-in-2nd-active-section', function(assert) {
var id = '#fullpage-first-slide-active-in-2nd-active-section';
var FP = initFullpageNew(id, Object.assign({}, sectionsAndSlidesCallbacks, {scrollingSpeed: 50, v2compatible:true}));
assert.deepEqual(afterRender, [1, 0], 'We expect Section 1.0 be loaded');
});
QUnit.test('Testing afterRender callback on fullpage-sigle-slide-active-in-2nd-active-section', function(assert) {
var id = '#fullpage-sigle-slide-active-in-2nd-active-section';
var FP = initFullpageNew(id, Object.assign({}, sectionsAndSlidesCallbacks, {scrollingSpeed: 50, v2compatible:true}));
assert.deepEqual(afterRender, [1, 0], 'We expect Section 1.0 be loaded');
});
// afterLoad
// ---------------------------------------
QUnit.test('Testing afterLoad callback on scroll with section', function(assert) {
var id = '#fullpage-no-slides';
var done = assert.async(2);
var FP = initFullpageNew(id, Object.assign({}, sectionsAndSlidesCallbacks, {scrollingSpeed: 50, v2compatible:true}));
FP.moveSectionDown();
setTimeout(function(){
assert.equal(sectionLoaded[1], true, 'We expect section 2 be loaded');
assert.equal(areOthersLoaded(sectionLoaded), 1, 'We expect only 2 section to be loaded');
assert.equal(afterLoad, 'null, 2', 'We expect the right values for the callback');
done();
FP.moveSectionDown();
}, 100);
setTimeout(function(){
assert.equal(sectionLoaded[2], true, 'We expect section 3 be loaded');
assert.equal(areOthersLoaded(sectionLoaded), 1, 'We expect only section 3 to be loaded');
assert.equal(afterLoad, 'null, 3', 'We expect the right values for the callback');
done();
}, 100*2);
});
QUnit.test('Testing afterLoad callback on scroll with section and anchors', function(assert) {
var id = '#fullpage-sections-and-slides-with-data-anchor';
var done = assert.async(1);
var FP = initFullpageNew(id, Object.assign({}, sectionsAndSlidesCallbacks, {scrollingSpeed: 50, v2compatible:true}));
FP.moveSectionDown();
setTimeout(function(){
assert.equal(afterLoad, 'page2, 2', 'We expect the right values for the callback');
done();
}, 100);
});
QUnit.test('Testing afterLoad when autoScrolling:false on scroll with section', function(assert) {
var id = '#fullpage-no-slides';
var done = assert.async(2);
var FP = initFullpageNew(id, Object.assign({}, sectionsAndSlidesCallbacks, {scrollingSpeed: 50, autoScrolling: false, v2compatible: true}));
simulateScroll(window.innerHeight);
setTimeout(function(){
assert.equal(sectionLoaded[1], true, 'We expect section 2 be loaded');
assert.equal(areOthersLoaded(sectionLoaded), 1, 'We expect only 2 section to be loaded');
assert.equal(afterLoad, 'null, 2', 'We expect the right values for the callback');
done();
simulateScroll(window.innerHeight * 2);
}, 100);
setTimeout(function(){
assert.equal(sectionLoaded[2], true, 'We expect section 3 be loaded');
assert.equal(areOthersLoaded(sectionLoaded), 1, 'We expect only section 3 to be loaded');
assert.equal(afterLoad, 'null, 3', 'We expect the right values for the callback');
done();
}, 100*2);
});
QUnit.test('Testing afterLoad when autoScrolling:false on scroll with section and anchors', function(assert) {
var id = '#fullpage-sections-and-slides-with-data-anchor';
var done = assert.async(1);
var FP = initFullpageNew(id, Object.assign({}, sectionsAndSlidesCallbacks, {scrollingSpeed: 50, autoScrolling: false, v2compatible: true}));
simulateScroll(window.innerHeight);
setTimeout(function(){
assert.equal(afterLoad, 'page2, 2', 'We expect the right values for the callback');
done();
}, 100);
});
//this test should be reviewed.
//at the moment the afterLoad callback doesn't get fired on page load, no matter what
//section is active by default. But... Probably it should...
//Same as afterSlideLoad on section change
QUnit.test('Testing afterLoad callback with fullpage-2nd-active-section', function(assert) {
var id = '#fullpage-2nd-active-section';
var FP = initFullpageNew(id, Object.assign({}, sectionsAndSlidesCallbacks, {scrollingSpeed: 50, v2compatible:true}));
assert.equal(sectionLoaded[1], false, 'We expect section 2 to not be loaded');
assert.equal(areOthersLoaded(sectionLoaded), 0, 'We expect 0 slides to be loaded');
assert.equal(afterLoad, '', 'We expect no values for the callback');
});
//this test should be reviewed.
//at the moment the afterLoad callback doesn't get fired on page load, no matter what
//section is active by default. But... Probably it should...
//Same as afterSlideLoad on section change
QUnit.test('Testing afterLoad callback with fullpage-first-slide-active-in-2nd-section', function(assert) {
var id = '#fullpage-first-slide-active-in-2nd-section';
var FP = initFullpageNew(id, Object.assign({}, sectionsAndSlidesCallbacks, {scrollingSpeed: 50, v2compatible:true}));
assert.equal(sectionLoaded[0], true, 'We expect section 1 to be loaded');
assert.equal(areOthersLoaded(sectionLoaded), 1, 'We expect 0 sections to be loaded');
assert.equal(afterLoad, 'null, 1', 'We expect no values for the callback');
});
//this test should be reviewed.
//CALLBACKS ARE NOT CONSISTENT. Rather we fire afterload on all page loads or in none.
//This one is firing while none of the others are
QUnit.test('Testing afterLoad callback with fullpage-middle-slide-active-in-2nd-section', function(assert) {
var id = '#fullpage-middle-slide-active-in-2nd-section';
var FP = initFullpageNew(id, Object.assign({}, sectionsAndSlidesCallbacks, {scrollingSpeed: 50, v2compatible:true}));
assert.equal(sectionLoaded[1], false, 'We expect section 2 be loaded');
assert.equal(areOthersLoaded(sectionLoaded), 1, 'We expect only 2 section to be loaded');
assert.equal(afterLoad, 'null, 1', 'We expect the right values for the callback');
});
// onLeave
// ---------------------------------------
QUnit.test('Testing onLeave callback on scroll with section', function(assert) {
var id = '#fullpage-no-slides';
var done = assert.async(2);
var FP = initFullpageNew(id, Object.assign({}, sectionsAndSlidesCallbacks, {scrollingSpeed: 50, v2compatible:true}));
FP.moveSectionDown();
setTimeout(function(){
assert.equal(sectionLoaded[0], false, 'We expect section 1 to not be loaded anymore');
assert.equal(onLeave, '1, 2, down', 'We expect the right values for the callback');
done();
FP.moveSectionDown();
}, 100);
setTimeout(function(){
assert.equal(sectionLoaded[1], false, 'We expect section 2 to not be loaded anymore');
assert.equal(onLeave, '2, 3, down', 'We expect the right values for the callback');
done();
}, 100*2);
});
QUnit.test('Testing onLeave does not get fired on page load', function(assert) {
var id = '#fullpage-no-slides';
var FP = initFullpageNew(id, Object.assign({}, sectionsAndSlidesCallbacks, {scrollingSpeed: 50, v2compatible:true}));
assert.equal(onLeave, '', 'We expect no values for the callback');
});
QUnit.test('Testing onLeave when autoScrolling:false', function(assert) {
var id = '#fullpage';
var done = assert.async(2);
var FP = initFullpageNew(id, Object.assign({}, sectionsAndSlidesCallbacks, {scrollingSpeed: 50, autoScrolling:false, v2compatible: true}));
//simulating scroll event
simulateScroll(window.innerHeight);
setTimeout(function(){
assert.equal(sectionLoaded[0], false, 'We expect section 1 to not be loaded anymore');
assert.equal(onLeave, '1, 2, down', 'We expect the right values for the callback');
done();
simulateScroll(window.innerHeight * 2);
}, 100);
setTimeout(function(){
assert.equal(sectionLoaded[1], false, 'We expect section 2 to not be loaded anymore');
assert.equal(onLeave, '2, 3, down', 'We expect the right values for the callback');
done();
}, 100*2);});
QUnit.test('Testing onLeave when autoScrolling:false with section and anchors', function(assert) {
var id = '#fullpage-sections-and-slides-with-data-anchor';
var done = assert.async(1);
var FP = initFullpageNew(id, Object.assign({}, sectionsAndSlidesCallbacks, {scrollingSpeed: 50, autoScrolling:false, v2compatible: true}));
simulateScroll(window.innerHeight);
setTimeout(function(){
assert.equal(afterLoad, 'page2, 2', 'We expect the right values for the callback');
done();
}, 100);
});
// afterResponsive
// ---------------------------------------
QUnit.test('Testing afterResponsive', function(assert) {
var id = '#fullpage';
var FP = initFullpageNew(id, Object.assign({}, sectionsAndSlidesCallbacks, {scrollingSpeed: 50, v2compatible:true}));
assert.equal(afterResponsive, false, 'We expect afterResponsive callback was not fired');
FP.setResponsive(true);
assert.equal(afterResponsive, true, 'We expect afterResponsive callback to be fired with true value');
FP.setResponsive(false);
assert.equal(afterResponsive, false, 'We expect afterResponsive callback to be fired with false value');
});
// afterResize
// ---------------------------------------
QUnit.test('Testing afterResize', function(assert) {
var id = '#fullpage';
var done = assert.async(1);
var FP = initFullpageNew(id, Object.assign({}, sectionsAndSlidesCallbacks, {scrollingSpeed: 50, v2compatible:true}));
window.dispatchEvent(new Event('resize'));
assert.equal(afterResize, false, 'We expect afterResize to not get fired synchronously');
setTimeout(function(){
assert.equal(afterResize, true, 'We expect afterResize to get fired with some delay');
done();
}, 450);
});
// afterReBuild
// ---------------------------------------
QUnit.test('Testing afterReBuild', function(assert) {
var id = '#fullpage';
var FP = initFullpageNew(id, Object.assign({}, sectionsAndSlidesCallbacks, {scrollingSpeed: 50, v2compatible:true}));
assert.equal(afterReBuild, false, 'We expect afterReBuild to not get fired by default');
FP.reBuild();
assert.equal(afterReBuild, true, 'We expect afterReBuild to get fired synchronously');
});