diff options
| -rw-r--r-- | spec/support/integration_spec_helper.rb | 30 | 
1 files changed, 30 insertions, 0 deletions
| diff --git a/spec/support/integration_spec_helper.rb b/spec/support/integration_spec_helper.rb index 78efb9027..b4d8a8283 100644 --- a/spec/support/integration_spec_helper.rb +++ b/spec/support/integration_spec_helper.rb @@ -19,6 +19,18 @@ module IntegrationSpecHelper          context('', &block) if block_given?        end      end + +    def paginate_collection klass, decorator, page=1 +      ModelDecorator.decorate( klass.page(page), with: decorator ) +    end + +    def build_paginated_collection factory, decorator, opts={} +      count = opts.delete(:count) || 2 +      page = opts.delete(:page) || 1 +      klass = nil +      count.times { klass ||= create(factory, opts).class } +      paginate_collection klass, decorator, page +    end    end    def self.included into @@ -47,3 +59,21 @@ RSpec::Matchers.define :have_the_right_number_of_links do |collection, count|    end    description { "have #{count} links for each item" }  end + +RSpec::Matchers.define :have_link_for_each_item do |collection, name, href| +  match do |actual| +    collection.each do |item| +      expect(rendered).to have_selector("tr.#{TableBuilderHelper.item_row_class_name(collection)}-#{item.id} .actions a[href='#{href.call(item)}']", count: 1) +    end +  end +  description { "have #{name} link for each item" } +end + +RSpec::Matchers.define :have_the_right_number_of_links do |collection, count| +  match do |actual| +    collection.each do |item| +      expect(rendered).to have_selector("tr.#{TableBuilderHelper.item_row_class_name(collection)}-#{item.id} .actions a", count: count) +    end +  end +  description { "have #{count} links for each item" } +end | 
