Files
node/first-project/node_modules/derby/test/View.components.mocha.coffee
2012-05-30 23:00:06 -04:00

131 lines
3.5 KiB
CoffeeScript

{expect, calls} = require 'racer/test/util'
{DetachedModel: Model} = require './mocks'
View = require '../lib/View.server'
describe 'App HTML components', ->
it 'supports void components', ->
view = new View
view._init new Model
view.make 'test', 'say "<app:test2>"'
view.make 'test2', 'hi'
expect(view.get 'test').to.equal 'say "hi"'
it 'supports literal attributes', ->
view = new View
view._init new Model
view.make 'test', 'say "<app:test2 message="Howdy">" or "<app:test2>"'
view.make 'test2', '''
{{{#if message}}}
{{{message}}}
{{{else}}}
Yo
{{{/}}}
'''
expect(view.get 'test').to.equal 'say "Howdy" or "Yo"'
it 'macro attributes are case-insensitive', ->
view = new View
view._init new Model
view.make 'test', 'say "<app:test2 messAGE="Howdy">" or "<app:test2>"'
view.make 'test2', '''
{{{#if messAGE}}}
{{{message}}}
{{{else}}}
Yo
{{{/}}}
'''
expect(view.get 'test').to.equal 'say "Howdy" or "Yo"'
it 'supports boolean and numerical attributes', ->
view = new View
view._init new Model
view.make 'test', '<app:test2 show="true"> / <app:test2 num="-4.5"> / <app:test2 show="false">'
view.make 'test2', '''
{{{#if show}}}
Hi
{{{else if equal(num, -4.5)}}}
Got it
{{{else}}}
Nada
{{{/}}}
'''
expect(view.get 'test').to.equal 'Hi / Got it / Nada'
it 'supports variable attributes', ->
view = new View
view._init new Model
view.make 'test', 'say "<app:test2 message="{{myMessage}}">"'
view.make 'test2', '''
{{{#if message}}}
{{{message}}}
{{{else}}}
Yo
{{{/}}}
'''
expect(view.get 'test').to.equal 'say "Yo"'
expect(view.get 'test', myMessage: 'Heyo').to.equal 'say "Heyo"'
it 'supports variable object attributes', ->
view = new View
view._init new Model
view.make 'test', 'say "<app:test2 message="{{myMessage}}">"'
view.make 'test2', '''
{{{#with message}}}
{{text}}
{{{/}}}
'''
expect(view.get 'test', myMessage: {text: 'Heyo'}).to.equal 'say "Heyo"'
it 'supports dot syntax for properties of variable object attributes', ->
view = new View
view._init new Model
view.make 'test', 'say "<app:test2 message="{{myMessage}}">"'
view.make 'test2', '''
{{{message.text}}}
'''
expect(view.get 'test', myMessage: {text: 'Heyo'}).to.equal 'say "Heyo"'
it 'supports bound attributes', ->
view = new View
model = new Model
view._init model
view.make 'test', 'say "<app:test2 message="{myMessage}">"'
view.make 'test2', '''
{{{#if message}}}
{{{message}}}
{{{else}}}
Yo
{{{/}}}
'''
model.set 'myMessage', 'Heyo'
expect(view.get 'test').to.equal 'say "<!--$0--><!--$1-->Heyo<!--$$1--><!--$$0-->"'
it 'supports bound attributes as element attributes', ->
view = new View
model = new Model
view._init model
view.make 'test', 'say "<app:test2 message="{myMessage}">"'
view.make 'test2', '''
<div title={{{message}}}></div>
'''
model.set 'myMessage', 'Heyo'
expect(view.get 'test').to.equal 'say "<div id=$0 title=Heyo></div>"'
it 'supports nonvoid components', ->
view = new View
view._init new Model
view.make 'test', '<ul><app:test2><b>Hi!</b></app:test2></ul>'
view.make 'test2', '<li>{{{content}}}</li>', {nonvoid: null}
expect(view.get 'test').to.equal '<ul><li><b>Hi!</b></li></ul>'