Chris@909: require File.dirname(__FILE__) + '/helper' Chris@909: require File.dirname(__FILE__) + '/../init' Chris@909: Chris@909: class PaginationTest < ActiveRecordTestCase Chris@909: fixtures :topics, :replies, :developers, :projects, :developers_projects Chris@909: Chris@909: class PaginationController < ActionController::Base Chris@909: if respond_to? :view_paths= Chris@909: self.view_paths = [ "#{File.dirname(__FILE__)}/../fixtures/" ] Chris@909: else Chris@909: self.template_root = [ "#{File.dirname(__FILE__)}/../fixtures/" ] Chris@909: end Chris@909: Chris@909: def simple_paginate Chris@909: @topic_pages, @topics = paginate(:topics) Chris@909: render :nothing => true Chris@909: end Chris@909: Chris@909: def paginate_with_per_page Chris@909: @topic_pages, @topics = paginate(:topics, :per_page => 1) Chris@909: render :nothing => true Chris@909: end Chris@909: Chris@909: def paginate_with_order Chris@909: @topic_pages, @topics = paginate(:topics, :order => 'created_at asc') Chris@909: render :nothing => true Chris@909: end Chris@909: Chris@909: def paginate_with_order_by Chris@909: @topic_pages, @topics = paginate(:topics, :order_by => 'created_at asc') Chris@909: render :nothing => true Chris@909: end Chris@909: Chris@909: def paginate_with_include_and_order Chris@909: @topic_pages, @topics = paginate(:topics, :include => :replies, :order => 'replies.created_at asc, topics.created_at asc') Chris@909: render :nothing => true Chris@909: end Chris@909: Chris@909: def paginate_with_conditions Chris@909: @topic_pages, @topics = paginate(:topics, :conditions => ["created_at > ?", 30.minutes.ago]) Chris@909: render :nothing => true Chris@909: end Chris@909: Chris@909: def paginate_with_class_name Chris@909: @developer_pages, @developers = paginate(:developers, :class_name => "DeVeLoPeR") Chris@909: render :nothing => true Chris@909: end Chris@909: Chris@909: def paginate_with_singular_name Chris@909: @developer_pages, @developers = paginate() Chris@909: render :nothing => true Chris@909: end Chris@909: Chris@909: def paginate_with_joins Chris@909: @developer_pages, @developers = paginate(:developers, Chris@909: :joins => 'LEFT JOIN developers_projects ON developers.id = developers_projects.developer_id', Chris@909: :conditions => 'project_id=1') Chris@909: render :nothing => true Chris@909: end Chris@909: Chris@909: def paginate_with_join Chris@909: @developer_pages, @developers = paginate(:developers, Chris@909: :join => 'LEFT JOIN developers_projects ON developers.id = developers_projects.developer_id', Chris@909: :conditions => 'project_id=1') Chris@909: render :nothing => true Chris@909: end Chris@909: Chris@909: def paginate_with_join_and_count Chris@909: @developer_pages, @developers = paginate(:developers, Chris@909: :join => 'd LEFT JOIN developers_projects ON d.id = developers_projects.developer_id', Chris@909: :conditions => 'project_id=1', Chris@909: :count => "d.id") Chris@909: render :nothing => true Chris@909: end Chris@909: Chris@909: def paginate_with_join_and_group Chris@909: @developer_pages, @developers = paginate(:developers, Chris@909: :join => 'INNER JOIN developers_projects ON developers.id = developers_projects.developer_id', Chris@909: :group => 'developers.id') Chris@909: render :nothing => true Chris@909: end Chris@909: Chris@909: def rescue_errors(e) raise e end Chris@909: Chris@909: def rescue_action(e) raise end Chris@909: Chris@909: end Chris@909: Chris@909: def setup Chris@909: @controller = PaginationController.new Chris@909: @request = ActionController::TestRequest.new Chris@909: @response = ActionController::TestResponse.new Chris@909: super Chris@909: end Chris@909: Chris@909: # Single Action Pagination Tests Chris@909: Chris@909: def test_simple_paginate Chris@909: get :simple_paginate Chris@909: assert_equal 1, assigns(:topic_pages).page_count Chris@909: assert_equal 3, assigns(:topics).size Chris@909: end Chris@909: Chris@909: def test_paginate_with_per_page Chris@909: get :paginate_with_per_page Chris@909: assert_equal 1, assigns(:topics).size Chris@909: assert_equal 3, assigns(:topic_pages).page_count Chris@909: end Chris@909: Chris@909: def test_paginate_with_order Chris@909: get :paginate_with_order Chris@909: expected = [topics(:futurama), Chris@909: topics(:harvey_birdman), Chris@909: topics(:rails)] Chris@909: assert_equal expected, assigns(:topics) Chris@909: assert_equal 1, assigns(:topic_pages).page_count Chris@909: end Chris@909: Chris@909: def test_paginate_with_order_by Chris@909: get :paginate_with_order Chris@909: expected = assigns(:topics) Chris@909: get :paginate_with_order_by Chris@909: assert_equal expected, assigns(:topics) Chris@909: assert_equal 1, assigns(:topic_pages).page_count Chris@909: end Chris@909: Chris@909: def test_paginate_with_conditions Chris@909: get :paginate_with_conditions Chris@909: expected = [topics(:rails)] Chris@909: assert_equal expected, assigns(:topics) Chris@909: assert_equal 1, assigns(:topic_pages).page_count Chris@909: end Chris@909: Chris@909: def test_paginate_with_class_name Chris@909: get :paginate_with_class_name Chris@909: Chris@909: assert assigns(:developers).size > 0 Chris@909: assert_equal DeVeLoPeR, assigns(:developers).first.class Chris@909: end Chris@909: Chris@909: def test_paginate_with_joins Chris@909: get :paginate_with_joins Chris@909: assert_equal 2, assigns(:developers).size Chris@909: developer_names = assigns(:developers).map { |d| d.name } Chris@909: assert developer_names.include?('David') Chris@909: assert developer_names.include?('Jamis') Chris@909: end Chris@909: Chris@909: def test_paginate_with_join_and_conditions Chris@909: get :paginate_with_joins Chris@909: expected = assigns(:developers) Chris@909: get :paginate_with_join Chris@909: assert_equal expected, assigns(:developers) Chris@909: end Chris@909: Chris@909: def test_paginate_with_join_and_count Chris@909: get :paginate_with_joins Chris@909: expected = assigns(:developers) Chris@909: get :paginate_with_join_and_count Chris@909: assert_equal expected, assigns(:developers) Chris@909: end Chris@909: Chris@909: def test_paginate_with_include_and_order Chris@909: get :paginate_with_include_and_order Chris@909: expected = Topic.find(:all, :include => 'replies', :order => 'replies.created_at asc, topics.created_at asc', :limit => 10) Chris@909: assert_equal expected, assigns(:topics) Chris@909: end Chris@909: Chris@909: def test_paginate_with_join_and_group Chris@909: get :paginate_with_join_and_group Chris@909: assert_equal 2, assigns(:developers).size Chris@909: assert_equal 2, assigns(:developer_pages).item_count Chris@909: developer_names = assigns(:developers).map { |d| d.name } Chris@909: assert developer_names.include?('David') Chris@909: assert developer_names.include?('Jamis') Chris@909: end Chris@909: end