$(function () { module('affix plugin') test('should be defined on jquery object', function () { ok($(document.body).affix, 'affix method is defined') }) module('affix', { setup: function() { // Run all tests in noConflict mode -- it's the only way to ensure that the plugin works in noConflict mode $.fn.bootstrapAffix = $.fn.affix.noConflict() }, teardown: function() { $.fn.affix = $.fn.bootstrapAffix delete $.fn.bootstrapAffix } }) test('should provide no conflict', function () { ok(!$.fn.affix, 'affix was set back to undefined (org value)') }) test('should return element', function () { ok($(document.body).bootstrapAffix()[0] == document.body, 'document.body returned') }) test('should exit early if element is not visible', function () { var $affix = $('
').bootstrapAffix() $affix.data('bs.affix').checkPosition() ok(!$affix.hasClass('affix'), 'affix class was not added') }) test('should trigger affixed event after affix', function () { stop() var template = $('
') template.appendTo('body') $('#affixTarget').bootstrapAffix({ offset: $('#affixTarget ul').position() }) $('#affixTarget') .on('affix.bs.affix', function () { ok(true, 'affix event triggered') }).on('affixed.bs.affix', function () { ok(true,'affixed event triggered') $('#affixTarget').remove() $('#affixAfter').remove() start() }) setTimeout(function () { window.scrollTo(0, document.body.scrollHeight) setTimeout(function () { window.scroll(0,0) }, 0) },0) }) })