module('Keyboard Navigation 2011', { setup: function(){ /* Tests start with picker on March 31, 2011. Fun facts: * March 1, 2011 was on a Tuesday * March 31, 2011 was on a Thursday */ this.input = $('') .appendTo('#qunit-fixture') .datepicker({format: "dd-mm-yyyy"}) .focus(); // Activate for visibility checks this.dp = this.input.data('datepicker') this.picker = this.dp.picker; }, teardown: function(){ this.picker.remove(); } }); test('Regression: by week (up/down arrows); up from Mar 6, 2011 should go to Feb 27, 2011', function(){ var target; this.input.val('06-03-2011').datepicker('update'); equal(this.dp.viewMode, 0); target = this.picker.find('.datepicker-days thead th.datepicker-switch'); equal(target.text(), 'March 2011', 'Title is "March 2011"'); datesEqual(this.dp.viewDate, UTCDate(2011, 2, 6)); datesEqual(this.dp.dates.get(-1), UTCDate(2011, 2, 6)); equal(this.dp.focusDate, null); // Navigation: -1 week, up arrow key this.input.trigger({ type: 'keydown', keyCode: 38 }); datesEqual(this.dp.viewDate, UTCDate(2011, 1, 27)); datesEqual(this.dp.dates.get(-1), UTCDate(2011, 2, 6)); datesEqual(this.dp.focusDate, UTCDate(2011, 1, 27)); target = this.picker.find('.datepicker-days thead th.datepicker-switch'); equal(target.text(), 'February 2011', 'Title is "February 2011"'); }); test('Regression: by day (left/right arrows); left from Mar 1, 2011 should go to Feb 28, 2011', function(){ var target; this.input.val('01-03-2011').datepicker('update'); equal(this.dp.viewMode, 0); target = this.picker.find('.datepicker-days thead th.datepicker-switch'); equal(target.text(), 'March 2011', 'Title is "March 2011"'); datesEqual(this.dp.viewDate, UTCDate(2011, 2, 1)); datesEqual(this.dp.dates.get(-1), UTCDate(2011, 2, 1)); equal(this.dp.focusDate, null); // Navigation: -1 day left arrow key this.input.trigger({ type: 'keydown', keyCode: 37 }); datesEqual(this.dp.viewDate, UTCDate(2011, 1, 28)); datesEqual(this.dp.dates.get(-1), UTCDate(2011, 2, 1)); datesEqual(this.dp.focusDate, UTCDate(2011, 1, 28)); target = this.picker.find('.datepicker-days thead th.datepicker-switch'); equal(target.text(), 'February 2011', 'Title is "February 2011"'); }); test('Regression: by month (shift + left/right arrows); left from Mar 15, 2011 should go to Feb 15, 2011', function(){ var target; this.input.val('15-03-2011').datepicker('update'); equal(this.dp.viewMode, 0); target = this.picker.find('.datepicker-days thead th.datepicker-switch'); equal(target.text(), 'March 2011', 'Title is "March 2011"'); datesEqual(this.dp.viewDate, UTCDate(2011, 2, 15)); datesEqual(this.dp.dates.get(-1), UTCDate(2011, 2, 15)); equal(this.dp.focusDate, null); // Navigation: -1 month, shift + left arrow key this.input.trigger({ type: 'keydown', keyCode: 37, shiftKey: true }); datesEqual(this.dp.viewDate, UTCDate(2011, 1, 15)); datesEqual(this.dp.dates.get(-1), UTCDate(2011, 2, 15)); datesEqual(this.dp.focusDate, UTCDate(2011, 1, 15)); target = this.picker.find('.datepicker-days thead th.datepicker-switch'); equal(target.text(), 'February 2011', 'Title is "February 2011"'); }); test('Regression: by month with view mode = 1 (left/right arrow); left from March 15, 2011 should go to February 15, 2011', function () { this.picker.remove(); this.input = $('') .appendTo('#qunit-fixture') .datepicker({ format: "dd-mm-yyyy", minViewMode: 1, startView: 1 }) .focus(); // Activate for visibility checks this.dp = this.input.data('datepicker'); this.picker = this.dp.picker; this.input.val('15-03-2011').datepicker('update'); equal(this.dp.viewMode, 1); target = this.picker.find('.datepicker-days thead th.datepicker-switch'); equal(target.text(), 'March 2011', 'Title is "March 2011"'); datesEqual(this.dp.viewDate, UTCDate(2011, 2, 15)); datesEqual(this.dp.dates.get(-1), UTCDate(2011, 2, 15)); equal(this.dp.focusDate, null); this.input.trigger({ type: 'keydown', keyCode: 37 }); datesEqual(this.dp.viewDate, UTCDate(2011, 1, 15)); datesEqual(this.dp.dates.get(-1), UTCDate(2011, 2, 15)); datesEqual(this.dp.focusDate, UTCDate(2011, 1, 15)); target = this.picker.find('.datepicker-days thead th.datepicker-switch'); equal(target.text(), 'February 2011', 'Title is "February 2011"'); }); test('Regression: by month with view mode = 1 (up/down arrow); down from March 15, 2011 should go to July 15, 2010', function () { this.picker.remove(); this.input = $('') .appendTo('#qunit-fixture') .datepicker({ format: "dd-mm-yyyy", minViewMode: 1, startView: 1 }) .focus(); // Activate for visibility checks this.dp = this.input.data('datepicker'); this.picker = this.dp.picker; this.input.val('15-03-2011').datepicker('update'); equal(this.dp.viewMode, 1); target = this.picker.find('.datepicker-days thead th.datepicker-switch'); equal(target.text(), 'March 2011', 'Title is "March 2011"'); datesEqual(this.dp.viewDate, UTCDate(2011, 2, 15)); datesEqual(this.dp.dates.get(-1), UTCDate(2011, 2, 15)); equal(this.dp.focusDate, null); this.input.trigger({ type: 'keydown', keyCode: 40 }); datesEqual(this.dp.viewDate, UTCDate(2011, 6, 15)); datesEqual(this.dp.dates.get(-1), UTCDate(2011, 2, 15)); datesEqual(this.dp.focusDate, UTCDate(2011, 6, 15)); target = this.picker.find('.datepicker-days thead th.datepicker-switch'); equal(target.text(), 'July 2011', 'Title is "July 2011"'); }); test('Regression: by year with view mode = 2 (left/right arrow); left from March 15, 2011 should go to March 15, 2010', function () { this.picker.remove(); this.input = $('') .appendTo('#qunit-fixture') .datepicker({ format: "dd-mm-yyyy", minViewMode: 2, startView: 2 }) .focus(); // Activate for visibility checks this.dp = this.input.data('datepicker'); this.picker = this.dp.picker; this.input.val('15-03-2011').datepicker('update'); equal(this.dp.viewMode, 2); target = this.picker.find('.datepicker-days thead th.datepicker-switch'); equal(target.text(), 'March 2011', 'Title is "March 2011"'); datesEqual(this.dp.viewDate, UTCDate(2011, 2, 15)); datesEqual(this.dp.dates.get(-1), UTCDate(2011, 2, 15)); equal(this.dp.focusDate, null); this.input.trigger({ type: 'keydown', keyCode: 37 }); datesEqual(this.dp.viewDate, UTCDate(2010, 2, 15)); datesEqual(this.dp.dates.get(-1), UTCDate(2011, 2, 15)); datesEqual(this.dp.focusDate, UTCDate(2010, 2, 15)); target = this.picker.find('.datepicker-days thead th.datepicker-switch'); equal(target.text(), 'March 2010', 'Title is "March 2010"'); }); test('Regression: by year with view mode = 2 (up/down arrow); dows from March 15, 2011 should go to March 15, 2015', function () { this.picker.remove(); this.input = $('') .appendTo('#qunit-fixture') .datepicker({ format: "dd-mm-yyyy", minViewMode: 2, startView: 2 }) .focus(); // Activate for visibility checks this.dp = this.input.data('datepicker'); this.picker = this.dp.picker; this.input.val('15-03-2011').datepicker('update'); equal(this.dp.viewMode, 2); target = this.picker.find('.datepicker-days thead th.datepicker-switch'); equal(target.text(), 'March 2011', 'Title is "March 2011"'); datesEqual(this.dp.viewDate, UTCDate(2011, 2, 15)); datesEqual(this.dp.dates.get(-1), UTCDate(2011, 2, 15)); equal(this.dp.focusDate, null); this.input.trigger({ type: 'keydown', keyCode: 40 }); datesEqual(this.dp.viewDate, UTCDate(2015, 2, 15)); datesEqual(this.dp.dates.get(-1), UTCDate(2011, 2, 15)); datesEqual(this.dp.focusDate, UTCDate(2015, 2, 15)); target = this.picker.find('.datepicker-days thead th.datepicker-switch'); equal(target.text(), 'March 2015', 'Title is "March 2015"'); });