Files
fullcalendar/tests/automated/select-method.js
T
2014-09-04 14:37:09 +01:00

199 lines
7.4 KiB
JavaScript

describe('select method', function() {
var options;
beforeEach(function() {
affix('#cal');
options = {
defaultDate: '2014-05-25',
selectable: true
};
});
afterEach(function() {
$('#cal').fullCalendar('destroy');
});
/*
THINGS TO IMPLEMENT IN SRC (in addition to notes further down):
- better date normalization (for both render and reporting to select callback)
- if second date is the same or before the first
- if given a mixture of timed/all-day
- for basic/month views, when given timed dates, should really be all-day
*/
[ false, true ].forEach(function(isRTL) {
describe('when isRTL is ' + isRTL, function() {
beforeEach(function() {
options.isRTL = isRTL;
});
describe('when in month view', function() {
beforeEach(function() {
options.defaultView = 'month';
});
describe('when called with all-day moments', function() {
describe('when in bounds', function() {
it('renders a selection', function() {
$('#cal').fullCalendar(options);
$('#cal').fullCalendar('select', '2014-05-07', '2014-05-09');
expect($('.fc-cell-overlay')).toBeVisible();
});
it('renders a selection when called with one argument', function() {
$('#cal').fullCalendar(options);
$('#cal').fullCalendar('select', '2014-05-07');
expect($('.fc-cell-overlay')).toBeVisible();
});
it('fires a selection event', function() {
options.select = function(start, end) {
expect(start.hasTime()).toEqual(false);
expect(end.hasTime()).toEqual(false);
expect(start).toEqualMoment('2014-05-07');
expect(end).toEqualMoment('2014-05-09');
};
spyOn(options, 'select').and.callThrough();
$('#cal').fullCalendar(options);
$('#cal').fullCalendar('select', '2014-05-07', '2014-05-09');
expect(options.select).toHaveBeenCalled();
});
});
describe('when out of bounds', function() {
it('doesn\'t render a selection', function() {
$('#cal').fullCalendar(options);
$('#cal').fullCalendar('select', '2015-05-07', '2015-05-09');
expect($('.fc-cell-overlay')).not.toBeVisible();
});
/*
TODO: implement this behavior
it('doesn\'t fire a selection event', function() {
options.select = function(start, end) {
expect(start).toEqualMoment('2014-05-07');
expect(end).toEqualMoment('2014-05-09');
};
spyOn(options, 'select').and.callThrough();
$('#cal').fullCalendar(options);
$('#cal').fullCalendar('select', '2015-05-07', '2015-05-09');
expect(options.select).not.toHaveBeenCalled();
});
*/
});
});
describe('when called with timed moments', function() {
it('renders a selection', function() {
$('#cal').fullCalendar(options);
$('#cal').fullCalendar('select', '2014-05-07T06:00:00', '2014-05-09T07:00:00');
expect($('.fc-cell-overlay')).toBeVisible();
});
it('fires a selection event', function() {
options.select = function(start, end) {
expect(start.hasTime()).toEqual(true);
expect(end.hasTime()).toEqual(true);
expect(start).toEqualMoment('2014-05-07T06:00:00');
expect(end).toEqualMoment('2014-05-09T06:00:00');
};
spyOn(options, 'select').and.callThrough();
$('#cal').fullCalendar(options);
$('#cal').fullCalendar('select', '2014-05-07T06:00:00', '2014-05-09T06:00:00');
expect(options.select).toHaveBeenCalled();
});
});
});
describe('when in agendaWeek view', function() { // May 25 - 31
beforeEach(function() {
options.defaultView = 'agendaWeek';
options.scrollTime = '01:00:00'; // so that most events will be below the divider
});
describe('when called with timed moments', function() {
describe('when in bounds', function() {
it('renders a selection when called with one argument', function() {
$('#cal').fullCalendar(options);
$('#cal').fullCalendar('select', '2014-05-26T06:00:00');
expect($('.fc-cell-overlay')).toBeVisible();
});
it('renders a selection over the slot area', function() {
$('#cal').fullCalendar(options);
$('#cal').fullCalendar('select', '2014-05-26T06:00:00', '2014-05-26T08:00:00');
expect($('.fc-cell-overlay')).toBeVisible();
var slotArea = $('.fc-agenda-slots').parent().parent();
var slotAreaTop = slotArea.offset().top;
var overlayTop = $('.fc-cell-overlay').offset().top;
expect(overlayTop).toBeGreaterThan(slotAreaTop);
});
});
describe('when out of bounds', function() {
it('doesn\'t render a selection', function() {
$('#cal').fullCalendar(options);
$('#cal').fullCalendar('select', '2015-05-26T06:00:00', '2015-05-26T07:00:00');
expect($('.fc-cell-overlay')).not.toBeVisible();
});
/*
TODO: implement this behavior
it('doesn\'t fire a selection event', function() {
options.select = function(start, end) {
expect(start).toEqualMoment('2015-05-07T06:00:00');
expect(end).toEqualMoment('2015-05-09T07:00:00');
};
spyOn(options, 'select').and.callThrough();
$('#cal').fullCalendar(options);
$('#cal').fullCalendar('select', '2015-05-07T06:00:00', '2015-05-09T07:00:00');
expect(options.select).not.toHaveBeenCalled();
});
*/
});
});
describe('when called with all-day moments', function() { // forget about in/out bounds for this :)
describe('when allDaySlot is on', function() {
beforeEach(function() {
options.allDaySlot = true;
});
it('renders a selection over the day area', function() {
$('#cal').fullCalendar(options);
$('#cal').fullCalendar('select', '2014-05-26', '2014-05-28');
expect($('.fc-cell-overlay')).toBeVisible();
var slotArea = $('.fc-agenda-slots').parent().parent();
var slotAreaTop = slotArea.offset().top;
var overlayTop = $('.fc-cell-overlay').offset().top;
expect(overlayTop).toBeLessThan(slotAreaTop);
});
it('fires a selection event', function() {
options.select = function(start, end) {
expect(start.hasTime()).toEqual(false);
expect(end.hasTime()).toEqual(false);
expect(start).toEqualMoment('2014-05-26');
expect(end).toEqualMoment('2014-05-28');
};
spyOn(options, 'select').and.callThrough();
$('#cal').fullCalendar(options);
$('#cal').fullCalendar('select', '2014-05-26', '2014-05-28');
expect(options.select).toHaveBeenCalled();
});
});
describe('when allDaySlot is off', function() {
beforeEach(function() {
options.allDaySlot = false;
});
it('doesn\'t render', function() {
$('#cal').fullCalendar(options);
$('#cal').fullCalendar('select', '2014-05-26', '2014-05-28');
expect($('.fc-cell-overlay')).not.toBeVisible();
});
/*
TODO: implement
it('doesn\'t fire a selection event', function() {
options.select = function(start, end) {
expect(start.hasTime()).toEqual(false);
expect(end.hasTime()).toEqual(false);
expect(start).toEqualMoment('2014-05-26');
expect(end).toEqualMoment('2014-05-28');
};
spyOn(options, 'select').and.callThrough();
$('#cal').fullCalendar(options);
$('#cal').fullCalendar('select', '2014-05-26', '2014-05-28');
expect(options.select).not.toHaveBeenCalled();
});
*/
});
});
});
});
});
});