summaryrefslogtreecommitdiffstats
path: root/spec
diff options
context:
space:
mode:
Diffstat (limited to 'spec')
-rw-r--r--spec/data.js35
-rw-r--r--spec/parser.js4
2 files changed, 23 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);
+ });
+ });
});
diff --git a/spec/parser.js b/spec/parser.js
index 097bb15..ebde171 100644
--- a/spec/parser.js
+++ b/spec/parser.js
@@ -21,6 +21,10 @@ describe('parser', function() {
equals(ast_for("{{@foo}}"), "{{ @ID:foo [] }}\n");
});
+ it('parses simple mustaches with data paths', function() {
+ equals(ast_for("{{@../foo}}"), "{{ @ID:foo [] }}\n");
+ });
+
it('parses mustaches with paths', function() {
equals(ast_for("{{foo/bar}}"), "{{ PATH:foo/bar [] }}\n");
});