diff options
Diffstat (limited to 'spec/data.js')
-rw-r--r-- | spec/data.js | 35 |
1 files changed, 19 insertions, 16 deletions
diff --git a/spec/data.js b/spec/data.js index eab80ef..bb90df5 100644 --- a/spec/data.js +++ b/spec/data.js @@ -85,22 +85,6 @@ describe('data', function() { equals("Hello undefined", result, "@foo as a parameter retrieves template data"); }); - it("parameter data throws when using this scope references", function() { - var string = "{{#goodbyes}}{{text}} cruel {{@./name}}! {{/goodbyes}}"; - - shouldThrow(function() { - CompilerContext.compile(string); - }, Error); - }); - - it("parameter data throws when using parent scope references", function() { - var string = "{{#goodbyes}}{{text}} cruel {{@../name}}! {{/goodbyes}}"; - - shouldThrow(function() { - CompilerContext.compile(string); - }, Error); - }); - it("parameter data throws when using complex scope references", function() { var string = "{{#goodbyes}}{{text}} cruel {{@foo/../name}}! {{/goodbyes}}"; @@ -251,4 +235,23 @@ describe('data', function() { equals('hello', result); }); }); + + describe('nesting', function() { + it('the root context can be looked up via @root', function() { + var template = CompilerContext.compile('{{#helper}}{{#helper}}{{@./depth}} {{@../depth}} {{@../../depth}}{{/helper}}{{/helper}}'); + var result = template({foo: 'hello'}, { + helpers: { + helper: function(options) { + var frame = Handlebars.createFrame(options.data); + frame.depth = options.data.depth + 1; + return options.fn(this, {data: frame}); + } + }, + data: { + depth: 0 + } + }); + equals('2 1 0', result); + }); + }); }); |