2019-09-02 19:48:52 +00:00
|
|
|
# Pleroma: A lightweight social networking server
|
2023-01-01 11:11:47 +00:00
|
|
|
# Copyright © 2017-2023 Pleroma Authors <https://pleroma.social/>
|
2019-09-02 19:48:52 +00:00
|
|
|
# SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
|
|
|
|
defmodule Pleroma.PaginationTest do
|
2020-12-21 11:21:40 +00:00
|
|
|
use Pleroma.DataCase, async: true
|
2019-09-02 19:48:52 +00:00
|
|
|
|
|
|
|
import Pleroma.Factory
|
|
|
|
|
|
|
|
alias Pleroma.Object
|
|
|
|
alias Pleroma.Pagination
|
|
|
|
|
|
|
|
describe "keyset" do
|
|
|
|
setup do
|
|
|
|
notes = insert_list(5, :note)
|
|
|
|
|
|
|
|
%{notes: notes}
|
|
|
|
end
|
|
|
|
|
|
|
|
test "paginates by min_id", %{notes: notes} do
|
|
|
|
id = Enum.at(notes, 2).id |> Integer.to_string()
|
2019-09-03 10:58:27 +00:00
|
|
|
|
|
|
|
%{total: total, items: paginated} =
|
2020-06-04 17:33:16 +00:00
|
|
|
Pagination.fetch_paginated(Object, %{min_id: id, total: true})
|
2019-09-02 19:48:52 +00:00
|
|
|
|
|
|
|
assert length(paginated) == 2
|
|
|
|
assert total == 5
|
|
|
|
end
|
|
|
|
|
|
|
|
test "paginates by since_id", %{notes: notes} do
|
|
|
|
id = Enum.at(notes, 2).id |> Integer.to_string()
|
2019-09-03 10:58:27 +00:00
|
|
|
|
|
|
|
%{total: total, items: paginated} =
|
2020-06-04 17:33:16 +00:00
|
|
|
Pagination.fetch_paginated(Object, %{since_id: id, total: true})
|
2019-09-02 19:48:52 +00:00
|
|
|
|
|
|
|
assert length(paginated) == 2
|
|
|
|
assert total == 5
|
|
|
|
end
|
|
|
|
|
|
|
|
test "paginates by max_id", %{notes: notes} do
|
|
|
|
id = Enum.at(notes, 1).id |> Integer.to_string()
|
2019-09-03 10:58:27 +00:00
|
|
|
|
|
|
|
%{total: total, items: paginated} =
|
2020-06-04 17:33:16 +00:00
|
|
|
Pagination.fetch_paginated(Object, %{max_id: id, total: true})
|
2019-09-02 19:48:52 +00:00
|
|
|
|
|
|
|
assert length(paginated) == 1
|
|
|
|
assert total == 5
|
|
|
|
end
|
|
|
|
|
|
|
|
test "paginates by min_id & limit", %{notes: notes} do
|
|
|
|
id = Enum.at(notes, 2).id |> Integer.to_string()
|
|
|
|
|
2020-06-04 17:33:16 +00:00
|
|
|
paginated = Pagination.fetch_paginated(Object, %{min_id: id, limit: 1})
|
2019-09-02 19:48:52 +00:00
|
|
|
|
|
|
|
assert length(paginated) == 1
|
|
|
|
end
|
2020-07-17 02:39:10 +00:00
|
|
|
|
|
|
|
test "handles id gracefully", %{notes: notes} do
|
|
|
|
id = Enum.at(notes, 1).id |> Integer.to_string()
|
|
|
|
|
|
|
|
paginated =
|
|
|
|
Pagination.fetch_paginated(Object, %{
|
|
|
|
id: "9s99Hq44Cnv8PKBwWG",
|
|
|
|
max_id: id,
|
|
|
|
limit: 20,
|
|
|
|
offset: 0
|
|
|
|
})
|
|
|
|
|
|
|
|
assert length(paginated) == 1
|
|
|
|
end
|
2019-09-02 19:48:52 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
describe "offset" do
|
|
|
|
setup do
|
|
|
|
notes = insert_list(5, :note)
|
|
|
|
|
|
|
|
%{notes: notes}
|
|
|
|
end
|
|
|
|
|
|
|
|
test "paginates by limit" do
|
2020-06-04 17:33:16 +00:00
|
|
|
paginated = Pagination.fetch_paginated(Object, %{limit: 2}, :offset)
|
2019-09-02 19:48:52 +00:00
|
|
|
|
|
|
|
assert length(paginated) == 2
|
|
|
|
end
|
|
|
|
|
|
|
|
test "paginates by limit & offset" do
|
2020-06-04 17:33:16 +00:00
|
|
|
paginated = Pagination.fetch_paginated(Object, %{limit: 2, offset: 4}, :offset)
|
2019-09-02 19:48:52 +00:00
|
|
|
|
|
|
|
assert length(paginated) == 1
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|