2017-03-21 12:53:20 -04:00
|
|
|
defmodule Pleroma.UserTest do
|
|
|
|
alias Pleroma.Builders.UserBuilder
|
|
|
|
alias Pleroma.User
|
|
|
|
use Pleroma.DataCase
|
|
|
|
|
|
|
|
test "ap_id returns the activity pub id for the user" do
|
|
|
|
host =
|
|
|
|
Application.get_env(:pleroma, Pleroma.Web.Endpoint)
|
|
|
|
|> Keyword.fetch!(:url)
|
|
|
|
|> Keyword.fetch!(:host)
|
|
|
|
|
|
|
|
user = UserBuilder.build
|
|
|
|
|
|
|
|
expected_ap_id = "https://#{host}/users/#{user.nickname}"
|
|
|
|
|
|
|
|
assert expected_ap_id == User.ap_id(user)
|
|
|
|
end
|
|
|
|
|
|
|
|
test "ap_followers returns the followers collection for the user" do
|
|
|
|
user = UserBuilder.build
|
|
|
|
|
|
|
|
expected_followers_collection = "#{User.ap_id(user)}/followers"
|
|
|
|
|
|
|
|
assert expected_followers_collection == User.ap_followers(user)
|
|
|
|
end
|
2017-03-22 13:36:08 -04:00
|
|
|
|
2017-03-23 08:13:09 -04:00
|
|
|
test "follow takes a user and another user" do
|
2017-03-22 13:36:08 -04:00
|
|
|
{ :ok, user } = UserBuilder.insert
|
|
|
|
{ :ok, following } = UserBuilder.insert(%{nickname: "guy"})
|
|
|
|
|
|
|
|
{:ok, user } = User.follow(user, following)
|
|
|
|
|
|
|
|
user = Repo.get(User, user.id)
|
|
|
|
|
|
|
|
assert user.following == [User.ap_followers(following)]
|
|
|
|
end
|
2017-03-23 08:13:09 -04:00
|
|
|
|
|
|
|
test "unfollow takes a user and another user" do
|
|
|
|
{ :ok, following } = UserBuilder.insert(%{nickname: "guy"})
|
|
|
|
{ :ok, user } = UserBuilder.insert(%{following: [User.ap_followers(following)]})
|
|
|
|
|
|
|
|
{:ok, user } = User.unfollow(user, following)
|
|
|
|
|
|
|
|
user = Repo.get(User, user.id)
|
|
|
|
|
|
|
|
assert user.following == []
|
|
|
|
end
|
2017-03-23 10:51:34 -04:00
|
|
|
|
|
|
|
test "test if a user is following another user" do
|
|
|
|
{ :ok, followed } = UserBuilder.insert(%{nickname: "guy"})
|
|
|
|
{ :ok, user } = UserBuilder.insert(%{following: [User.ap_followers(followed)]})
|
|
|
|
|
|
|
|
assert User.following?(user, followed)
|
|
|
|
refute User.following?(followed, user)
|
|
|
|
end
|
2017-04-15 10:40:09 -04:00
|
|
|
|
|
|
|
describe "user registration" do
|
|
|
|
@full_user_data %{
|
|
|
|
bio: "A guy",
|
|
|
|
name: "my name",
|
|
|
|
nickname: "nick",
|
|
|
|
password: "test",
|
|
|
|
password_confirmation: "test",
|
|
|
|
email: "email@example.com"
|
|
|
|
}
|
|
|
|
|
|
|
|
test "it requires a bio, email, name, nickname and password" do
|
|
|
|
@full_user_data
|
|
|
|
|> Map.keys
|
|
|
|
|> Enum.each(fn (key) ->
|
|
|
|
params = Map.delete(@full_user_data, key)
|
|
|
|
changeset = User.register_changeset(%User{}, params)
|
|
|
|
assert changeset.valid? == false
|
|
|
|
end)
|
|
|
|
end
|
|
|
|
|
|
|
|
test "it sets the password_hash, ap_id and following fields" do
|
|
|
|
changeset = User.register_changeset(%User{}, @full_user_data)
|
|
|
|
|
|
|
|
assert changeset.valid?
|
|
|
|
|
|
|
|
assert is_binary(changeset.changes[:password_hash])
|
|
|
|
assert changeset.changes[:ap_id] == User.ap_id(%User{nickname: @full_user_data.nickname})
|
|
|
|
assert changeset.changes[:following] == [User.ap_followers(%User{nickname: @full_user_data.nickname})]
|
|
|
|
end
|
|
|
|
end
|
2017-03-21 12:53:20 -04:00
|
|
|
end
|