From 7530654328ae508bdd05d273ba4c4e04c90744b3 Mon Sep 17 00:00:00 2001 From: Igor Minar Date: Sat, 24 Nov 2012 01:47:52 +0100 Subject: feat(jqLite): add triggerHandler() we need triggerHandler() to become jQuery 1.8.x compatible. this is not fully featured triggerHandler() implementation - it doesn't bother creating new DOM events and passing them into the event handlers. this is intentional, we don't need access to the native DOM event for our own purposes and creating these event objects is really tricky. --- test/jqLiteSpec.js | 27 +++++++++++++++++++++++++++ 1 file changed, 27 insertions(+) (limited to 'test') diff --git a/test/jqLiteSpec.js b/test/jqLiteSpec.js index 1a56a343..76a2c5a8 100644 --- a/test/jqLiteSpec.js +++ b/test/jqLiteSpec.js @@ -1091,6 +1091,33 @@ describe('jqLite', function() { }); + describe('triggerHandler', function() { + it('should trigger all registered handlers for an event', function() { + var element = jqLite('poke'), + pokeSpy = jasmine.createSpy('poke'), + clickSpy1 = jasmine.createSpy('clickSpy1'), + clickSpy2 = jasmine.createSpy('clickSpy2'); + + element.bind('poke', pokeSpy); + element.bind('click', clickSpy1); + element.bind('click', clickSpy2); + + expect(pokeSpy).not.toHaveBeenCalled(); + expect(clickSpy1).not.toHaveBeenCalled(); + expect(clickSpy2).not.toHaveBeenCalled(); + + element.triggerHandler('poke'); + expect(pokeSpy).toHaveBeenCalledOnce(); + expect(clickSpy1).not.toHaveBeenCalled(); + expect(clickSpy2).not.toHaveBeenCalled(); + + element.triggerHandler('click'); + expect(clickSpy1).toHaveBeenCalledOnce(); + expect(clickSpy2).toHaveBeenCalledOnce(); + }); + }); + + describe('camelCase', function() { it('should leave non-dashed strings alone', function() { -- cgit v1.2.3