From d574939e2cc18c58178efdccba096cfa0eca82c6 Mon Sep 17 00:00:00 2001 From: Mario Visic Date: Mon, 24 Oct 2011 20:52:43 +0800 Subject: [PATCH 01/28] Added a failing test for paginating has many associations. --- features/engine/has_many.feature | 11 +++++ .../step_definitions/content_types_steps.rb | 1 - features/step_definitions/has_many_steps.rb | 47 +++++++++++++++++++ spec/factories.rb | 5 +- 4 files changed, 62 insertions(+), 2 deletions(-) create mode 100644 features/engine/has_many.feature create mode 100644 features/step_definitions/has_many_steps.rb diff --git a/features/engine/has_many.feature b/features/engine/has_many.feature new file mode 100644 index 00000000..69016d46 --- /dev/null +++ b/features/engine/has_many.feature @@ -0,0 +1,11 @@ +Feature: Has Many Association + As a designer + In order to make dealing with models easier + I want to be able to display other models that have a has many association + + Background: + Given I have the site: "test site" set up + + Scenario: Paginating a has many association + Given I have an "Articles" model which has many "Comments" + Then I should be able to view a paginated list of "Comments" per "Articles" diff --git a/features/step_definitions/content_types_steps.rb b/features/step_definitions/content_types_steps.rb index 6e65375b..d51255c4 100644 --- a/features/step_definitions/content_types_steps.rb +++ b/features/step_definitions/content_types_steps.rb @@ -66,4 +66,3 @@ end Then %r{^I should see once the "([^"]*)" field$} do |field| page.should have_css("#content_#{field.underscore.downcase}_input", :count => 1) end - diff --git a/features/step_definitions/has_many_steps.rb b/features/step_definitions/has_many_steps.rb new file mode 100644 index 00000000..c2b30a78 --- /dev/null +++ b/features/step_definitions/has_many_steps.rb @@ -0,0 +1,47 @@ +Given %r{^I have an? "([^"]*)" model which has many "([^"]*)"$} do |parent_model, child_model| + @parent_model = FactoryGirl.build(:content_type, :site => @site, :name => parent_model).tap do |ct| + ct.content_custom_fields.build :label => 'Body', :kind => 'string', :required => false + ct.save! + end + @child_model = FactoryGirl.build(:content_type, :site => @site, :name => child_model).tap do |ct| + ct.content_custom_fields.build :label => 'Body', :kind => 'string', :required => false + ct.content_custom_fields.build :label => parent_model.singularize, :kind => 'has_one', :required => false, :target => parent_model + ct.save! + end + + @parent_model.content_custom_fields.build({ + :label => child_model, + :kind => 'has_many', + :target => @child_model.content_klass.to_s, + :reverse_lookup => @child_model.content_klass.custom_field_alias_to_name(parent_model.downcase.singularize) + }) +end + +Then /^I should be able to view a paginated list of "([^"]*)" per "([^"]*)"$/ do |parent_model, child_model| + # Create contents + @parent_model.contents.create!(:slug => 'parent', :body => 'Parent') + @child_model.contents.create!(:slug => 'one', :body => 'One') + @child_model.contents.create!(:slug => 'two', :body => 'Two') + @child_model.contents.create!(:slug => 'three', :body => 'Three') + + # Create a page + raw_template = %{ + {% for article in contents.articles %} + {% paginate article.comments by 2 %} + {% for comment in paginate.collection %} + {{ comment.body }} + {% endfor %} + {{ paginate | default_pagination }} + {% endpaginate %} + {% endfor %} + } + + # Create a page + FactoryGirl.create(:page, :site => @site, :slug => 'hello', :raw_template => raw_template) + + # The page should have the first two comments + visit '/hello' + page.should have_content 'one' + page.should have_content 'two' + page.should_not have_content 'three' +end diff --git a/spec/factories.rb b/spec/factories.rb index 22eaf582..3968ccb9 100644 --- a/spec/factories.rb +++ b/spec/factories.rb @@ -138,4 +138,7 @@ FactoryGirl.define do site { Site.where(:subdomain => "acme").first || Factory(:site) } end -end \ No newline at end of file + factory :content_instance do + end + +end From 25441ff60ace2ec3068a4a657303ea355ba0877e Mon Sep 17 00:00:00 2001 From: Mario Visic Date: Mon, 24 Oct 2011 22:35:21 +0800 Subject: [PATCH 02/28] Arrays now paginate correctly. --- lib/locomotive/liquid/drops/array_extension.rb | 5 +++++ lib/locomotive/liquid/drops/base.rb | 17 +++++++++++++++++ lib/locomotive/liquid/drops/contents.rb | 13 ------------- lib/locomotive/liquid/tags/paginate.rb | 1 + lib/locomotive/render.rb | 1 + 5 files changed, 24 insertions(+), 13 deletions(-) create mode 100644 lib/locomotive/liquid/drops/array_extension.rb diff --git a/lib/locomotive/liquid/drops/array_extension.rb b/lib/locomotive/liquid/drops/array_extension.rb new file mode 100644 index 00000000..0584ff8f --- /dev/null +++ b/lib/locomotive/liquid/drops/array_extension.rb @@ -0,0 +1,5 @@ +class Array + def to_liquid + Locomotive::Liquid::Drops::Base.new(self) + end +end diff --git a/lib/locomotive/liquid/drops/base.rb b/lib/locomotive/liquid/drops/base.rb index f5717f5f..7abd618d 100644 --- a/lib/locomotive/liquid/drops/base.rb +++ b/lib/locomotive/liquid/drops/base.rb @@ -30,6 +30,23 @@ module Locomotive records end + def paginate(options = {}) + @collection = self.collection.paginate(options) + { + :collection => @collection, + :current_page => @collection.current_page, + :previous_page => @collection.previous_page, + :next_page => @collection.next_page, + :total_entries => @collection.total_entries, + :total_pages => @collection.total_pages, + :per_page => @collection.per_page + } + end + + def collection + @_source + end + protected def liquify(*records, &block) diff --git a/lib/locomotive/liquid/drops/contents.rb b/lib/locomotive/liquid/drops/contents.rb index 691e5c9f..c0aefc0d 100644 --- a/lib/locomotive/liquid/drops/contents.rb +++ b/lib/locomotive/liquid/drops/contents.rb @@ -63,19 +63,6 @@ module Locomotive protected - def paginate(options = {}) - @collection = self.collection.paginate(options) - { - :collection => @collection, - :current_page => @collection.current_page, - :previous_page => @collection.previous_page, - :next_page => @collection.next_page, - :total_entries => @collection.total_entries, - :total_pages => @collection.total_pages, - :per_page => @collection.per_page - } - end - def collection @collection ||= @content_type.ordered_contents(@context['with_scope']) end diff --git a/lib/locomotive/liquid/tags/paginate.rb b/lib/locomotive/liquid/tags/paginate.rb index eb41575a..31560382 100644 --- a/lib/locomotive/liquid/tags/paginate.rb +++ b/lib/locomotive/liquid/tags/paginate.rb @@ -43,6 +43,7 @@ module Locomotive page_count, current_page = pagination['total_pages'], pagination['current_page'] path = context.registers[:page].fullpath + path = context['path'] pagination['previous'] = link(I18n.t('pagination.previous'), current_page - 1, path) if pagination['previous_page'] pagination['next'] = link(I18n.t('pagination.next'), current_page + 1, path) if pagination['next_page'] diff --git a/lib/locomotive/render.rb b/lib/locomotive/render.rb index d17d2d20..ea52a817 100644 --- a/lib/locomotive/render.rb +++ b/lib/locomotive/render.rb @@ -65,6 +65,7 @@ module Locomotive 'contents' => Locomotive::Liquid::Drops::Contents.new, 'current_page' => self.params[:page], 'params' => self.params, + 'path' => request.path, 'url' => request.url, 'now' => Time.now.utc, 'today' => Date.today From 2bb9f5ed0568c18b5cf4bf047b4e670da7f4d7cb Mon Sep 17 00:00:00 2001 From: Mario Visic Date: Mon, 24 Oct 2011 23:34:43 +0800 Subject: [PATCH 03/28] Revert "Arrays now paginate correctly." This reverts commit 25441ff60ace2ec3068a4a657303ea355ba0877e. --- lib/locomotive/liquid/drops/array_extension.rb | 5 ----- lib/locomotive/liquid/drops/base.rb | 17 ----------------- lib/locomotive/liquid/drops/contents.rb | 13 +++++++++++++ lib/locomotive/liquid/tags/paginate.rb | 1 - lib/locomotive/render.rb | 1 - 5 files changed, 13 insertions(+), 24 deletions(-) delete mode 100644 lib/locomotive/liquid/drops/array_extension.rb diff --git a/lib/locomotive/liquid/drops/array_extension.rb b/lib/locomotive/liquid/drops/array_extension.rb deleted file mode 100644 index 0584ff8f..00000000 --- a/lib/locomotive/liquid/drops/array_extension.rb +++ /dev/null @@ -1,5 +0,0 @@ -class Array - def to_liquid - Locomotive::Liquid::Drops::Base.new(self) - end -end diff --git a/lib/locomotive/liquid/drops/base.rb b/lib/locomotive/liquid/drops/base.rb index 7abd618d..f5717f5f 100644 --- a/lib/locomotive/liquid/drops/base.rb +++ b/lib/locomotive/liquid/drops/base.rb @@ -30,23 +30,6 @@ module Locomotive records end - def paginate(options = {}) - @collection = self.collection.paginate(options) - { - :collection => @collection, - :current_page => @collection.current_page, - :previous_page => @collection.previous_page, - :next_page => @collection.next_page, - :total_entries => @collection.total_entries, - :total_pages => @collection.total_pages, - :per_page => @collection.per_page - } - end - - def collection - @_source - end - protected def liquify(*records, &block) diff --git a/lib/locomotive/liquid/drops/contents.rb b/lib/locomotive/liquid/drops/contents.rb index c0aefc0d..691e5c9f 100644 --- a/lib/locomotive/liquid/drops/contents.rb +++ b/lib/locomotive/liquid/drops/contents.rb @@ -63,6 +63,19 @@ module Locomotive protected + def paginate(options = {}) + @collection = self.collection.paginate(options) + { + :collection => @collection, + :current_page => @collection.current_page, + :previous_page => @collection.previous_page, + :next_page => @collection.next_page, + :total_entries => @collection.total_entries, + :total_pages => @collection.total_pages, + :per_page => @collection.per_page + } + end + def collection @collection ||= @content_type.ordered_contents(@context['with_scope']) end diff --git a/lib/locomotive/liquid/tags/paginate.rb b/lib/locomotive/liquid/tags/paginate.rb index 31560382..eb41575a 100644 --- a/lib/locomotive/liquid/tags/paginate.rb +++ b/lib/locomotive/liquid/tags/paginate.rb @@ -43,7 +43,6 @@ module Locomotive page_count, current_page = pagination['total_pages'], pagination['current_page'] path = context.registers[:page].fullpath - path = context['path'] pagination['previous'] = link(I18n.t('pagination.previous'), current_page - 1, path) if pagination['previous_page'] pagination['next'] = link(I18n.t('pagination.next'), current_page + 1, path) if pagination['next_page'] diff --git a/lib/locomotive/render.rb b/lib/locomotive/render.rb index ea52a817..d17d2d20 100644 --- a/lib/locomotive/render.rb +++ b/lib/locomotive/render.rb @@ -65,7 +65,6 @@ module Locomotive 'contents' => Locomotive::Liquid::Drops::Contents.new, 'current_page' => self.params[:page], 'params' => self.params, - 'path' => request.path, 'url' => request.url, 'now' => Time.now.utc, 'today' => Date.today From e6abd6bbe042f62f0eb1b76be416500de734c9b9 Mon Sep 17 00:00:00 2001 From: Mario Visic Date: Mon, 24 Oct 2011 23:37:39 +0800 Subject: [PATCH 04/28] Path fix for pagination. --- lib/locomotive/liquid/tags/paginate.rb | 2 +- lib/locomotive/render.rb | 1 + 2 files changed, 2 insertions(+), 1 deletion(-) diff --git a/lib/locomotive/liquid/tags/paginate.rb b/lib/locomotive/liquid/tags/paginate.rb index eb41575a..7bac6fcb 100644 --- a/lib/locomotive/liquid/tags/paginate.rb +++ b/lib/locomotive/liquid/tags/paginate.rb @@ -42,7 +42,7 @@ module Locomotive page_count, current_page = pagination['total_pages'], pagination['current_page'] - path = context.registers[:page].fullpath + path = context['path'] pagination['previous'] = link(I18n.t('pagination.previous'), current_page - 1, path) if pagination['previous_page'] pagination['next'] = link(I18n.t('pagination.next'), current_page + 1, path) if pagination['next_page'] diff --git a/lib/locomotive/render.rb b/lib/locomotive/render.rb index d17d2d20..ea52a817 100644 --- a/lib/locomotive/render.rb +++ b/lib/locomotive/render.rb @@ -65,6 +65,7 @@ module Locomotive 'contents' => Locomotive::Liquid::Drops::Contents.new, 'current_page' => self.params[:page], 'params' => self.params, + 'path' => request.path, 'url' => request.url, 'now' => Time.now.utc, 'today' => Date.today From 786d2d969312757d37e4f826c095aa3deab7bb21 Mon Sep 17 00:00:00 2001 From: Mario Visic Date: Mon, 24 Oct 2011 23:44:35 +0800 Subject: [PATCH 05/28] Added will paginate to liquid. --- config/initializers/will_paginate.rb | 1 + .../liquid/drops/will_paginate_extension.rb | 13 +++++++++++++ lib/locomotive/liquid/tags/paginate.rb | 2 +- 3 files changed, 15 insertions(+), 1 deletion(-) create mode 100644 lib/locomotive/liquid/drops/will_paginate_extension.rb diff --git a/config/initializers/will_paginate.rb b/config/initializers/will_paginate.rb index dfed3fe9..e808301f 100644 --- a/config/initializers/will_paginate.rb +++ b/config/initializers/will_paginate.rb @@ -1 +1,2 @@ require 'will_paginate/array' +require 'locomotive/liquid/drops/will_paginate_extension' diff --git a/lib/locomotive/liquid/drops/will_paginate_extension.rb b/lib/locomotive/liquid/drops/will_paginate_extension.rb new file mode 100644 index 00000000..a1d0910e --- /dev/null +++ b/lib/locomotive/liquid/drops/will_paginate_extension.rb @@ -0,0 +1,13 @@ +class WillPaginate::Collection + def to_liquid + { + :collection => self.to_a, + :current_page => current_page, + :previous_page => previous_page, + :next_page => next_page, + :total_entries => total_entries, + :total_pages => total_pages, + :per_page => per_page + } + end +end diff --git a/lib/locomotive/liquid/tags/paginate.rb b/lib/locomotive/liquid/tags/paginate.rb index 7bac6fcb..4844ef93 100644 --- a/lib/locomotive/liquid/tags/paginate.rb +++ b/lib/locomotive/liquid/tags/paginate.rb @@ -38,7 +38,7 @@ module Locomotive pagination = collection.send(:paginate, { :page => context['current_page'], - :per_page => @per_page }).stringify_keys + :per_page => @per_page }).to_liquid.stringify_keys page_count, current_page = pagination['total_pages'], pagination['current_page'] From 4939017f8d114a6b7c191dd76141ed6274814265 Mon Sep 17 00:00:00 2001 From: Mario Visic Date: Sat, 29 Oct 2011 14:35:23 +0800 Subject: [PATCH 06/28] No Site now renders a 404 error, this will prevent indexing of pages that do not exist. --- lib/locomotive/routing/site_dispatcher.rb | 2 +- spec/lib/locomotive/routing/site_dispatcher_spec.rb | 12 ++++++++++-- 2 files changed, 11 insertions(+), 3 deletions(-) diff --git a/lib/locomotive/routing/site_dispatcher.rb b/lib/locomotive/routing/site_dispatcher.rb index 7405be1d..186a5630 100644 --- a/lib/locomotive/routing/site_dispatcher.rb +++ b/lib/locomotive/routing/site_dispatcher.rb @@ -39,7 +39,7 @@ module Locomotive end def render_no_site_error - render :template => '/admin/errors/no_site', :layout => false + render :template => '/admin/errors/no_site', :layout => false, :status => :not_found end def validate_site_membership diff --git a/spec/lib/locomotive/routing/site_dispatcher_spec.rb b/spec/lib/locomotive/routing/site_dispatcher_spec.rb index 6b4a4c6f..43802192 100644 --- a/spec/lib/locomotive/routing/site_dispatcher_spec.rb +++ b/spec/lib/locomotive/routing/site_dispatcher_spec.rb @@ -147,11 +147,19 @@ describe Locomotive::Routing::SiteDispatcher do describe '#render_no_site_error' do - it 'renders the no site template with no layout' do - @controller.expects(:render).with(:template => '/admin/errors/no_site', :layout => false) + before :each do + @controller.instance_variable_set('@_response', ActionDispatch::Response.new) @controller.send(:render_no_site_error) end + it 'should have a no site error message' do + @controller.response.body.should include 'No Site' + end + + it 'should have a 404 not found status' do + @controller.response.should be_not_found + end + end describe '#validate_site_membership' do From fda3382300a237d21ef82cbd31b2c3a842ca4e54 Mon Sep 17 00:00:00 2001 From: Mario Visic Date: Sat, 29 Oct 2011 14:35:23 +0800 Subject: [PATCH 07/28] No Site now renders a 404 error, this will prevent indexing of pages that do not exist. Fixes #237 --- lib/locomotive/routing/site_dispatcher.rb | 2 +- spec/lib/locomotive/routing/site_dispatcher_spec.rb | 12 ++++++++++-- 2 files changed, 11 insertions(+), 3 deletions(-) diff --git a/lib/locomotive/routing/site_dispatcher.rb b/lib/locomotive/routing/site_dispatcher.rb index 7405be1d..186a5630 100644 --- a/lib/locomotive/routing/site_dispatcher.rb +++ b/lib/locomotive/routing/site_dispatcher.rb @@ -39,7 +39,7 @@ module Locomotive end def render_no_site_error - render :template => '/admin/errors/no_site', :layout => false + render :template => '/admin/errors/no_site', :layout => false, :status => :not_found end def validate_site_membership diff --git a/spec/lib/locomotive/routing/site_dispatcher_spec.rb b/spec/lib/locomotive/routing/site_dispatcher_spec.rb index 6b4a4c6f..43802192 100644 --- a/spec/lib/locomotive/routing/site_dispatcher_spec.rb +++ b/spec/lib/locomotive/routing/site_dispatcher_spec.rb @@ -147,11 +147,19 @@ describe Locomotive::Routing::SiteDispatcher do describe '#render_no_site_error' do - it 'renders the no site template with no layout' do - @controller.expects(:render).with(:template => '/admin/errors/no_site', :layout => false) + before :each do + @controller.instance_variable_set('@_response', ActionDispatch::Response.new) @controller.send(:render_no_site_error) end + it 'should have a no site error message' do + @controller.response.body.should include 'No Site' + end + + it 'should have a 404 not found status' do + @controller.response.should be_not_found + end + end describe '#validate_site_membership' do From 732f8f76f3c9767526097cade625491e355f1845 Mon Sep 17 00:00:00 2001 From: did Date: Sun, 30 Oct 2011 14:58:13 +0100 Subject: [PATCH 08/28] revert to bson_ext (1.3.1) because the last versions (1.4.x) have been yanked recently (temporary solution) --- Gemfile | 4 +++- Gemfile.lock | 12 +++++++----- locomotive_cms.gemspec | 6 +++++- 3 files changed, 15 insertions(+), 7 deletions(-) diff --git a/Gemfile b/Gemfile index 5f45c6dc..49049540 100644 --- a/Gemfile +++ b/Gemfile @@ -10,8 +10,10 @@ gem 'warden' gem 'devise', '1.3.4' gem 'devise_bushido_authenticatable', '1.0.0.alpha10', :require => 'devise_cas_authenticatable' +gem 'mongo', '~> 1.3.1' +gem 'bson', '~> 1.3.1' +gem 'bson_ext', '~> 1.3.1' gem 'mongoid', '~> 2.0.2' -gem 'bson_ext', '~> 1.4.0' gem 'locomotive_mongoid_acts_as_tree', '0.1.5.7', :require => 'mongoid_acts_as_tree' gem 'will_paginate', '~> 3.0.0' diff --git a/Gemfile.lock b/Gemfile.lock index 9b2033f1..5a90dfd7 100644 --- a/Gemfile.lock +++ b/Gemfile.lock @@ -42,8 +42,8 @@ GEM autotest (4.4.6) ZenTest (>= 4.4.1) bcrypt-ruby (2.1.4) - bson (1.4.0) - bson_ext (1.4.0) + bson (1.3.1) + bson_ext (1.3.1) builder (2.1.2) bushido (0.0.35) highline (>= 1.6.1) @@ -168,8 +168,8 @@ GEM mimemagic (0.1.8) mimetype-fu (0.1.2) mocha (0.9.12) - mongo (1.4.0) - bson (= 1.4.0) + mongo (1.3.1) + bson (>= 1.3.1) mongoid (2.0.2) activemodel (~> 3.0) mongo (~> 1.3) @@ -285,7 +285,8 @@ DEPENDENCIES ZenTest actionmailer-with-request autotest - bson_ext (~> 1.4.0) + bson (~> 1.3.1) + bson_ext (~> 1.3.1) bushido (= 0.0.35) bushido_stub (= 0.0.3) cancan @@ -316,6 +317,7 @@ DEPENDENCIES locomotive_mongoid_acts_as_tree (= 0.1.5.7) mimetype-fu mocha (= 0.9.12) + mongo (~> 1.3.1) mongoid (~> 2.0.2) pickle rack-cache diff --git a/locomotive_cms.gemspec b/locomotive_cms.gemspec index f1047bd7..4bf0f342 100644 --- a/locomotive_cms.gemspec +++ b/locomotive_cms.gemspec @@ -21,8 +21,12 @@ Gem::Specification.new do |s| s.add_dependency 'warden' s.add_dependency 'devise', '1.3.4' s.add_dependency 'devise_bushido_authenticatable', '1.0.0.alpha10' + + s.add_dependency 'mongo', '~> 1.3.1' + s.add_dependency 'bson', '~> 1.3.1' + s.add_dependency 'bson_ext', '~> 1.3.1' s.add_dependency 'mongoid', '~> 2.0.2' - s.add_dependency 'bson_ext', '~> 1.4.0' + s.add_dependency 'locomotive_mongoid_acts_as_tree', '0.1.5.7' s.add_dependency 'will_paginate', '~> 3.0.0' From 06ab49ecec56b765069829b19de4b2f864dda75f Mon Sep 17 00:00:00 2001 From: Mario Visic Date: Sat, 5 Nov 2011 16:45:43 +1100 Subject: [PATCH 09/28] Replaced will_paginate with kaminari --- Gemfile | 2 +- Gemfile.lock | 5 +++-- config/initializers/will_paginate.rb | 2 -- .../liquid/drops/will_paginate_extension.rb | 13 ------------- locomotive_cms.gemspec | 2 +- spec/lib/locomotive/liquid/tags/paginate_spec.rb | 3 ++- 6 files changed, 7 insertions(+), 20 deletions(-) delete mode 100644 config/initializers/will_paginate.rb delete mode 100644 lib/locomotive/liquid/drops/will_paginate_extension.rb diff --git a/Gemfile b/Gemfile index 5f45c6dc..d5869e29 100644 --- a/Gemfile +++ b/Gemfile @@ -13,7 +13,7 @@ gem 'devise_bushido_authenticatable', '1.0.0.alpha10', :require => 'devise_cas_a gem 'mongoid', '~> 2.0.2' gem 'bson_ext', '~> 1.4.0' gem 'locomotive_mongoid_acts_as_tree', '0.1.5.7', :require => 'mongoid_acts_as_tree' -gem 'will_paginate', '~> 3.0.0' +gem 'kaminari' gem 'haml', '3.1.2' gem 'sass', '3.1.2' diff --git a/Gemfile.lock b/Gemfile.lock index 9b2033f1..c98e769d 100644 --- a/Gemfile.lock +++ b/Gemfile.lock @@ -145,6 +145,8 @@ GEM yui-compressor (>= 0.9.3) json (1.6.1) json_pure (1.6.1) + kaminari (0.12.4) + rails (>= 3.0.0) kgio (2.6.0) launchy (0.3.7) configuration (>= 0.0.5) @@ -270,7 +272,6 @@ GEM raindrops (~> 0.6) warden (1.0.5) rack (>= 1.0) - will_paginate (3.0.2) xpath (0.1.4) nokogiri (~> 1.3) yui-compressor (0.9.6) @@ -309,6 +310,7 @@ DEPENDENCIES highline httparty (= 0.7.8) inherited_resources (~> 1.1.2) + kaminari launchy linecache (= 0.43) locomotive_jammit-s3 @@ -332,5 +334,4 @@ DEPENDENCIES spork (~> 0.9.0.rc) unicorn warden - will_paginate (~> 3.0.0) xpath (~> 0.1.4) diff --git a/config/initializers/will_paginate.rb b/config/initializers/will_paginate.rb deleted file mode 100644 index e808301f..00000000 --- a/config/initializers/will_paginate.rb +++ /dev/null @@ -1,2 +0,0 @@ -require 'will_paginate/array' -require 'locomotive/liquid/drops/will_paginate_extension' diff --git a/lib/locomotive/liquid/drops/will_paginate_extension.rb b/lib/locomotive/liquid/drops/will_paginate_extension.rb deleted file mode 100644 index a1d0910e..00000000 --- a/lib/locomotive/liquid/drops/will_paginate_extension.rb +++ /dev/null @@ -1,13 +0,0 @@ -class WillPaginate::Collection - def to_liquid - { - :collection => self.to_a, - :current_page => current_page, - :previous_page => previous_page, - :next_page => next_page, - :total_entries => total_entries, - :total_pages => total_pages, - :per_page => per_page - } - end -end diff --git a/locomotive_cms.gemspec b/locomotive_cms.gemspec index f1047bd7..0472402a 100644 --- a/locomotive_cms.gemspec +++ b/locomotive_cms.gemspec @@ -24,7 +24,7 @@ Gem::Specification.new do |s| s.add_dependency 'mongoid', '~> 2.0.2' s.add_dependency 'bson_ext', '~> 1.4.0' s.add_dependency 'locomotive_mongoid_acts_as_tree', '0.1.5.7' - s.add_dependency 'will_paginate', '~> 3.0.0' + s.add_dependency 'kaminari' s.add_dependency 'haml', '3.1.2' s.add_dependency 'sass', '3.1.2' diff --git a/spec/lib/locomotive/liquid/tags/paginate_spec.rb b/spec/lib/locomotive/liquid/tags/paginate_spec.rb index 4f63f707..2058320a 100644 --- a/spec/lib/locomotive/liquid/tags/paginate_spec.rb +++ b/spec/lib/locomotive/liquid/tags/paginate_spec.rb @@ -52,7 +52,8 @@ describe Locomotive::Liquid::Tags::Paginate do {}, { 'projects' => options.has_key?(:collection) ? options[:collection] : PaginatedCollection.new(['Ruby on Rails', 'jQuery', 'mongodb', 'Liquid', 'sqlite3']), - 'current_page' => options[:page] || 1 + 'current_page' => options[:page] || 1, + 'path' => '/' }, { :page => FactoryGirl.build(:page) }, true) From c3c5d8e754bfc3b515d0632e2c54d6dc1069059a Mon Sep 17 00:00:00 2001 From: Mario Visic Date: Sat, 5 Nov 2011 18:42:04 +1100 Subject: [PATCH 10/28] Tests are passing for has many pagination with Kaminari. --- features/step_definitions/has_many_steps.rb | 25 +++++++++++++------ lib/locomotive/engine.rb | 2 +- .../liquid/drops/paginatable_array.rb | 13 ++++++++++ lib/locomotive/liquid/tags/paginate.rb | 11 +++++--- 4 files changed, 39 insertions(+), 12 deletions(-) create mode 100644 lib/locomotive/liquid/drops/paginatable_array.rb diff --git a/features/step_definitions/has_many_steps.rb b/features/step_definitions/has_many_steps.rb index c2b30a78..23b4e3ac 100644 --- a/features/step_definitions/has_many_steps.rb +++ b/features/step_definitions/has_many_steps.rb @@ -19,10 +19,14 @@ end Then /^I should be able to view a paginated list of "([^"]*)" per "([^"]*)"$/ do |parent_model, child_model| # Create contents - @parent_model.contents.create!(:slug => 'parent', :body => 'Parent') - @child_model.contents.create!(:slug => 'one', :body => 'One') - @child_model.contents.create!(:slug => 'two', :body => 'Two') - @child_model.contents.create!(:slug => 'three', :body => 'Three') + article = @parent_model.contents.create!(:slug => 'parent', :body => 'Parent') + @child_model.contents.create!(:slug => 'one', :body => 'One', :custom_field_2 => article.id.to_s) + @child_model.contents.create!(:slug => 'two', :body => 'Two', :custom_field_2 => article.id.to_s) + @child_model.contents.create!(:slug => 'three', :body => 'Three', :custom_field_2 => article.id.to_s) + + @child_model.contents.each do |comment| + article.comments << comment + end # Create a page raw_template = %{ @@ -41,7 +45,14 @@ Then /^I should be able to view a paginated list of "([^"]*)" per "([^"]*)"$/ do # The page should have the first two comments visit '/hello' - page.should have_content 'one' - page.should have_content 'two' - page.should_not have_content 'three' + page.should have_content 'One' + page.should have_content 'Two' + page.should_not have_content 'Three' + + + # The second page should have the last comment + click_link '2' + page.should_not have_content 'One' + page.should_not have_content 'Two' + page.should have_content 'Three' end diff --git a/lib/locomotive/engine.rb b/lib/locomotive/engine.rb index 3acea079..a8681c7c 100644 --- a/lib/locomotive/engine.rb +++ b/lib/locomotive/engine.rb @@ -5,7 +5,7 @@ require 'json/pure' require 'devise' require 'mongoid' require 'mongoid_acts_as_tree' -require 'will_paginate' +require 'kaminari' require 'haml' require 'liquid' require 'formtastic' diff --git a/lib/locomotive/liquid/drops/paginatable_array.rb b/lib/locomotive/liquid/drops/paginatable_array.rb new file mode 100644 index 00000000..d5c2e665 --- /dev/null +++ b/lib/locomotive/liquid/drops/paginatable_array.rb @@ -0,0 +1,13 @@ +class Kaminari::PaginatableArray + def to_liquid(options = {}) + { + :collection => self.to_a, + :current_page => current_page, + :previous_page => first_page? ? nil : current_page - 1, + :next_page => last_page? ? nil : current_page + 1, + :total_entries => total_count, + :total_pages => num_pages, + :per_page => limit_value + } + end +end diff --git a/lib/locomotive/liquid/tags/paginate.rb b/lib/locomotive/liquid/tags/paginate.rb index 4844ef93..93f71fa3 100644 --- a/lib/locomotive/liquid/tags/paginate.rb +++ b/lib/locomotive/liquid/tags/paginate.rb @@ -36,10 +36,13 @@ module Locomotive raise ::Liquid::ArgumentError.new("Cannot paginate array '#{@collection_name}'. Not found.") if collection.nil? - pagination = collection.send(:paginate, { - :page => context['current_page'], - :per_page => @per_page }).to_liquid.stringify_keys - + if collection.is_a? Array + pagination = Kaminari.paginate_array(collection).page(context['current_page']).per(@per_page).to_liquid.stringify_keys + else + pagination = collection.send(:paginate, { + :page => context['current_page'], + :per_page => @per_page }).to_liquid.stringify_keys + end page_count, current_page = pagination['total_pages'], pagination['current_page'] path = context['path'] From ad0adc71530111d79d60cd174fc216f30c4fe0c6 Mon Sep 17 00:00:00 2001 From: Mario Visic Date: Sat, 5 Nov 2011 19:10:26 +1100 Subject: [PATCH 11/28] Added a cucumber feature to paginate through models. --- features/engine/pagination.feature | 8 +++++ features/step_definitions/pagination_steps.rb | 35 +++++++++++++++++++ features/step_definitions/site_steps.rb | 4 +++ lib/locomotive/liquid/drops/contents.rb | 11 +----- .../liquid/drops/paginatable_array.rb | 2 +- 5 files changed, 49 insertions(+), 11 deletions(-) create mode 100644 features/engine/pagination.feature create mode 100644 features/step_definitions/pagination_steps.rb diff --git a/features/engine/pagination.feature b/features/engine/pagination.feature new file mode 100644 index 00000000..c9d1317c --- /dev/null +++ b/features/engine/pagination.feature @@ -0,0 +1,8 @@ +Feature: Pagination + As a designer + In order to display a sensible amount of items per page + I want to be able to paginate through models + + Scenario: Paginating through a model + Given I have a site setup + Then I should be able to display paginated models diff --git a/features/step_definitions/pagination_steps.rb b/features/step_definitions/pagination_steps.rb new file mode 100644 index 00000000..b0d53167 --- /dev/null +++ b/features/step_definitions/pagination_steps.rb @@ -0,0 +1,35 @@ +Then /^I should be able to display paginated models$/ do + # Create our article model and three articles + @article_model = FactoryGirl.build(:content_type, :site => @site, :name => 'Articles').tap do |ct| + ct.content_custom_fields.build :label => 'Body', :kind => 'string', :required => false + ct.save! + end + + %w(First Second Third).each do |body| + @article_model.contents.create!(:body => body) + end + + # Create a page with template + raw_template = %{ + {% paginate contents.articles by 2 %} + {% for article in paginate.collection %} + {{ article.body }} + {% endfor %} + {{ paginate | default_pagination }} + {% endpaginate %} + } + FactoryGirl.create(:page, :site => @site, :slug => 'hello', :raw_template => raw_template) + + # The page should have the first two articles + visit '/hello' + page.should have_content 'First' + page.should have_content 'Second' + page.should_not have_content 'Third' + + # The second page should have the last article + click_link '2' + page.should_not have_content 'First' + page.should_not have_content 'Second' + page.should have_content 'Third' +end + diff --git a/features/step_definitions/site_steps.rb b/features/step_definitions/site_steps.rb index 075a451d..9924f9db 100644 --- a/features/step_definitions/site_steps.rb +++ b/features/step_definitions/site_steps.rb @@ -13,6 +13,10 @@ Given /^I have the site: "([^"]*)" set up(?: with #{capture_fields})?$/ do |site @admin.should_not be_nil end +Given /^I have a site setup$/ do + Given %{I have the site: "test site" set up} +end + Given /^I have a designer and an author$/ do FactoryGirl.create(:designer, :site => Site.first) FactoryGirl.create(:author, :site => Site.first) diff --git a/lib/locomotive/liquid/drops/contents.rb b/lib/locomotive/liquid/drops/contents.rb index 691e5c9f..8c46f3fa 100644 --- a/lib/locomotive/liquid/drops/contents.rb +++ b/lib/locomotive/liquid/drops/contents.rb @@ -64,16 +64,7 @@ module Locomotive protected def paginate(options = {}) - @collection = self.collection.paginate(options) - { - :collection => @collection, - :current_page => @collection.current_page, - :previous_page => @collection.previous_page, - :next_page => @collection.next_page, - :total_entries => @collection.total_entries, - :total_pages => @collection.total_pages, - :per_page => @collection.per_page - } + @collection = Kaminari.paginate_array(self.collection).page(options[:page]).per(options[:per_page]) end def collection diff --git a/lib/locomotive/liquid/drops/paginatable_array.rb b/lib/locomotive/liquid/drops/paginatable_array.rb index d5c2e665..5dd738a9 100644 --- a/lib/locomotive/liquid/drops/paginatable_array.rb +++ b/lib/locomotive/liquid/drops/paginatable_array.rb @@ -1,7 +1,7 @@ class Kaminari::PaginatableArray def to_liquid(options = {}) { - :collection => self.to_a, + :collection => to_a, :current_page => current_page, :previous_page => first_page? ? nil : current_page - 1, :next_page => last_page? ? nil : current_page + 1, From 4d9c77d41a2de4b406e26878763287c8730b9f17 Mon Sep 17 00:00:00 2001 From: Mario Visic Date: Sat, 5 Nov 2011 19:17:30 +1100 Subject: [PATCH 12/28] Tidy up cucumbers a tad. --- features/engine/has_many.feature | 7 ++----- features/engine/pagination.feature | 2 +- features/step_definitions/has_many_steps.rb | 5 ++++- features/step_definitions/site_steps.rb | 2 +- 4 files changed, 8 insertions(+), 8 deletions(-) diff --git a/features/engine/has_many.feature b/features/engine/has_many.feature index 69016d46..3d07ea13 100644 --- a/features/engine/has_many.feature +++ b/features/engine/has_many.feature @@ -3,9 +3,6 @@ Feature: Has Many Association In order to make dealing with models easier I want to be able to display other models that have a has many association - Background: - Given I have the site: "test site" set up - Scenario: Paginating a has many association - Given I have an "Articles" model which has many "Comments" - Then I should be able to view a paginated list of "Comments" per "Articles" + Given I have a site set up + Then I should be able to view a paginaed list of a has many association diff --git a/features/engine/pagination.feature b/features/engine/pagination.feature index c9d1317c..6fa8234c 100644 --- a/features/engine/pagination.feature +++ b/features/engine/pagination.feature @@ -4,5 +4,5 @@ Feature: Pagination I want to be able to paginate through models Scenario: Paginating through a model - Given I have a site setup + Given I have a site set up Then I should be able to display paginated models diff --git a/features/step_definitions/has_many_steps.rb b/features/step_definitions/has_many_steps.rb index 23b4e3ac..4d4e5ce0 100644 --- a/features/step_definitions/has_many_steps.rb +++ b/features/step_definitions/has_many_steps.rb @@ -17,7 +17,10 @@ Given %r{^I have an? "([^"]*)" model which has many "([^"]*)"$} do |parent_model }) end -Then /^I should be able to view a paginated list of "([^"]*)" per "([^"]*)"$/ do |parent_model, child_model| +Then /^I should be able to view a paginaed list of a has many association$/ do + # Create models + Given %{I have an "Articles" model which has many "Comments"} + # Create contents article = @parent_model.contents.create!(:slug => 'parent', :body => 'Parent') @child_model.contents.create!(:slug => 'one', :body => 'One', :custom_field_2 => article.id.to_s) diff --git a/features/step_definitions/site_steps.rb b/features/step_definitions/site_steps.rb index 9924f9db..ee03442a 100644 --- a/features/step_definitions/site_steps.rb +++ b/features/step_definitions/site_steps.rb @@ -13,7 +13,7 @@ Given /^I have the site: "([^"]*)" set up(?: with #{capture_fields})?$/ do |site @admin.should_not be_nil end -Given /^I have a site setup$/ do +Given /^I have a site set up$/ do Given %{I have the site: "test site" set up} end From a3f66e19b57dac3979e9978196f874de114f1373 Mon Sep 17 00:00:00 2001 From: did Date: Sat, 5 Nov 2011 15:18:15 +0100 Subject: [PATCH 13/28] fix issue #243 (Kaminari causing error on Bushido) --- lib/locomotive.rb | 1 + lib/locomotive/kaminari.rb | 17 +++++++++++++++++ .../liquid/drops/paginatable_array.rb | 13 ------------- 3 files changed, 18 insertions(+), 13 deletions(-) create mode 100644 lib/locomotive/kaminari.rb delete mode 100644 lib/locomotive/liquid/drops/paginatable_array.rb diff --git a/lib/locomotive.rb b/lib/locomotive.rb index 7d5c812b..71492398 100644 --- a/lib/locomotive.rb +++ b/lib/locomotive.rb @@ -6,6 +6,7 @@ require 'locomotive/core_ext' require 'locomotive/configuration' require 'locomotive/logger' require 'locomotive/dragonfly' +require 'locomotive/kaminari' require 'locomotive/liquid' require 'locomotive/mongoid' require 'locomotive/carrierwave' diff --git a/lib/locomotive/kaminari.rb b/lib/locomotive/kaminari.rb new file mode 100644 index 00000000..d54fa7da --- /dev/null +++ b/lib/locomotive/kaminari.rb @@ -0,0 +1,17 @@ +require 'kaminari' + +module Kaminari + class PaginatableArray < Array + def to_liquid(options = {}) + { + :collection => to_a, + :current_page => current_page, + :previous_page => first_page? ? nil : current_page - 1, + :next_page => last_page? ? nil : current_page + 1, + :total_entries => total_count, + :total_pages => num_pages, + :per_page => limit_value + } + end + end +end diff --git a/lib/locomotive/liquid/drops/paginatable_array.rb b/lib/locomotive/liquid/drops/paginatable_array.rb deleted file mode 100644 index 5dd738a9..00000000 --- a/lib/locomotive/liquid/drops/paginatable_array.rb +++ /dev/null @@ -1,13 +0,0 @@ -class Kaminari::PaginatableArray - def to_liquid(options = {}) - { - :collection => to_a, - :current_page => current_page, - :previous_page => first_page? ? nil : current_page - 1, - :next_page => last_page? ? nil : current_page + 1, - :total_entries => total_count, - :total_pages => num_pages, - :per_page => limit_value - } - end -end From b2bfec1bc4e00e7f441ddd88f2f3a1809f257945 Mon Sep 17 00:00:00 2001 From: Sean Grove Date: Wed, 16 Nov 2011 11:32:00 -0800 Subject: [PATCH 14/28] BUSHIDO_FIX: Adds hooks for user.added and user.removed, updates app.claimed event, switches to using bushido_user_id as permanent unchanging user id --- lib/locomotive/hosting/bushido/account_ext.rb | 5 ++- lib/locomotive/hosting/bushido/enabler.rb | 2 +- lib/locomotive/hosting/bushido/hooks.rb | 32 +++++++++++++++++++ 3 files changed, 35 insertions(+), 4 deletions(-) diff --git a/lib/locomotive/hosting/bushido/account_ext.rb b/lib/locomotive/hosting/bushido/account_ext.rb index 46e42a77..dc32e76c 100644 --- a/lib/locomotive/hosting/bushido/account_ext.rb +++ b/lib/locomotive/hosting/bushido/account_ext.rb @@ -8,7 +8,7 @@ module Locomotive included do - field :bushido_user_id, :type => Integer + field :bushido_user_id, :type => String end @@ -20,7 +20,6 @@ module Locomotive self.update_attributes({ :email => extra_attributes['email'], :name => "#{extra_attributes['first_name']} #{extra_attributes['last_name']}", - :bushido_user_id => extra_attributes['ido_id'], :locale => extra_attributes['locale'], }) end @@ -31,4 +30,4 @@ module Locomotive end end -end \ No newline at end of file +end diff --git a/lib/locomotive/hosting/bushido/enabler.rb b/lib/locomotive/hosting/bushido/enabler.rb index 6ac86d36..5c114499 100644 --- a/lib/locomotive/hosting/bushido/enabler.rb +++ b/lib/locomotive/hosting/bushido/enabler.rb @@ -78,7 +78,7 @@ module Locomotive config.cas_base_url = 'https://auth.bushi.do/cas' config.cas_logout_url = 'https://auth.bushi.do/cas/logout' config.cas_create_user = false - config.cas_username_column = :email + config.cas_username_column = :bushido_user_id end Admin::SessionsController.class_eval do diff --git a/lib/locomotive/hosting/bushido/hooks.rb b/lib/locomotive/hosting/bushido/hooks.rb index 466c23b1..32acb478 100644 --- a/lib/locomotive/hosting/bushido/hooks.rb +++ b/lib/locomotive/hosting/bushido/hooks.rb @@ -10,12 +10,44 @@ module Locomotive def subscribe_to_events ::Bushido::Data.listen('app.claimed') do |event| Locomotive.log "Saving #{Account.first.inspect} with incoming data #{event.inspect}" + Locomotive.log "Devise username column: #{::Devise.cas_username_column}=" + Locomotive.log "Setting username to: #{event['data'].try(:[], 'ido_id')}" account = Account.first account.email = event['data'].try(:[], 'email') account.name = account.email.split('@').first + account.send("#{::Devise.cas_username_column}=".to_sym, event['data'].try(:[], 'ido_id')) account.save end + + ::Bushido::Data.listen('user.added') do |event| + Locomotive.log "Adding a new account with incoming data #{event.inspect}" + Locomotive.log "Devise username column: #{::Devise.cas_username_column}=" + Locomotive.log "Setting username to: #{event['data'].try(:[], 'ido_id')}" + + account = Account.new(:email => event['data'].try(:[], 'email')) + account.name = account.email.split('@').first + account.send("#{::Devise.cas_username_column}=".to_sym, event['data'].try(:[], 'ido_id')) + account.save + + Site.all.each do |site| + site.memberships.create(:account => account) if account.errors.empty? + end + + end + + ::Bushido::Data.listen('user.removed') do |event| + Locomotive.log "Removing account based on incoming data #{event.inspect}" + Locomotive.log "Devise username column: #{::Devise.cas_username_column}=" + Locomotive.log "Removing username: #{event['data'].try(:[], 'ido_id')}" + + ido_id = event['data'].try(:[], 'ido_id') + + ido_id and + Account.exists?(::Devise.cas_username_column => ido_id) and + Account.where(::Devise.cas_username_column => ido_id).destroy + end + end end From 5a4a9f54753ac36108a997bfd09f738480cb563a Mon Sep 17 00:00:00 2001 From: Sean Grove Date: Wed, 16 Nov 2011 11:37:30 -0800 Subject: [PATCH 15/28] BUSHIDO_FIX: Adds bushido hooks user.added user.removed, and updates app.claimed to work with bushido_user_id as the permanent id Conflicts: lib/locomotive/hosting/bushido/hooks.rb --- lib/locomotive/hosting/bushido/hooks.rb | 7 ++----- 1 file changed, 2 insertions(+), 5 deletions(-) diff --git a/lib/locomotive/hosting/bushido/hooks.rb b/lib/locomotive/hosting/bushido/hooks.rb index 32acb478..d0d552a8 100644 --- a/lib/locomotive/hosting/bushido/hooks.rb +++ b/lib/locomotive/hosting/bushido/hooks.rb @@ -41,11 +41,8 @@ module Locomotive Locomotive.log "Devise username column: #{::Devise.cas_username_column}=" Locomotive.log "Removing username: #{event['data'].try(:[], 'ido_id')}" - ido_id = event['data'].try(:[], 'ido_id') - - ido_id and - Account.exists?(::Devise.cas_username_column => ido_id) and - Account.where(::Devise.cas_username_column => ido_id).destroy + Account.exists?(::Devise.cas_username_column => event['data'].try(:[], 'ido_id')) and + Account.where(::Devise.cas_username_column => event['data'].try(:[], 'ido_id')).destroy end end From 43dee9391d6c266209925264d6b12edd1062773a Mon Sep 17 00:00:00 2001 From: Sean Grove Date: Wed, 16 Nov 2011 11:21:01 -0800 Subject: [PATCH 16/28] Uses a more careful approach when removing a user based on the bushido user.removed hook --- lib/locomotive/hosting/bushido/hooks.rb | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/lib/locomotive/hosting/bushido/hooks.rb b/lib/locomotive/hosting/bushido/hooks.rb index d0d552a8..32acb478 100644 --- a/lib/locomotive/hosting/bushido/hooks.rb +++ b/lib/locomotive/hosting/bushido/hooks.rb @@ -41,8 +41,11 @@ module Locomotive Locomotive.log "Devise username column: #{::Devise.cas_username_column}=" Locomotive.log "Removing username: #{event['data'].try(:[], 'ido_id')}" - Account.exists?(::Devise.cas_username_column => event['data'].try(:[], 'ido_id')) and - Account.where(::Devise.cas_username_column => event['data'].try(:[], 'ido_id')).destroy + ido_id = event['data'].try(:[], 'ido_id') + + ido_id and + Account.exists?(::Devise.cas_username_column => ido_id) and + Account.where(::Devise.cas_username_column => ido_id).destroy end end From ed96ab1cf5381bfdc8882396e42b99199eb2d3e9 Mon Sep 17 00:00:00 2001 From: Sean Grove Date: Wed, 16 Nov 2011 11:38:23 -0800 Subject: [PATCH 17/28] BUSHIDO_FIX: Adds bushido hooks user.added user.removed, and updates app.claimed to work with bushido_user_id as the permanent id Conflicts: lib/locomotive/hosting/bushido/hooks.rb --- lib/locomotive/hosting/bushido/hooks.rb | 7 ++----- 1 file changed, 2 insertions(+), 5 deletions(-) diff --git a/lib/locomotive/hosting/bushido/hooks.rb b/lib/locomotive/hosting/bushido/hooks.rb index 32acb478..d0d552a8 100644 --- a/lib/locomotive/hosting/bushido/hooks.rb +++ b/lib/locomotive/hosting/bushido/hooks.rb @@ -41,11 +41,8 @@ module Locomotive Locomotive.log "Devise username column: #{::Devise.cas_username_column}=" Locomotive.log "Removing username: #{event['data'].try(:[], 'ido_id')}" - ido_id = event['data'].try(:[], 'ido_id') - - ido_id and - Account.exists?(::Devise.cas_username_column => ido_id) and - Account.where(::Devise.cas_username_column => ido_id).destroy + Account.exists?(::Devise.cas_username_column => event['data'].try(:[], 'ido_id')) and + Account.where(::Devise.cas_username_column => event['data'].try(:[], 'ido_id')).destroy end end From d1306aec53c7301c54ae9169c53057602d4c59fe Mon Sep 17 00:00:00 2001 From: Sean Grove Date: Wed, 16 Nov 2011 11:39:47 -0800 Subject: [PATCH 18/28] Horrific rebasing strategy, but working code. --- lib/locomotive/hosting/bushido/hooks.rb | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/lib/locomotive/hosting/bushido/hooks.rb b/lib/locomotive/hosting/bushido/hooks.rb index d0d552a8..5e0abd5b 100644 --- a/lib/locomotive/hosting/bushido/hooks.rb +++ b/lib/locomotive/hosting/bushido/hooks.rb @@ -41,8 +41,11 @@ module Locomotive Locomotive.log "Devise username column: #{::Devise.cas_username_column}=" Locomotive.log "Removing username: #{event['data'].try(:[], 'ido_id')}" - Account.exists?(::Devise.cas_username_column => event['data'].try(:[], 'ido_id')) and - Account.where(::Devise.cas_username_column => event['data'].try(:[], 'ido_id')).destroy + ido_id = event['data'].try(:[], 'ido_id') + + ido_id and + Account.exists?(::Devise.cas_username_column => ido_id) and + Account.where(::Devise.cas_username_column => ido_id).destroy end end From ef5caad89796e1600c1a35eade59a845d3184804 Mon Sep 17 00:00:00 2001 From: Sean Grove Date: Wed, 16 Nov 2011 12:04:51 -0800 Subject: [PATCH 19/28] Proper mongoid exists? syntax --- lib/locomotive/hosting/bushido/hooks.rb | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/locomotive/hosting/bushido/hooks.rb b/lib/locomotive/hosting/bushido/hooks.rb index 5e0abd5b..1c41e5ec 100644 --- a/lib/locomotive/hosting/bushido/hooks.rb +++ b/lib/locomotive/hosting/bushido/hooks.rb @@ -44,7 +44,7 @@ module Locomotive ido_id = event['data'].try(:[], 'ido_id') ido_id and - Account.exists?(::Devise.cas_username_column => ido_id) and + Account.exists?(:conditions => {::Devise.cas_username_column => ido_id}) and Account.where(::Devise.cas_username_column => ido_id).destroy end From e6c1d6e94e50c45d33f8049e66709f27eb5befbc Mon Sep 17 00:00:00 2001 From: Mario Visic Date: Sun, 20 Nov 2011 21:18:42 +1100 Subject: [PATCH 20/28] changes to the gemfile to remove local gem dependencies. --- Gemfile | 16 ++++++---------- Gemfile.lock | 49 ++++++++++++++++++++++++------------------------- 2 files changed, 30 insertions(+), 35 deletions(-) diff --git a/Gemfile b/Gemfile index efbb8757..6a07cfde 100644 --- a/Gemfile +++ b/Gemfile @@ -6,22 +6,18 @@ gem 'rake', '0.9.2' gem 'rails', '~> 3.1.1' -gem 'devise', :git => 'git://github.com/plataformatec/devise.git' -# gem 'devise', '~> 1.4.9' # FIXME: waiting for the new devise gem coming soon +gem 'devise', :git => 'git://github.com/plataformatec/devise.git'# FIXME: waiting for the new devise gem coming soon gem 'cancan', '~> 1.6.7' -gem 'bson', '~> 1.3.1' -gem 'mongo', '~> 1.3.1' -gem 'bson_ext', '~> 1.3.1' -gem 'mongoid', '~> 2.3.3' -gem 'locomotive_mongoid_acts_as_tree', '0.1.5.7', :require => 'mongoid_acts_as_tree', :path => '../gems/acts_as_tree' # TODO: REPLACE IT -gem 'custom_fields', :git => 'git://github.com/locomotivecms/custom_fields.git' -#gem 'custom_fields', '~> 1.1.0.rc1', :path => '../gems/custom_fields' +gem 'bson_ext', '~> 1.4.0' +gem 'mongoid', '~> 2.3.2' +gem 'locomotive_mongoid_acts_as_tree', :git => 'git@github.com:locomotivecms/mongoid_acts_as_tree.git' +gem 'custom_fields', :git => 'git://github.com/locomotivecms/custom_fields.git', :branch => 'mongoid_2_3_2' gem 'will_paginate', '~> 3.0.2' gem 'haml', '~> 3.1.3' gem 'sass-rails', '~> 3.1.4' -gem "compass", :git => 'git://github.com/chriseppstein/compass.git', :branch => 'rails31' +gem "compass", :git => 'git://github.com/chriseppstein/compass.git' gem 'coffee-script', '~> 2.2.0' gem 'uglifier', '~> 1.0.4' gem 'jquery-rails', '~> 1.0.16' diff --git a/Gemfile.lock b/Gemfile.lock index a4d8360f..2b41b436 100644 --- a/Gemfile.lock +++ b/Gemfile.lock @@ -1,21 +1,21 @@ GIT remote: git://github.com/chriseppstein/compass.git - revision: 22e2458b77519e8eb8463170c1a1fe4bab105f3e - branch: rails31 + revision: ebd758a7999a74611a3d682ba72c661a83f97498 specs: - compass (0.12.0.alpha.0.22e2458) + compass (0.12.alpha.0.ebd758a) chunky_png (~> 1.2) fssm (>= 0.2.7) sass (~> 3.1) GIT remote: git://github.com/locomotivecms/custom_fields.git - revision: af88a1602442c1507152426a5dcac662695c55ef + revision: e32bf03759e7eac2281e7eb35dc0b70fc684d8ad + branch: mongoid_2_3_2 specs: custom_fields (1.1.0.rc1) activesupport (~> 3.1.1) carrierwave-mongoid (~> 0.1.3) - mongoid (~> 2.3.3) + mongoid (= 2.3.2) GIT remote: git://github.com/nragaz/uploadify-rails.git @@ -27,7 +27,7 @@ GIT GIT remote: git://github.com/plataformatec/devise.git - revision: e8aabd465216bcb260448056c8ed4580d099a8c9 + revision: a5aa03b98328d8e1fdb4081a74b3c04ff9593607 specs: devise (1.5.0.dev) bcrypt-ruby (~> 3.0) @@ -40,8 +40,9 @@ GIT specs: handlebars-rails (0.9.1) -PATH - remote: ../gems/acts_as_tree +GIT + remote: git@github.com:locomotivecms/mongoid_acts_as_tree.git + revision: ca494d22c3d7946385aba1153c017d9c30e9f9d3 specs: locomotive_mongoid_acts_as_tree (0.1.5.7) @@ -87,8 +88,8 @@ GEM autotest (4.4.6) ZenTest (>= 4.4.1) bcrypt-ruby (3.0.1) - bson (1.3.1) - bson_ext (1.3.1) + bson (1.4.0) + bson_ext (1.4.0) builder (3.0.0) bushido (0.0.35) highline (>= 1.6.1) @@ -120,10 +121,10 @@ GEM execjs coffee-script-source (1.1.3) columnize (0.3.4) - cucumber (1.1.2) + cucumber (1.1.1) builder (>= 2.1.2) diff-lcs (>= 1.1.2) - gherkin (~> 2.6.2) + gherkin (~> 2.6.0) json (>= 1.4.6) term-ansicolor (>= 1.0.6) cucumber-rails (1.2.0) @@ -178,10 +179,10 @@ GEM multi_json multi_xml i18n (0.6.0) - jquery-rails (1.0.17) + jquery-rails (1.0.16) railties (~> 3.0) thor (~> 0.14) - json (1.5.4) + json (1.6.1) json_pure (1.6.1) kgio (2.6.0) launchy (2.0.5) @@ -197,11 +198,11 @@ GEM mime-types (1.17.2) mimetype-fu (0.1.2) mocha (0.9.12) - mongo (1.3.1) - bson (>= 1.3.1) - mongoid (2.3.3) + mongo (1.4.0) + bson (= 1.4.0) + mongoid (2.3.2) activemodel (~> 3.1) - mongo (~> 1.3) + mongo (~> 1.4) tzinfo (~> 0.3.22) multi_json (1.0.3) multi_xml (0.4.1) @@ -284,7 +285,7 @@ GEM archive-tar-minitar (>= 0.5.2) rubyzip (0.9.4) sanitize (2.0.3) - nokogiri (< 1.6, >= 1.4.4) + nokogiri (>= 1.4.4, < 1.6) sass (3.1.10) sass-rails (3.1.4) actionpack (~> 3.1.0) @@ -301,7 +302,7 @@ GEM sprockets (2.0.3) hike (~> 1.2) rack (~> 1.0) - tilt (!= 1.3.0, ~> 1.1) + tilt (~> 1.1, != 1.3.0) term-ansicolor (1.0.7) thor (0.14.6) tilt (1.3.3) @@ -333,8 +334,7 @@ DEPENDENCIES ZenTest actionmailer-with-request (~> 0.3.0) autotest - bson (~> 1.3.1) - bson_ext (~> 1.3.1) + bson_ext (~> 1.4.0) bushido (= 0.0.35) cancan (~> 1.6.7) capybara @@ -363,11 +363,10 @@ DEPENDENCIES launchy linecache (= 0.43) locomotive_liquid (= 2.2.2) - locomotive_mongoid_acts_as_tree (= 0.1.5.7)! + locomotive_mongoid_acts_as_tree! mimetype-fu (~> 0.1.2) mocha (= 0.9.12) - mongo (~> 1.3.1) - mongoid (~> 2.3.3) + mongoid (~> 2.3.2) pickle rack-cache (~> 1.1) rails (~> 3.1.1) From 769cf7548c3089b386623bc1f8779f67a1bf93d7 Mon Sep 17 00:00:00 2001 From: Mario Visic Date: Sun, 20 Nov 2011 21:36:10 +1100 Subject: [PATCH 21/28] Updated gemfile with kaminari again. --- Gemfile | 2 +- Gemfile.lock | 5 +++-- lib/locomotive/dependencies.rb | 4 ++-- 3 files changed, 6 insertions(+), 5 deletions(-) diff --git a/Gemfile b/Gemfile index 6a07cfde..d286bc46 100644 --- a/Gemfile +++ b/Gemfile @@ -13,7 +13,7 @@ gem 'bson_ext', '~> 1.4.0' gem 'mongoid', '~> 2.3.2' gem 'locomotive_mongoid_acts_as_tree', :git => 'git@github.com:locomotivecms/mongoid_acts_as_tree.git' gem 'custom_fields', :git => 'git://github.com/locomotivecms/custom_fields.git', :branch => 'mongoid_2_3_2' -gem 'will_paginate', '~> 3.0.2' +gem 'kaminari' gem 'haml', '~> 3.1.3' gem 'sass-rails', '~> 3.1.4' diff --git a/Gemfile.lock b/Gemfile.lock index 2b41b436..027d3d5e 100644 --- a/Gemfile.lock +++ b/Gemfile.lock @@ -184,6 +184,8 @@ GEM thor (~> 0.14) json (1.6.1) json_pure (1.6.1) + kaminari (0.12.4) + rails (>= 3.0.0) kgio (2.6.0) launchy (2.0.5) addressable (~> 2.2.6) @@ -321,7 +323,6 @@ GEM raindrops (~> 0.6) warden (1.1.0) rack (>= 1.0) - will_paginate (3.0.2) xpath (0.1.4) nokogiri (~> 1.3) @@ -360,6 +361,7 @@ DEPENDENCIES highline (~> 1.6.2) httparty (~> 0.8.1) jquery-rails (~> 1.0.16) + kaminari launchy linecache (= 0.43) locomotive_liquid (= 2.2.2) @@ -386,5 +388,4 @@ DEPENDENCIES uglifier (~> 1.0.4) unicorn uploadify-rails! - will_paginate (~> 3.0.2) xpath (~> 0.1.4) diff --git a/lib/locomotive/dependencies.rb b/lib/locomotive/dependencies.rb index 4397e7d4..23904ab2 100644 --- a/lib/locomotive/dependencies.rb +++ b/lib/locomotive/dependencies.rb @@ -2,7 +2,7 @@ require 'devise' require 'mongoid' require 'mongoid/railtie' require 'mongoid_acts_as_tree' -require 'will_paginate' +require 'kaminari' require 'haml' require 'liquid' require 'formtastic' @@ -19,4 +19,4 @@ require 'dragonfly' require 'cancan' require 'RMagick' require 'cells' -require 'sanitize' \ No newline at end of file +require 'sanitize' From 51c0397531d115fd4da56228340008c5e13b4549 Mon Sep 17 00:00:00 2001 From: Mario Visic Date: Sun, 20 Nov 2011 21:39:46 +1100 Subject: [PATCH 22/28] Removed spork to get spec helper working. Will readd later if required. --- Gemfile | 1 - Gemfile.lock | 2 - .../locomotive/liquid/drops/contents_spec.rb | 3 - spec/spec_helper.rb | 108 +++++------------- 4 files changed, 28 insertions(+), 86 deletions(-) diff --git a/Gemfile b/Gemfile index d286bc46..9c3c9d5a 100644 --- a/Gemfile +++ b/Gemfile @@ -78,7 +78,6 @@ group :test do gem 'capybara' gem 'database_cleaner' - gem 'spork', '~> 0.9.0.rc' gem 'launchy' gem 'mocha', '0.9.12' # :git => 'git://github.com/floehopper/mocha.git' end diff --git a/Gemfile.lock b/Gemfile.lock index 027d3d5e..3f66eab6 100644 --- a/Gemfile.lock +++ b/Gemfile.lock @@ -300,7 +300,6 @@ GEM ffi (= 1.0.9) json_pure rubyzip - spork (0.9.0.rc9) sprockets (2.0.3) hike (~> 1.2) rack (~> 1.0) @@ -383,7 +382,6 @@ DEPENDENCIES rubyzip sanitize (~> 2.0.3) sass-rails (~> 3.1.4) - spork (~> 0.9.0.rc) tinymce-rails uglifier (~> 1.0.4) unicorn diff --git a/spec/lib/locomotive/liquid/drops/contents_spec.rb b/spec/lib/locomotive/liquid/drops/contents_spec.rb index a0bb806d..d39758b1 100644 --- a/spec/lib/locomotive/liquid/drops/contents_spec.rb +++ b/spec/lib/locomotive/liquid/drops/contents_spec.rb @@ -3,9 +3,6 @@ require 'spec_helper' describe Locomotive::Liquid::Drops::Contents do before(:each) do - # Reload the file (needed for spork) - load File.join(Rails.root, 'lib', 'locomotive', 'liquid', 'drops', 'contents.rb') - @site = FactoryGirl.build(:site) @content_type = FactoryGirl.build(:content_type, :site => @site, :slug => 'projects') end diff --git a/spec/spec_helper.rb b/spec/spec_helper.rb index 5ef675c5..a745e68c 100644 --- a/spec/spec_helper.rb +++ b/spec/spec_helper.rb @@ -1,93 +1,41 @@ -# Note: if segmentation fault with spork / imagemagick on mac os x, take a look at: -# http://stackoverflow.com/questions/2838307/why-is-this-rmagick-call-generating-a-segmentation-fault +ENV["RAILS_ENV"] ||= 'test' -require 'rubygems' -require 'spork' +require 'rails/mongoid' +require File.join(File.dirname(__FILE__), 'dummy', 'config', 'environment.rb') +require 'rspec/rails' +require 'factory_girl' -# figure out where we are being loaded from -if $LOADED_FEATURES.grep(/spec\/spec_helper\.rb/).any? - begin - raise "foo" - rescue => e - puts <<-MSG - =================================================== - It looks like spec_helper.rb has been loaded - multiple times. Normalize the require to: +# Requires supporting ruby files with custom matchers and macros, etc, +# in spec/support/ and its subdirectories. +Dir[Rails.root.join('spec/support/**/*.rb')].each { |f| require f } - require "spec/spec_helper" +Locomotive.configure_for_test - Things like File.join and File.expand_path will - cause it to be loaded multiple times. +RSpec.configure do |config| - Loaded this time from: + config.include(Locomotive::RSpec::Matchers) - #{e.backtrace.join("\n ")} - =================================================== - MSG + config.mock_with :mocha + + config.before(:each) do + Locomotive.config.heroku = false end -end + require 'database_cleaner' + config.before(:suite) do + DatabaseCleaner.strategy = :truncation + DatabaseCleaner.orm = 'mongoid' + end -Spork.prefork do - # Loading more in this block will cause your tests to run faster. However, - # if you change any configuration or code from libraries loaded here, you'll - # need to restart spork for it take effect. - - # This file is copied to spec/ when you run 'rails generate rspec:install' - ENV["RAILS_ENV"] ||= 'test' - - # Avoid preloading models - require 'rails/mongoid' - Spork.trap_class_method(Rails::Mongoid, :load_models) - - require File.expand_path('../../config/environment', __FILE__) - - require 'rspec/rails' - - require 'factory_girl' - Spork.trap_class_method(FactoryGirl, :find_definitions) - - # Requires supporting ruby files with custom matchers and macros, etc, - # in spec/support/ and its subdirectories. - Dir[Rails.root.join('spec/support/**/*.rb')].each { |f| require f } - - Locomotive.configure_for_test - - RSpec.configure do |config| - - config.include(Locomotive::RSpec::Matchers) - - config.mock_with :mocha - - config.before(:each) do - Locomotive.config.heroku = false - end - - require 'database_cleaner' - config.before(:suite) do - DatabaseCleaner.strategy = :truncation - DatabaseCleaner.orm = 'mongoid' - end - - config.before(:each) do - if self.described_class != Locomotive::Import::Job - DatabaseCleaner.clean - end - end - - config.before(:all) do - if self.described_class == Locomotive::Import::Job - DatabaseCleaner.clean - end + config.before(:each) do + if self.described_class != Locomotive::Import::Job + DatabaseCleaner.clean end end + config.before(:all) do + if self.described_class == Locomotive::Import::Job + DatabaseCleaner.clean + end + end end - -Spork.each_run do - # This code will be run each time you run your specs. - Dir[Rails.root.join('spec/support/**/*.rb')].each { |f| require f } - - # loading ruby file directly breaks the tests - # Dir[Rails.root.join('app/models/*.rb')].each { |f| load f } -end \ No newline at end of file From a97978468f481bdec03db562a49be8b616842749 Mon Sep 17 00:00:00 2001 From: Mario Visic Date: Sun, 20 Nov 2011 21:52:22 +1100 Subject: [PATCH 23/28] Use a later custom fields version. --- Gemfile | 4 ++-- Gemfile.lock | 13 ++++++------- 2 files changed, 8 insertions(+), 9 deletions(-) diff --git a/Gemfile b/Gemfile index 9c3c9d5a..35e28a75 100644 --- a/Gemfile +++ b/Gemfile @@ -10,9 +10,9 @@ gem 'devise', :git => 'git://github.com/plataformatec/devise.git'# gem 'cancan', '~> 1.6.7' gem 'bson_ext', '~> 1.4.0' -gem 'mongoid', '~> 2.3.2' +gem 'mongoid', '~> 2.3.3' gem 'locomotive_mongoid_acts_as_tree', :git => 'git@github.com:locomotivecms/mongoid_acts_as_tree.git' -gem 'custom_fields', :git => 'git://github.com/locomotivecms/custom_fields.git', :branch => 'mongoid_2_3_2' +gem 'custom_fields', :git => 'git://github.com/locomotivecms/custom_fields.git' gem 'kaminari' gem 'haml', '~> 3.1.3' diff --git a/Gemfile.lock b/Gemfile.lock index 3f66eab6..3c9544ee 100644 --- a/Gemfile.lock +++ b/Gemfile.lock @@ -9,13 +9,12 @@ GIT GIT remote: git://github.com/locomotivecms/custom_fields.git - revision: e32bf03759e7eac2281e7eb35dc0b70fc684d8ad - branch: mongoid_2_3_2 + revision: af88a1602442c1507152426a5dcac662695c55ef specs: custom_fields (1.1.0.rc1) activesupport (~> 3.1.1) carrierwave-mongoid (~> 0.1.3) - mongoid (= 2.3.2) + mongoid (~> 2.3.3) GIT remote: git://github.com/nragaz/uploadify-rails.git @@ -104,7 +103,7 @@ GEM rack-test (>= 0.5.4) selenium-webdriver (~> 2.0) xpath (~> 0.1.4) - carrierwave (0.5.7) + carrierwave (0.5.8) activesupport (~> 3.0) carrierwave-mongoid (0.1.3) carrierwave (>= 0.5.6) @@ -202,9 +201,9 @@ GEM mocha (0.9.12) mongo (1.4.0) bson (= 1.4.0) - mongoid (2.3.2) + mongoid (2.3.3) activemodel (~> 3.1) - mongo (~> 1.4) + mongo (~> 1.3) tzinfo (~> 0.3.22) multi_json (1.0.3) multi_xml (0.4.1) @@ -367,7 +366,7 @@ DEPENDENCIES locomotive_mongoid_acts_as_tree! mimetype-fu (~> 0.1.2) mocha (= 0.9.12) - mongoid (~> 2.3.2) + mongoid (~> 2.3.3) pickle rack-cache (~> 1.1) rails (~> 3.1.1) From a7b66f0e25fd93f9ad8810dabcfa598c7c9ddfc8 Mon Sep 17 00:00:00 2001 From: Mario Visic Date: Sun, 20 Nov 2011 21:59:12 +1100 Subject: [PATCH 24/28] Lots of fixes to get tets closer to working. --- .../locomotive/current_site_controller.rb | 7 +++---- app/controllers/locomotive/import_controller.rb | 7 +++---- .../locomotive/my_account_controller.rb | 5 +++-- app/controllers/locomotive/sites_controller.rb | 2 -- app/models/locomotive/content_instance.rb | 2 +- app/models/locomotive/content_type.rb | 2 +- spec/models/{ => locomotive}/ability_spec.rb | 14 +++++++------- spec/models/{ => locomotive}/account_spec.rb | 0 spec/models/{ => locomotive}/asset_spec.rb | 0 .../{ => locomotive}/content_instance_spec.rb | 0 spec/models/{ => locomotive}/content_type_spec.rb | 0 .../{ => locomotive}/editable_element_spec.rb | 0 spec/models/{ => locomotive}/membership_spec.rb | 0 spec/models/{ => locomotive}/page_spec.rb | 0 spec/models/{ => locomotive}/site_spec.rb | 0 spec/models/{ => locomotive}/snippet_spec.rb | 0 spec/models/{ => locomotive}/theme_asset_spec.rb | 0 17 files changed, 18 insertions(+), 21 deletions(-) rename spec/models/{ => locomotive}/ability_spec.rb (92%) rename spec/models/{ => locomotive}/account_spec.rb (100%) rename spec/models/{ => locomotive}/asset_spec.rb (100%) rename spec/models/{ => locomotive}/content_instance_spec.rb (100%) rename spec/models/{ => locomotive}/content_type_spec.rb (100%) rename spec/models/{ => locomotive}/editable_element_spec.rb (100%) rename spec/models/{ => locomotive}/membership_spec.rb (100%) rename spec/models/{ => locomotive}/page_spec.rb (100%) rename spec/models/{ => locomotive}/site_spec.rb (100%) rename spec/models/{ => locomotive}/snippet_spec.rb (100%) rename spec/models/{ => locomotive}/theme_asset_spec.rb (100%) diff --git a/app/controllers/locomotive/current_site_controller.rb b/app/controllers/locomotive/current_site_controller.rb index 73aaea72..241e1abc 100644 --- a/app/controllers/locomotive/current_site_controller.rb +++ b/app/controllers/locomotive/current_site_controller.rb @@ -1,18 +1,17 @@ module Locomotive class CurrentSiteController < BaseController - defaults :instance_name => 'site' - sections 'settings', 'site' - actions :edit, :update - skip_load_and_authorize_resource load_and_authorize_resource :class => 'Site' respond_to :json, :only => :update + def edit + end + def update update! do |success, failure| success.html { redirect_to edit_current_site_url(new_host_if_subdomain_changed) } diff --git a/app/controllers/locomotive/import_controller.rb b/app/controllers/locomotive/import_controller.rb index 2492bb71..c5db218a 100644 --- a/app/controllers/locomotive/import_controller.rb +++ b/app/controllers/locomotive/import_controller.rb @@ -3,8 +3,6 @@ module Locomotive sections 'settings', 'site' - actions :show, :new, :create - skip_load_and_authorize_resource before_filter :authorize_import @@ -23,7 +21,8 @@ module Locomotive end end - def new; end + def new + end def create begin @@ -52,4 +51,4 @@ module Locomotive end end -end \ No newline at end of file +end diff --git a/app/controllers/locomotive/my_account_controller.rb b/app/controllers/locomotive/my_account_controller.rb index d9d659ec..95f33986 100644 --- a/app/controllers/locomotive/my_account_controller.rb +++ b/app/controllers/locomotive/my_account_controller.rb @@ -3,12 +3,13 @@ module Locomotive sections 'settings', 'account' - actions :edit, :update - respond_to :json, :only => :update skip_load_and_authorize_resource + def edit + end + def update update! { edit_my_account_url } end diff --git a/app/controllers/locomotive/sites_controller.rb b/app/controllers/locomotive/sites_controller.rb index feaed930..5f031e0e 100644 --- a/app/controllers/locomotive/sites_controller.rb +++ b/app/controllers/locomotive/sites_controller.rb @@ -1,8 +1,6 @@ module Locomotive class SitesController < BaseController - defaults :instance_name => 'site' - sections 'settings' def create diff --git a/app/models/locomotive/content_instance.rb b/app/models/locomotive/content_instance.rb index 36f54f23..b077cbf4 100644 --- a/app/models/locomotive/content_instance.rb +++ b/app/models/locomotive/content_instance.rb @@ -124,4 +124,4 @@ module Locomotive end end -end \ No newline at end of file +end diff --git a/app/models/locomotive/content_type.rb b/app/models/locomotive/content_type.rb index 219c78b5..3c283800 100644 --- a/app/models/locomotive/content_type.rb +++ b/app/models/locomotive/content_type.rb @@ -144,4 +144,4 @@ module Locomotive end end -end \ No newline at end of file +end diff --git a/spec/models/ability_spec.rb b/spec/models/locomotive/ability_spec.rb similarity index 92% rename from spec/models/ability_spec.rb rename to spec/models/locomotive/ability_spec.rb index 237426ae..5d0efc13 100644 --- a/spec/models/ability_spec.rb +++ b/spec/models/locomotive/ability_spec.rb @@ -1,6 +1,6 @@ require 'spec_helper' -describe Ability do +describe Locomotive::Ability do before :each do @site = FactoryGirl.create(:site) @@ -13,7 +13,7 @@ describe Ability do context 'pages' do - subject { Page.new } + subject { Locomotive::Page.new } context 'management' do it 'should allow management of pages from (admin, designer, author)' do @@ -33,7 +33,7 @@ describe Ability do context 'content instance' do - subject { ContentInstance.new } + subject { Locomotive::ContentInstance.new } context 'management' do it 'should allow management of pages from (admin, designer, author)' do @@ -47,7 +47,7 @@ describe Ability do context 'content type' do - subject { ContentType.new } + subject { Locomotive::ContentType.new } context 'management' do it 'should allow management of pages from (admin, designer)' do @@ -67,7 +67,7 @@ describe Ability do context 'theme assets' do - subject { ThemeAsset.new } + subject { Locomotive::ThemeAsset.new } context 'management' do it 'should allow management of pages from (admin, designer)' do @@ -87,7 +87,7 @@ describe Ability do context 'site' do - subject { Site.new } + subject { Locomotive::Site.new } context 'management' do it 'should allow management of pages from (admin)' do @@ -115,7 +115,7 @@ describe Ability do context 'membership' do - subject { Membership.new } + subject { Locomotive::Membership.new } context 'management' do it 'should allow management of memberships from (admin, designer)' do diff --git a/spec/models/account_spec.rb b/spec/models/locomotive/account_spec.rb similarity index 100% rename from spec/models/account_spec.rb rename to spec/models/locomotive/account_spec.rb diff --git a/spec/models/asset_spec.rb b/spec/models/locomotive/asset_spec.rb similarity index 100% rename from spec/models/asset_spec.rb rename to spec/models/locomotive/asset_spec.rb diff --git a/spec/models/content_instance_spec.rb b/spec/models/locomotive/content_instance_spec.rb similarity index 100% rename from spec/models/content_instance_spec.rb rename to spec/models/locomotive/content_instance_spec.rb diff --git a/spec/models/content_type_spec.rb b/spec/models/locomotive/content_type_spec.rb similarity index 100% rename from spec/models/content_type_spec.rb rename to spec/models/locomotive/content_type_spec.rb diff --git a/spec/models/editable_element_spec.rb b/spec/models/locomotive/editable_element_spec.rb similarity index 100% rename from spec/models/editable_element_spec.rb rename to spec/models/locomotive/editable_element_spec.rb diff --git a/spec/models/membership_spec.rb b/spec/models/locomotive/membership_spec.rb similarity index 100% rename from spec/models/membership_spec.rb rename to spec/models/locomotive/membership_spec.rb diff --git a/spec/models/page_spec.rb b/spec/models/locomotive/page_spec.rb similarity index 100% rename from spec/models/page_spec.rb rename to spec/models/locomotive/page_spec.rb diff --git a/spec/models/site_spec.rb b/spec/models/locomotive/site_spec.rb similarity index 100% rename from spec/models/site_spec.rb rename to spec/models/locomotive/site_spec.rb diff --git a/spec/models/snippet_spec.rb b/spec/models/locomotive/snippet_spec.rb similarity index 100% rename from spec/models/snippet_spec.rb rename to spec/models/locomotive/snippet_spec.rb diff --git a/spec/models/theme_asset_spec.rb b/spec/models/locomotive/theme_asset_spec.rb similarity index 100% rename from spec/models/theme_asset_spec.rb rename to spec/models/locomotive/theme_asset_spec.rb From 47db53e0e5e83ad8b3bef2719b72f494131f5175 Mon Sep 17 00:00:00 2001 From: Mario Visic Date: Sun, 20 Nov 2011 22:25:01 +1100 Subject: [PATCH 25/28] Namespace factory girl factories. --- spec/spec_helper.rb | 2 +- spec/{ => support}/factories.rb | 24 ++++++++++++------------ 2 files changed, 13 insertions(+), 13 deletions(-) rename spec/{ => support}/factories.rb (83%) diff --git a/spec/spec_helper.rb b/spec/spec_helper.rb index a745e68c..10fae0dd 100644 --- a/spec/spec_helper.rb +++ b/spec/spec_helper.rb @@ -7,7 +7,7 @@ require 'factory_girl' # Requires supporting ruby files with custom matchers and macros, etc, # in spec/support/ and its subdirectories. -Dir[Rails.root.join('spec/support/**/*.rb')].each { |f| require f } +Dir[File.join(File.dirname(__FILE__), 'support', '**', '*.rb')].each { |f| require f } Locomotive.configure_for_test diff --git a/spec/factories.rb b/spec/support/factories.rb similarity index 83% rename from spec/factories.rb rename to spec/support/factories.rb index 3968ccb9..1d80a4df 100644 --- a/spec/factories.rb +++ b/spec/support/factories.rb @@ -1,14 +1,14 @@ FactoryGirl.define do ## Site ## - factory :site do + factory :site, :class => Locomotive::Site do name 'Acme Website' - subdomain 'acme' + # subdomain 'acme' created_at Time.now factory "test site" do name 'Locomotive test website' - subdomain 'test' + # subdomain 'test' after_build do |site_test| site_test.memberships.build :account => Account.where(:name => "Admin").first || Factory("admin user"), :role => 'admin' @@ -16,7 +16,7 @@ FactoryGirl.define do factory "another site" do name "Locomotive test website #2" - subdomain "test2" + # subdomain "test2" end end @@ -41,7 +41,7 @@ FactoryGirl.define do end # Accounts ## - factory :account do + factory :account, :class => Locomotive::Account do name 'Bart Simpson' email 'bart@simpson.net' password 'easyone' @@ -74,7 +74,7 @@ FactoryGirl.define do end ## Memberships ## - factory :membership do + factory :membership, :class => Locomotive::Membership do role 'admin' account { Account.where(:name => "Bart Simpson").first || Factory('admin user') } @@ -96,7 +96,7 @@ FactoryGirl.define do end ## Pages ## - factory :page do + factory :page, :class => Locomotive::Page do title 'Home page' slug 'index' published true @@ -113,7 +113,7 @@ FactoryGirl.define do end ## Snippets ## - factory :snippet do + factory :snippet, :class => Locomotive::Snippet do name 'My website title' slug 'header' template %{Acme} @@ -122,23 +122,23 @@ FactoryGirl.define do ## Assets ## - factory :asset do + factory :asset, :class => Locomotive::ContentAsset do site { Site.where(:subdomain => "acme").first || Factory(:site) } end ## Theme assets ## - factory :theme_asset do + factory :theme_asset, :class => Locomotive::ThemeAsset do site { Site.where(:subdomain => "acme").first || Factory(:site) } end ## Content types ## - factory :content_type do + factory :content_type, :class => Locomotive::ContentType do name 'My project' site { Site.where(:subdomain => "acme").first || Factory(:site) } end - factory :content_instance do + factory :content_instance, :class => Locomotive::ContentInstance do end end From a99ba182002f21044aea8dd47eeed3594ddcb4d8 Mon Sep 17 00:00:00 2001 From: Mario Visic Date: Sun, 20 Nov 2011 22:47:03 +1100 Subject: [PATCH 26/28] Temporarily removed a module include causing issues. --- app/models/locomotive/content_instance.rb | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/app/models/locomotive/content_instance.rb b/app/models/locomotive/content_instance.rb index b077cbf4..5ce46de8 100644 --- a/app/models/locomotive/content_instance.rb +++ b/app/models/locomotive/content_instance.rb @@ -5,7 +5,11 @@ module Locomotive include ::Mongoid::Timestamps ## extensions ## - include CustomFields::ProxyClassEnabler + # + # FIXME: I cannot find the module below defined in custom fields or the + # locomotive CMS engine. Please uncomment when the module is available + # + # include CustomFields::ProxyClassEnabler include Extensions::Shared::Seo ## fields (dynamic fields) ## From 75041ba21c65782ee5aef2b7d1669d0c6a1c1e53 Mon Sep 17 00:00:00 2001 From: Mario Visic Date: Sun, 20 Nov 2011 22:47:41 +1100 Subject: [PATCH 27/28] Specs now run for all models. The account model now passes GREEEEn. --- app/models/locomotive/ability.rb | 6 ++--- app/models/locomotive/account.rb | 6 ++--- spec/models/locomotive/account_spec.rb | 24 +++++++++---------- .../{asset_spec.rb => content_asset_spec.rb} | 12 +++++----- .../locomotive/content_instance_spec.rb | 4 ++-- spec/models/locomotive/content_type_spec.rb | 2 +- .../locomotive/editable_element_spec.rb | 4 ++-- spec/models/locomotive/membership_spec.rb | 2 +- spec/models/locomotive/page_spec.rb | 2 +- spec/models/locomotive/site_spec.rb | 2 +- spec/models/locomotive/snippet_spec.rb | 2 +- spec/models/locomotive/theme_asset_spec.rb | 2 +- spec/support/factories.rb | 16 ++++++------- spec/support/locomotive.rb | 6 ++--- 14 files changed, 45 insertions(+), 45 deletions(-) rename spec/models/locomotive/{asset_spec.rb => content_asset_spec.rb} (72%) diff --git a/app/models/locomotive/ability.rb b/app/models/locomotive/ability.rb index eeb46f02..54c7bc19 100644 --- a/app/models/locomotive/ability.rb +++ b/app/models/locomotive/ability.rb @@ -32,7 +32,7 @@ module Locomotive can :touch, [Page, ThemeAsset] can :sort, Page - can :manage, [ContentInstance, Asset] + can :manage, [ContentInstance, ContentAsset] can :touch, Site do |site| site == @site @@ -50,7 +50,7 @@ module Locomotive can :manage, ThemeAsset - can :manage, Asset + can :manage, ContentAsset can :manage, Site do |site| site == @site @@ -82,4 +82,4 @@ module Locomotive end end end -end \ No newline at end of file +end diff --git a/app/models/locomotive/account.rb b/app/models/locomotive/account.rb index 0bd6a1df..9a47801c 100644 --- a/app/models/locomotive/account.rb +++ b/app/models/locomotive/account.rb @@ -27,7 +27,7 @@ module Locomotive end def reset_switch_site_token! - self.switch_site_token = ActiveSupport::SecureRandom.base64(8).gsub("/", "_").gsub(/=+$/, "") + self.switch_site_token = SecureRandom.base64(8).gsub("/", "_").gsub(/=+$/, "") self.save end @@ -37,7 +37,7 @@ module Locomotive end def self.find_using_switch_site_token!(token, age = 1.minute) - self.find_using_switch_site_token(token, age) || raise(Mongoid::Errors::DocumentNotFound.new(self, token)) + self.find_using_switch_site_token(token, age) || raise(::Mongoid::Errors::DocumentNotFound.new(self, token)) end def devise_mailer @@ -67,4 +67,4 @@ module Locomotive end end -end \ No newline at end of file +end diff --git a/spec/models/locomotive/account_spec.rb b/spec/models/locomotive/account_spec.rb index c8f429a8..d866bce3 100644 --- a/spec/models/locomotive/account_spec.rb +++ b/spec/models/locomotive/account_spec.rb @@ -1,6 +1,6 @@ require 'spec_helper' -describe Account do +describe Locomotive::Account do it 'should have a valid factory' do FactoryGirl.build(:account).should be_valid @@ -17,7 +17,7 @@ describe Account do end it "should have a default locale" do - account = Account.new + account = Locomotive::Account.new account.locale.should == 'en' end @@ -31,8 +31,8 @@ describe Account do it 'should own many sites' do account = FactoryGirl.create(:account) - site_1 = FactoryGirl.create(:site, :memberships => [Membership.new(:account => account)]) - site_2 = FactoryGirl.create(:site, :subdomain => 'foo', :memberships => [Membership.new(:account => account)]) + site_1 = FactoryGirl.create(:site, :memberships => [Locomotive::Membership.new(:account => account)]) + site_2 = FactoryGirl.create(:site, :memberships => [Locomotive::Membership.new(:account => account)]) account.reload.sites.to_a.should == [site_1, site_2] end @@ -40,14 +40,14 @@ describe Account do before(:each) do @account = FactoryGirl.build(:account) - @site_1 = FactoryGirl.build(:site, :subdomain => 'foo', :memberships => [FactoryGirl.build(:membership, :account => @account)]) - @site_2 = FactoryGirl.build(:site, :subdomain => 'bar', :memberships => [FactoryGirl.build(:membership, :account => @account)]) + @site_1 = FactoryGirl.build(:site,:memberships => [FactoryGirl.build(:membership, :account => @account)]) + @site_2 = FactoryGirl.build(:site,:memberships => [FactoryGirl.build(:membership, :account => @account)]) @account.stubs(:sites).returns([@site_1, @site_2]) - Site.any_instance.stubs(:save).returns(true) + Locomotive::Site.any_instance.stubs(:save).returns(true) end it 'should also delete memberships' do - Site.any_instance.stubs(:admin_memberships).returns(['junk', 'dirt']) + Locomotive::Site.any_instance.stubs(:admin_memberships).returns(['junk', 'dirt']) @site_1.memberships.first.expects(:destroy) @site_2.memberships.first.expects(:destroy) @account.destroy @@ -78,13 +78,13 @@ describe Account do context 'retrieving an account' do it 'does not find it with an empty token' do - Account.find_using_switch_site_token(nil).should be_nil + Locomotive::Account.find_using_switch_site_token(nil).should be_nil end it 'raises an exception if not found' do - lambda { - Account.find_using_switch_site_token!(nil) - }.should raise_error(Mongoid::Errors::DocumentNotFound) + expect { + Locomotive::Account.find_using_switch_site_token!(nil) + }.to raise_error Mongoid::Errors::DocumentNotFound end end diff --git a/spec/models/locomotive/asset_spec.rb b/spec/models/locomotive/content_asset_spec.rb similarity index 72% rename from spec/models/locomotive/asset_spec.rb rename to spec/models/locomotive/content_asset_spec.rb index 58b4afc6..fb884356 100644 --- a/spec/models/locomotive/asset_spec.rb +++ b/spec/models/locomotive/content_asset_spec.rb @@ -2,23 +2,23 @@ require 'spec_helper' -describe Asset do +describe Locomotive::ContentAsset do describe 'attaching a file' do before(:each) do - Asset.any_instance.stubs(:site_id).returns('test') + ContentAsset.any_instance.stubs(:site_id).returns('test') @asset = FactoryGirl.build(:asset) end it 'should process picture' do - @asset.source = FixturedAsset.open('5k.png') + @asset.source = FixturedContentAsset.open('5k.png') @asset.source.file.content_type.should_not be_nil @asset.image?.should be_true end it 'should get width and height from the image' do - @asset.source = FixturedAsset.open('5k.png') + @asset.source = FixturedContentAsset.open('5k.png') @asset.width.should == 32 @asset.height.should == 32 end @@ -28,7 +28,7 @@ describe Asset do describe 'vignette' do before(:each) do - @asset = FactoryGirl.build(:asset, :source => FixturedAsset.open('5k.png')) + @asset = FactoryGirl.build(:asset, :source => FixturedContentAsset.open('5k.png')) end it 'does not resize image smaller than 50x50' do @@ -43,4 +43,4 @@ describe Asset do end -end \ No newline at end of file +end diff --git a/spec/models/locomotive/content_instance_spec.rb b/spec/models/locomotive/content_instance_spec.rb index 9669ab61..3f35d9a4 100644 --- a/spec/models/locomotive/content_instance_spec.rb +++ b/spec/models/locomotive/content_instance_spec.rb @@ -2,7 +2,7 @@ require 'spec_helper' -describe ContentInstance do +describe Locomotive::ContentInstance do before(:each) do Site.any_instance.stubs(:create_default_pages!).returns(true) @@ -189,4 +189,4 @@ describe ContentInstance do def fake_bson_id(id) BSON::ObjectId(id.to_s.rjust(24, '0')) end -end \ No newline at end of file +end diff --git a/spec/models/locomotive/content_type_spec.rb b/spec/models/locomotive/content_type_spec.rb index 73f72679..8ce132e1 100644 --- a/spec/models/locomotive/content_type_spec.rb +++ b/spec/models/locomotive/content_type_spec.rb @@ -1,6 +1,6 @@ require 'spec_helper' -describe ContentType do +describe Locomotive::ContentType do before(:each) do Site.any_instance.stubs(:create_default_pages!).returns(true) diff --git a/spec/models/locomotive/editable_element_spec.rb b/spec/models/locomotive/editable_element_spec.rb index 79901bae..ec2f33c3 100644 --- a/spec/models/locomotive/editable_element_spec.rb +++ b/spec/models/locomotive/editable_element_spec.rb @@ -1,6 +1,6 @@ require 'spec_helper' -describe EditableElement do +describe Locomotive::EditableElement do before(:each) do @site = FactoryGirl.create(:site) @@ -52,4 +52,4 @@ describe EditableElement do end end -end \ No newline at end of file +end diff --git a/spec/models/locomotive/membership_spec.rb b/spec/models/locomotive/membership_spec.rb index f2c5fffe..62a0d64b 100644 --- a/spec/models/locomotive/membership_spec.rb +++ b/spec/models/locomotive/membership_spec.rb @@ -1,6 +1,6 @@ require 'spec_helper' -describe Membership do +describe Locomotive::Membership do it 'should have a valid factory' do FactoryGirl.build(:membership, :account => FactoryGirl.build(:account)).should be_valid diff --git a/spec/models/locomotive/page_spec.rb b/spec/models/locomotive/page_spec.rb index 4e2fcaca..409c9522 100644 --- a/spec/models/locomotive/page_spec.rb +++ b/spec/models/locomotive/page_spec.rb @@ -2,7 +2,7 @@ require 'spec_helper' -describe Page do +describe Locomotive::Page do before(:each) do Site.any_instance.stubs(:create_default_pages!).returns(true) diff --git a/spec/models/locomotive/site_spec.rb b/spec/models/locomotive/site_spec.rb index fa434f73..21a069d2 100644 --- a/spec/models/locomotive/site_spec.rb +++ b/spec/models/locomotive/site_spec.rb @@ -1,6 +1,6 @@ require 'spec_helper' -describe Site do +describe Locomotive::Site do it 'should have a valid factory' do FactoryGirl.build(:site).should be_valid diff --git a/spec/models/locomotive/snippet_spec.rb b/spec/models/locomotive/snippet_spec.rb index 8f4a6d7e..a09d62da 100644 --- a/spec/models/locomotive/snippet_spec.rb +++ b/spec/models/locomotive/snippet_spec.rb @@ -1,6 +1,6 @@ require 'spec_helper' -describe Snippet do +describe Locomotive::Snippet do it 'should have a valid factory' do FactoryGirl.build(:snippet).should be_valid diff --git a/spec/models/locomotive/theme_asset_spec.rb b/spec/models/locomotive/theme_asset_spec.rb index 16abe137..e485c529 100644 --- a/spec/models/locomotive/theme_asset_spec.rb +++ b/spec/models/locomotive/theme_asset_spec.rb @@ -2,7 +2,7 @@ require 'spec_helper' -describe ThemeAsset do +describe Locomotive::ThemeAsset do describe 'attaching a file' do diff --git a/spec/support/factories.rb b/spec/support/factories.rb index 1d80a4df..eb87fa35 100644 --- a/spec/support/factories.rb +++ b/spec/support/factories.rb @@ -11,7 +11,7 @@ FactoryGirl.define do # subdomain 'test' after_build do |site_test| - site_test.memberships.build :account => Account.where(:name => "Admin").first || Factory("admin user"), :role => 'admin' + site_test.memberships.build :account => Locomotive::Account.where(:name => "Admin").first || Factory("admin user"), :role => 'admin' end factory "another site" do @@ -100,14 +100,14 @@ FactoryGirl.define do title 'Home page' slug 'index' published true - site { Site.where(:subdomain => "acme").first || Factory(:site) } + site { Locomotive::Site.where(:subdomain => "acme").first || Factory(:site) } factory :sub_page do title 'Subpage' slug 'subpage' published true - site { Site.where(:subdomain => "acme").first || Factory(:site) } - parent { Page.where(:slug => "index").first || Factory(:page) } + site { Locomotive::Site.where(:subdomain => "acme").first || Factory(:site) } + parent { Locomotive::Page.where(:slug => "index").first || Factory(:page) } end end @@ -117,25 +117,25 @@ FactoryGirl.define do name 'My website title' slug 'header' template %{Acme} - site { Site.where(:subdomain => "acme").first || Factory(:site) } + site { Locomotive::Site.where(:subdomain => "acme").first || Factory(:site) } end ## Assets ## factory :asset, :class => Locomotive::ContentAsset do - site { Site.where(:subdomain => "acme").first || Factory(:site) } + site { Locomotive::Site.where(:subdomain => "acme").first || Factory(:site) } end ## Theme assets ## factory :theme_asset, :class => Locomotive::ThemeAsset do - site { Site.where(:subdomain => "acme").first || Factory(:site) } + site { Locomotive::Site.where(:subdomain => "acme").first || Factory(:site) } end ## Content types ## factory :content_type, :class => Locomotive::ContentType do name 'My project' - site { Site.where(:subdomain => "acme").first || Factory(:site) } + site { Locomotive::Site.where(:subdomain => "acme").first || Factory(:site) } end factory :content_instance, :class => Locomotive::ContentInstance do diff --git a/spec/support/locomotive.rb b/spec/support/locomotive.rb index c054f2f3..374f90fd 100644 --- a/spec/support/locomotive.rb +++ b/spec/support/locomotive.rb @@ -29,11 +29,11 @@ def Locomotive.configure_for_test(force = false) Locomotive.define_subdomain_and_domains_options - Object.send(:remove_const, 'Site') if Object.const_defined?('Site') - load 'site.rb' + Object.send(:remove_const, 'Locomotive::Site') if Object.const_defined?('Locomotive::Site') + load 'locomotive/site.rb' FactoryGirl.factories.clear load File.join(Rails.root, 'spec', 'factories.rb') end end -end \ No newline at end of file +end From e21a40c157715b3213871cc5c406a7bc5b666d4d Mon Sep 17 00:00:00 2001 From: Mario Visic Date: Sun, 20 Nov 2011 22:52:20 +1100 Subject: [PATCH 28/28] Some fixes for the content asset spec. --- spec/models/locomotive/content_asset_spec.rb | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/spec/models/locomotive/content_asset_spec.rb b/spec/models/locomotive/content_asset_spec.rb index fb884356..6599af8c 100644 --- a/spec/models/locomotive/content_asset_spec.rb +++ b/spec/models/locomotive/content_asset_spec.rb @@ -7,18 +7,18 @@ describe Locomotive::ContentAsset do describe 'attaching a file' do before(:each) do - ContentAsset.any_instance.stubs(:site_id).returns('test') + Locomotive::ContentAsset.any_instance.stubs(:site_id).returns('test') @asset = FactoryGirl.build(:asset) end it 'should process picture' do - @asset.source = FixturedContentAsset.open('5k.png') + @asset.source = FixturedAsset.open('5k.png') @asset.source.file.content_type.should_not be_nil @asset.image?.should be_true end it 'should get width and height from the image' do - @asset.source = FixturedContentAsset.open('5k.png') + @asset.source = FixturedAsset.open('5k.png') @asset.width.should == 32 @asset.height.should == 32 end @@ -28,7 +28,7 @@ describe Locomotive::ContentAsset do describe 'vignette' do before(:each) do - @asset = FactoryGirl.build(:asset, :source => FixturedContentAsset.open('5k.png')) + @asset = FactoryGirl.build(:asset, :source => FixturedAsset.open('5k.png')) end it 'does not resize image smaller than 50x50' do