2019-09-02 20:48:52 +01:00
|
|
|
# Pleroma: A lightweight social networking server
|
2021-01-13 06:49:20 +00:00
|
|
|
# Copyright © 2017-2021 Pleroma Authors <https://pleroma.social/>
|
2019-09-02 20:48:52 +01: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 20:48:52 +01: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 11:58:27 +01:00
|
|
|
|
|
|
|
%{total: total, items: paginated} =
|
2020-06-04 18:33:16 +01:00
|
|
|
Pagination.fetch_paginated(Object, %{min_id: id, total: true})
|
2019-09-02 20:48:52 +01: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 11:58:27 +01:00
|
|
|
|
|
|
|
%{total: total, items: paginated} =
|
2020-06-04 18:33:16 +01:00
|
|
|
Pagination.fetch_paginated(Object, %{since_id: id, total: true})
|
2019-09-02 20:48:52 +01: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 11:58:27 +01:00
|
|
|
|
|
|
|
%{total: total, items: paginated} =
|
2020-06-04 18:33:16 +01:00
|
|
|
Pagination.fetch_paginated(Object, %{max_id: id, total: true})
|
2019-09-02 20:48:52 +01: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 18:33:16 +01:00
|
|
|
paginated = Pagination.fetch_paginated(Object, %{min_id: id, limit: 1})
|
2019-09-02 20:48:52 +01:00
|
|
|
|
|
|
|
assert length(paginated) == 1
|
|
|
|
end
|
2020-07-17 03:39:10 +01: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 20:48:52 +01:00
|
|
|
end
|
|
|
|
|
|
|
|
describe "offset" do
|
|
|
|
setup do
|
|
|
|
notes = insert_list(5, :note)
|
|
|
|
|
|
|
|
%{notes: notes}
|
|
|
|
end
|
|
|
|
|
|
|
|
test "paginates by limit" do
|
2020-06-04 18:33:16 +01:00
|
|
|
paginated = Pagination.fetch_paginated(Object, %{limit: 2}, :offset)
|
2019-09-02 20:48:52 +01:00
|
|
|
|
|
|
|
assert length(paginated) == 2
|
|
|
|
end
|
|
|
|
|
|
|
|
test "paginates by limit & offset" do
|
2020-06-04 18:33:16 +01:00
|
|
|
paginated = Pagination.fetch_paginated(Object, %{limit: 2, offset: 4}, :offset)
|
2019-09-02 20:48:52 +01:00
|
|
|
|
|
|
|
assert length(paginated) == 1
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|