FloatingGhost
98cb255d12
Some checks failed
ci/woodpecker/push/build-amd64 Pipeline is pending
ci/woodpecker/push/build-arm64 Pipeline is pending
ci/woodpecker/push/docs Pipeline is pending
ci/woodpecker/push/test Pipeline is pending
ci/woodpecker/pr/test Pipeline failed
ci/woodpecker/pr/build-amd64 unknown status
ci/woodpecker/pr/build-arm64 unknown status
ci/woodpecker/pr/docs unknown status
OTP builds to 1.15
Changelog entry
Ensure policies are fully loaded
Fix :warn
use main branch for linkify
Fix warn in tests
Migrations for phoenix 1.17
Revert "Migrations for phoenix 1.17"
This reverts commit 6a3b2f15b7
.
Oban upgrade
Add default empty whitelist
mix format
limit test to amd64
OTP 26 tests for 1.15
use OTP_VERSION tag
baka
just 1.15
Massive deps update
Update locale, deps
Mix format
shell????
multiline???
?
max cases 1
use assert_recieve
don't put_env in async tests
don't async conn/fs tests
mix format
FIx some uploader issues
Fix tests
216 lines
5.6 KiB
Elixir
216 lines
5.6 KiB
Elixir
# Pleroma: A lightweight social networking server
|
|
# Copyright © 2017-2021 Pleroma Authors <https://pleroma.social/>
|
|
# SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
defmodule Pleroma.Web.AdminAPI.SearchTest do
|
|
use Pleroma.Web.ConnCase, async: false
|
|
|
|
alias Pleroma.Web.AdminAPI.Search
|
|
|
|
import Pleroma.Factory
|
|
|
|
describe "search for admin" do
|
|
test "it ignores case" do
|
|
insert(:user, nickname: "papercoach")
|
|
insert(:user, nickname: "CanadaPaperCoach")
|
|
|
|
{:ok, _results, count} =
|
|
Search.user(%{
|
|
query: "paper",
|
|
local: false,
|
|
page: 1,
|
|
page_size: 50
|
|
})
|
|
|
|
assert count == 2
|
|
end
|
|
|
|
test "it returns local/external users" do
|
|
insert(:user, local: true)
|
|
insert(:user, local: false)
|
|
insert(:user, local: false)
|
|
|
|
{:ok, _results, local_count} =
|
|
Search.user(%{
|
|
query: "",
|
|
local: true
|
|
})
|
|
|
|
{:ok, _results, external_count} =
|
|
Search.user(%{
|
|
query: "",
|
|
external: true
|
|
})
|
|
|
|
assert local_count == 1
|
|
assert external_count == 2
|
|
end
|
|
|
|
test "it returns active/deactivated users" do
|
|
insert(:user, is_active: false)
|
|
insert(:user, is_active: false)
|
|
insert(:user, is_active: true)
|
|
|
|
{:ok, _results, active_count} =
|
|
Search.user(%{
|
|
query: "",
|
|
active: true
|
|
})
|
|
|
|
{:ok, _results, deactivated_count} =
|
|
Search.user(%{
|
|
query: "",
|
|
deactivated: true
|
|
})
|
|
|
|
assert active_count == 1
|
|
assert deactivated_count == 2
|
|
end
|
|
|
|
test "it returns specific user" do
|
|
insert(:user)
|
|
insert(:user)
|
|
user = insert(:user, nickname: "bob", local: true, is_active: true)
|
|
|
|
{:ok, _results, total_count} = Search.user(%{query: ""})
|
|
|
|
{:ok, [^user], count} =
|
|
Search.user(%{
|
|
query: "Bo",
|
|
active: true,
|
|
local: true
|
|
})
|
|
|
|
assert total_count == 3
|
|
assert count == 1
|
|
end
|
|
|
|
test "it returns user by domain" do
|
|
insert(:user)
|
|
insert(:user)
|
|
user = insert(:user, nickname: "some@domain.com")
|
|
|
|
{:ok, _results, total} = Search.user()
|
|
{:ok, [^user], count} = Search.user(%{query: "domain.com"})
|
|
assert total == 3
|
|
assert count == 1
|
|
end
|
|
|
|
test "it return user by full nickname" do
|
|
insert(:user)
|
|
insert(:user)
|
|
user = insert(:user, nickname: "some@domain.com")
|
|
|
|
{:ok, _results, total} = Search.user()
|
|
{:ok, [^user], count} = Search.user(%{query: "some@domain.com"})
|
|
assert total == 3
|
|
assert count == 1
|
|
end
|
|
|
|
test "it returns admin user" do
|
|
admin = insert(:user, is_admin: true)
|
|
insert(:user)
|
|
insert(:user)
|
|
|
|
{:ok, _results, total} = Search.user()
|
|
{:ok, [^admin], count} = Search.user(%{is_admin: true})
|
|
assert total == 3
|
|
assert count == 1
|
|
end
|
|
|
|
test "it returns moderator user" do
|
|
moderator = insert(:user, is_moderator: true)
|
|
insert(:user)
|
|
insert(:user)
|
|
|
|
{:ok, _results, total} = Search.user()
|
|
{:ok, [^moderator], count} = Search.user(%{is_moderator: true})
|
|
assert total == 3
|
|
assert count == 1
|
|
end
|
|
|
|
test "it returns users with tags" do
|
|
user1 = insert(:user, tags: ["first"])
|
|
user2 = insert(:user, tags: ["second"])
|
|
insert(:user)
|
|
insert(:user)
|
|
|
|
{:ok, _results, total} = Search.user()
|
|
{:ok, users, count} = Search.user(%{tags: ["first", "second"]})
|
|
assert total == 4
|
|
assert count == 2
|
|
assert user1 in users
|
|
assert user2 in users
|
|
end
|
|
|
|
test "it returns users by actor_types" do
|
|
user_service = insert(:user, actor_type: "Service")
|
|
user_application = insert(:user, actor_type: "Application")
|
|
user1 = insert(:user)
|
|
user2 = insert(:user)
|
|
|
|
{:ok, [^user_service], 1} = Search.user(%{actor_types: ["Service"]})
|
|
{:ok, [^user_application], 1} = Search.user(%{actor_types: ["Application"]})
|
|
{:ok, [^user2, ^user1], 2} = Search.user(%{actor_types: ["Person"]})
|
|
|
|
{:ok, [^user2, ^user1, ^user_service], 3} =
|
|
Search.user(%{actor_types: ["Person", "Service"]})
|
|
end
|
|
|
|
test "it returns user by display name" do
|
|
user = insert(:user, name: "Display name")
|
|
insert(:user)
|
|
insert(:user)
|
|
|
|
{:ok, _results, total} = Search.user()
|
|
{:ok, [^user], count} = Search.user(%{name: "display"})
|
|
|
|
assert total == 3
|
|
assert count == 1
|
|
end
|
|
|
|
test "it returns user by email" do
|
|
user = insert(:user, email: "some@example.com")
|
|
insert(:user)
|
|
insert(:user)
|
|
|
|
{:ok, _results, total} = Search.user()
|
|
{:ok, [^user], count} = Search.user(%{email: "some@example.com"})
|
|
|
|
assert total == 3
|
|
assert count == 1
|
|
end
|
|
|
|
test "it returns unapproved user" do
|
|
unapproved = insert(:user, is_approved: false)
|
|
insert(:user)
|
|
insert(:user)
|
|
|
|
{:ok, _results, total} = Search.user()
|
|
{:ok, [^unapproved], count} = Search.user(%{need_approval: true})
|
|
assert total == 3
|
|
assert count == 1
|
|
end
|
|
|
|
test "it returns unconfirmed user" do
|
|
unconfirmed = insert(:user, is_confirmed: false)
|
|
insert(:user)
|
|
insert(:user)
|
|
|
|
{:ok, _results, total} = Search.user()
|
|
{:ok, [^unconfirmed], count} = Search.user(%{unconfirmed: true})
|
|
assert total == 3
|
|
assert count == 1
|
|
end
|
|
|
|
# Note: as in Mastodon, `is_discoverable` doesn't anyhow relate to user searchability
|
|
test "it returns non-discoverable users" do
|
|
insert(:user)
|
|
insert(:user, is_discoverable: false)
|
|
|
|
{:ok, _results, total} = Search.user()
|
|
|
|
assert total == 2
|
|
end
|
|
end
|
|
end
|