import unittest import pystache from pystache import Renderer from examples.nested_context import NestedContext from examples.complex_view import ComplexView from examples.lambdas import Lambdas from examples.template_partial import TemplatePartial from examples.simple import Simple from tests.common import assert_strings class TestSimple(unittest.TestCase): def test_nested_context(self): view = NestedContext() view.template = '{{#foo}}{{thing1}} and {{thing2}} and {{outer_thing}}{{/foo}}{{^foo}}Not foo!{{/foo}}' self.assertEquals(view.render(), "one and foo and two") def test_looping_and_negation_context(self): view = ComplexView() view.template = '{{#item}}{{header}}: {{name}} {{/item}}{{^item}} Shouldnt see me{{/item}}' self.assertEquals(view.render(), "Colors: red Colors: green Colors: blue ") def test_empty_context(self): view = ComplexView() template = '{{#empty_list}}Shouldnt see me {{/empty_list}}{{^empty_list}}Should see me{{/empty_list}}' self.assertEquals(pystache.Renderer().render(template), "Should see me") def test_callables(self): view = Lambdas() view.template = '{{#replace_foo_with_bar}}foo != bar. oh, it does!{{/replace_foo_with_bar}}' self.assertEquals(view.render(), 'bar != bar. oh, it does!') def test_rendering_partial(self): view = TemplatePartial() view.template = '{{>inner_partial}}' self.assertEquals(view.render(), 'Again, Welcome!') view.template = '{{#looping}}{{>inner_partial}} {{/looping}}' self.assertEquals(view.render(), '''Again, Welcome! Again, Welcome! Again, Welcome! ''') def test_non_existent_value_renders_blank(self): view = Simple() template = '{{not_set}} {{blank}}' self.assertEquals(pystache.Renderer().render(template), ' ') def test_template_partial_extension(self): """ Side note: From the spec-- Partial tags SHOULD be treated as standalone when appropriate. In particular, this means that trailing newlines should be removed. """ view = TemplatePartial() view.template_extension = 'txt' assert_strings(self, view.render(), u"""Welcome ------- ## Again, Welcome! ##""")