Fixed a bug with snippets within blocks

This commit is contained in:
Mario Visic 2011-02-16 17:37:26 +08:00
parent 083debc516
commit 26a2b7d2a7
2 changed files with 41 additions and 9 deletions

View File

@ -15,8 +15,6 @@ class Snippet
after_save :update_templates after_save :update_templates
after_destroy :update_templates after_destroy :update_templates
# TODO: after_save callback to let pages embedding this snippet know about the changes the user has just made.
## validations ## ## validations ##
validates_presence_of :site, :name, :slug, :template validates_presence_of :site, :name, :slug, :template
validates_uniqueness_of :slug, :scope => :site_id validates_uniqueness_of :slug, :scope => :site_id
@ -50,15 +48,14 @@ class Snippet
when Locomotive::Liquid::Tags::Snippet when Locomotive::Liquid::Tags::Snippet
node.refresh(self) if node.slug == self.slug node.refresh(self) if node.slug == self.slug
when Locomotive::Liquid::Tags::InheritedBlock when Locomotive::Liquid::Tags::InheritedBlock
self._change_snippet_inside_template(node.parent) if node.parent _change_snippet_inside_template(node.parent) if node.parent
else end
if node.respond_to?(:nodelist) # Walk the children of this entry if they're available.
(node.nodelist || []).each do |child| if node.respond_to?(:nodelist)
self._change_snippet_inside_template(child) (node.nodelist || []).each do |child|
end self._change_snippet_inside_template(child)
end end
end end
end end
end end

View File

@ -16,4 +16,39 @@ describe Snippet do
end end
end end
describe '#update_templates' do
before :each do
@site = Factory(:site, :subdomain => 'omg')
@snippet = Factory(:snippet, :site => @site, :slug => 'my_test_snippet', :template => 'a testing template')
end
context 'with a normal top level snippet' do
before :each do
@page = Factory(:page, :site => @site, :slug => 'my_page_here', :raw_template => "{% include 'my_test_snippet' %}")
end
it 'updates templates with the new snippet template' do
@snippet.update_attributes(:template => 'a new template')
Page.find(@page.id).render({}).should == 'a new template'
end
end
context 'for snippets inside of a block' do
before :each do
@page = Factory(:page, :site => @site, :slug => 'my_page_here', :raw_template => "{% block main %}{% include 'my_test_snippet' %}{% endblock %}")
end
it 'updates templates with the new snippet template' do
@snippet.update_attributes(:template => 'a new template')
Page.find(@page.id).render({}).should == 'a new template'
end
end
end
end end