Files
atom/spec/stdlib/template-spec.coffee
2012-01-11 13:16:10 -08:00

115 lines
4.3 KiB
CoffeeScript

Template = require 'template'
describe "Template", ->
describe "toView", ->
view = null
beforeEach ->
subviewTemplate = class extends Template
content: (params) ->
@div =>
@h2 { outlet: "header" }, params.title
@div "I am a subview"
template = class extends Template
content: (attrs) ->
@div keydown: 'viewClicked', class: 'rootDiv', =>
@h1 { outlet: 'header' }, attrs.title
@list()
@subview 'subview', subviewTemplate.build(title: "Subview")
list: ->
@ol =>
@li outlet: 'li1', click: 'li1Clicked', class: 'foo', "one"
@li outlet: 'li2', keypress:'li2Keypressed', class: 'bar', "two"
viewProperties:
initialize: (attrs) ->
@initializeCalledWith = attrs
foo: "bar",
li1Clicked: ->,
li2Keypressed: ->
viewClicked: ->
view = template.build(title: "Zebra")
describe ".build(attributes)", ->
it "generates markup based on the content method", ->
expect(view).toMatchSelector "div"
expect(view.find("h1:contains(Zebra)")).toExist()
expect(view.find("ol > li.foo:contains(one)")).toExist()
expect(view.find("ol > li.bar:contains(two)")).toExist()
it "extends the view with viewProperties, calling the 'constructor' property if present", ->
expect(view.constructor).toBeDefined()
expect(view.foo).toBe("bar")
expect(view.initializeCalledWith).toEqual title: "Zebra"
it "wires references for elements with 'outlet' attributes", ->
expect(view.li1).toMatchSelector "li.foo:contains(one)"
expect(view.li2).toMatchSelector "li.bar:contains(two)"
it "constructs and wires outlets for subviews", ->
expect(view.subview).toExist()
expect(view.subview.find('h2:contains(Subview)')).toExist()
it "does not overwrite outlets on the superview with outlets from the subviews", ->
expect(view.header).toMatchSelector "h1"
expect(view.subview.header).toMatchSelector "h2"
it "binds events for elements with event name attributes", ->
spyOn(view, 'viewClicked').andCallFake (event, elt) ->
expect(event.type).toBe 'keydown'
expect(elt).toMatchSelector "div.rootDiv"
spyOn(view, 'li1Clicked').andCallFake (event, elt) ->
expect(event.type).toBe 'click'
expect(elt).toMatchSelector 'li.foo:contains(one)'
spyOn(view, 'li2Keypressed').andCallFake (event, elt) ->
expect(event.type).toBe 'keypress'
expect(elt).toMatchSelector "li.bar:contains(two)"
view.keydown()
expect(view.viewClicked).toHaveBeenCalled()
view.li1.click()
expect(view.li1Clicked).toHaveBeenCalled()
expect(view.li2Keypressed).not.toHaveBeenCalled()
view.li1Clicked.reset()
view.li2.keypress()
expect(view.li2Keypressed).toHaveBeenCalled()
expect(view.li1Clicked).not.toHaveBeenCalled()
it "makes the original jquery wrapper accessible via the view method from any child element", ->
expect(view.view()).toBe view
expect(view.header.view()).toBe view
expect(view.subview.view()).toBe view.subview
expect(view.subview.header.view()).toBe view.subview
describe "$.fn.bindKey", ->
describe "when passed a key pattern and a method name", ->
it "calls the named method on the parent view when a keydown event matches the pattern", ->
view.someMethod = jasmine.createSpy('someMethod')
view.li1.bindKey 'ctrl+m', 'someMethod'
view.li1.trigger window.keydownEvent('meta+z')
expect(view.someMethod).not.toHaveBeenCalled()
view.li1.trigger window.keydownEvent('ctrl+m')
expect(view.someMethod).toHaveBeenCalled()
describe "when passed a key pattern and a function", ->
it "calls the given function when a keydown event matches the pattern", ->
action = jasmine.createSpy('someMethod')
view.li1.bindKey 'ctrl+m', action
view.li1.trigger window.keydownEvent('meta+z')
expect(action).not.toHaveBeenCalled()
view.li1.trigger window.keydownEvent('ctrl+m')
expect(action).toHaveBeenCalled()