eBooru/test/unit/paginator_test.rb

97 lines
5.1 KiB
Ruby
Raw Normal View History

# frozen_string_literal: true
require "test_helper"
2018-04-14 11:51:29 -04:00
class PaginatorTest < ActiveSupport::TestCase
def assert_paginated(expected_records:, is_first_page:, is_last_page:, &)
records = yield
assert_equal(expected_records.map(&:id), records.map(&:id))
assert_equal(is_first_page, records.is_first_page?, "is_first_page")
assert_equal(is_last_page, records.is_last_page?, "is_last_page")
2018-04-14 11:51:29 -04:00
end
def assert_invalid_page_number(model, page)
assert_raises(Danbooru::Paginator::PaginationError) do
model.paginate(page)
end
end
{ active_record: Blip, opensearch: Post }.each do |type, model| # rubocop:disable Metrics/BlockLength
context type do
setup do
@user = create(:user)
CurrentUser.user = @user
end
context "sequential pagination (before)" do
should "return the correct set of records" do
@records = create_list(model.name.underscore, 4)
assert_paginated(expected_records: [], is_first_page: false, is_last_page: true) { model.paginate("b#{@records[0].id}", limit: 2) }
assert_paginated(expected_records: [@records[0]], is_first_page: false, is_last_page: true) { model.paginate("b#{@records[1].id}", limit: 2) }
assert_paginated(expected_records: [@records[1], @records[0]], is_first_page: false, is_last_page: true) { model.paginate("b#{@records[2].id}", limit: 2) }
assert_paginated(expected_records: [@records[2], @records[1]], is_first_page: false, is_last_page: false) { model.paginate("b#{@records[3].id}", limit: 2) }
assert_paginated(expected_records: [@records[3], @records[2]], is_first_page: false, is_last_page: false) { model.paginate("b999999999", limit: 2) }
end
end
2018-04-14 11:51:29 -04:00
context "sequential pagination (after)" do
should "return the correct set of records" do
@records = create_list(model.name.underscore, 4)
assert_paginated(expected_records: [@records[1], @records[0]], is_first_page: false, is_last_page: false) { model.paginate("a0", limit: 2) }
assert_paginated(expected_records: [@records[2], @records[1]], is_first_page: false, is_last_page: false) { model.paginate("a#{@records[0].id}", limit: 2) }
assert_paginated(expected_records: [@records[3], @records[2]], is_first_page: true, is_last_page: false) { model.paginate("a#{@records[1].id}", limit: 2) }
assert_paginated(expected_records: [@records[3]], is_first_page: true, is_last_page: false) { model.paginate("a#{@records[2].id}", limit: 2) }
assert_paginated(expected_records: [], is_first_page: true, is_last_page: false) { model.paginate("a#{@records[3].id}", limit: 2) }
end
end
2018-04-14 11:51:29 -04:00
context "numbered pagination" do
setup do
skip "flaky af" if ENV["CI"] && type == :opensearch
end
should "return the correct set of records" do
@records = create_list(model.name.underscore, 4)
assert_paginated(expected_records: [@records[0]], is_first_page: true, is_last_page: false) { model.paginate("1", limit: 1) }
assert_paginated(expected_records: [@records[1]], is_first_page: false, is_last_page: false) { model.paginate("2", limit: 1) }
assert_paginated(expected_records: [@records[2]], is_first_page: false, is_last_page: false) { model.paginate("3", limit: 1) }
assert_paginated(expected_records: [@records[3]], is_first_page: false, is_last_page: true) { model.paginate("4", limit: 1) }
assert_paginated(expected_records: [], is_first_page: false, is_last_page: true) { model.paginate("5", limit: 1) }
end
2018-04-14 11:51:29 -04:00
should "return the correct set of records when only one result exists" do
@records = create_list(model.name.underscore, 2)
assert_paginated(expected_records: [@records[0], @records[1]], is_first_page: true, is_last_page: true) { model.paginate("1", limit: 2) }
end
end
should "fail for invalid page numbers" do
assert_invalid_page_number(model, -1)
assert_invalid_page_number(model, "-1")
assert_invalid_page_number(model, "a")
assert_invalid_page_number(model, "751")
assert_invalid_page_number(model, "c1")
end
should "apply the correct limit" do
assert_equal(Danbooru.config.records_per_page, model.paginate(1).records_per_page)
assert_equal(10, model.paginate(1, limit: 10).records_per_page)
assert_equal(10, model.paginate(1, limit: "10").records_per_page)
assert_equal(320, model.paginate(1, limit: "321").records_per_page)
assert_equal(0, model.paginate(1, limit: "0").records_per_page)
assert_equal(0, model.paginate(1, limit: "-1").records_per_page)
assert_equal(0, model.paginate(1, limit: "a").records_per_page)
end
should "apply the correct limit when paginating posts" do
assert_equal(@user.per_page, model.paginate_posts(1).records_per_page)
assert_equal(10, model.paginate_posts(1, limit: 10).records_per_page)
@user.update_columns(per_page: 25)
assert_equal(25, model.paginate_posts(1).records_per_page)
assert_equal(10, model.paginate_posts(1, limit: 10).records_per_page)
end
2018-04-14 11:51:29 -04:00
end
end
end