2019-09-02 13:48:52 -06:00
|
|
|
# Pleroma: A lightweight social networking server
|
2020-03-03 15:44:49 -07:00
|
|
|
# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/>
|
2019-09-02 13:48:52 -06:00
|
|
|
# SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
|
|
|
|
defmodule Pleroma.PaginationTest do
|
2020-12-21 04:21:40 -07:00
|
|
|
use Pleroma.DataCase, async: true
|
2019-09-02 13:48:52 -06: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 04:58:27 -06:00
|
|
|
|
|
|
|
%{total: total, items: paginated} =
|
2020-06-04 11:33:16 -06:00
|
|
|
Pagination.fetch_paginated(Object, %{min_id: id, total: true})
|
2019-09-02 13:48:52 -06: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 04:58:27 -06:00
|
|
|
|
|
|
|
%{total: total, items: paginated} =
|
2020-06-04 11:33:16 -06:00
|
|
|
Pagination.fetch_paginated(Object, %{since_id: id, total: true})
|
2019-09-02 13:48:52 -06: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 04:58:27 -06:00
|
|
|
|
|
|
|
%{total: total, items: paginated} =
|
2020-06-04 11:33:16 -06:00
|
|
|
Pagination.fetch_paginated(Object, %{max_id: id, total: true})
|
2019-09-02 13:48:52 -06: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 11:33:16 -06:00
|
|
|
paginated = Pagination.fetch_paginated(Object, %{min_id: id, limit: 1})
|
2019-09-02 13:48:52 -06:00
|
|
|
|
|
|
|
assert length(paginated) == 1
|
|
|
|
end
|
2020-07-16 20:39:10 -06: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 13:48:52 -06:00
|
|
|
end
|
|
|
|
|
|
|
|
describe "offset" do
|
|
|
|
setup do
|
|
|
|
notes = insert_list(5, :note)
|
|
|
|
|
|
|
|
%{notes: notes}
|
|
|
|
end
|
|
|
|
|
|
|
|
test "paginates by limit" do
|
2020-06-04 11:33:16 -06:00
|
|
|
paginated = Pagination.fetch_paginated(Object, %{limit: 2}, :offset)
|
2019-09-02 13:48:52 -06:00
|
|
|
|
|
|
|
assert length(paginated) == 2
|
|
|
|
end
|
|
|
|
|
|
|
|
test "paginates by limit & offset" do
|
2020-06-04 11:33:16 -06:00
|
|
|
paginated = Pagination.fetch_paginated(Object, %{limit: 2, offset: 4}, :offset)
|
2019-09-02 13:48:52 -06:00
|
|
|
|
|
|
|
assert length(paginated) == 1
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|