Add join/leave group
This commit is contained in:
@@ -499,9 +499,9 @@ defmodule Mobilizon.ActorsTest do
|
||||
alias Mobilizon.Actors.Member
|
||||
alias Mobilizon.Actors.Actor
|
||||
|
||||
@valid_attrs %{approved: true, role: 0}
|
||||
@update_attrs %{approved: false, role: 1}
|
||||
@invalid_attrs %{approved: nil, role: nil}
|
||||
@valid_attrs %{role: :member}
|
||||
@update_attrs %{role: :not_approved}
|
||||
@invalid_attrs %{role: nil}
|
||||
|
||||
setup do
|
||||
actor = insert(:actor)
|
||||
@@ -528,8 +528,7 @@ defmodule Mobilizon.ActorsTest do
|
||||
|> Map.put(:parent_id, group.id)
|
||||
|
||||
assert {:ok, %Member{} = member} = Actors.create_member(valid_attrs)
|
||||
assert member.approved == true
|
||||
assert member.role == 0
|
||||
assert member.role == :member
|
||||
|
||||
assert [group] = Actor.get_groups_member_of(actor)
|
||||
assert [actor] = Actor.get_members_for_group(group)
|
||||
@@ -562,8 +561,7 @@ defmodule Mobilizon.ActorsTest do
|
||||
member = create_test_member(context)
|
||||
assert {:ok, member} = Actors.update_member(member, @update_attrs)
|
||||
assert %Member{} = member
|
||||
assert member.approved == false
|
||||
assert member.role == 1
|
||||
assert member.role == :not_approved
|
||||
end
|
||||
|
||||
# This can't happen, since attrs are optional
|
||||
|
||||
@@ -115,7 +115,7 @@ defmodule MobilizonWeb.Resolvers.GroupResolverTest do
|
||||
|
||||
test "delete_group/3 deletes a group", %{conn: conn, user: user, actor: actor} do
|
||||
group = insert(:group)
|
||||
insert(:member, parent: group, actor: actor, role: 2)
|
||||
insert(:member, parent: group, actor: actor, role: :administrator)
|
||||
|
||||
mutation = """
|
||||
mutation {
|
||||
@@ -146,7 +146,7 @@ defmodule MobilizonWeb.Resolvers.GroupResolverTest do
|
||||
|
||||
test "delete_group/3 should check user authentication", %{conn: conn, actor: actor} do
|
||||
group = insert(:group)
|
||||
insert(:member, parent: group, actor: actor, role: 2)
|
||||
insert(:member, parent: group, actor: actor, role: :member)
|
||||
|
||||
mutation = """
|
||||
mutation {
|
||||
@@ -172,7 +172,7 @@ defmodule MobilizonWeb.Resolvers.GroupResolverTest do
|
||||
actor: actor
|
||||
} do
|
||||
group = insert(:group)
|
||||
insert(:member, parent: group, actor: actor, role: 2)
|
||||
insert(:member, parent: group, actor: actor, role: :member)
|
||||
|
||||
mutation = """
|
||||
mutation {
|
||||
@@ -225,7 +225,7 @@ defmodule MobilizonWeb.Resolvers.GroupResolverTest do
|
||||
actor: actor
|
||||
} do
|
||||
group = insert(:group)
|
||||
insert(:member, parent: group, actor: actor, role: 1)
|
||||
insert(:member, parent: group, actor: actor, role: :member)
|
||||
|
||||
mutation = """
|
||||
mutation {
|
||||
|
||||
289
test/mobilizon_web/resolvers/member_resolver_test.exs
Normal file
289
test/mobilizon_web/resolvers/member_resolver_test.exs
Normal file
@@ -0,0 +1,289 @@
|
||||
defmodule MobilizonWeb.Resolvers.MemberResolverTest do
|
||||
use MobilizonWeb.ConnCase
|
||||
|
||||
alias MobilizonWeb.AbsintheHelpers
|
||||
|
||||
import Mobilizon.Factory
|
||||
|
||||
setup %{conn: conn} do
|
||||
user = insert(:user)
|
||||
actor = insert(:actor, user: user, preferred_username: "test")
|
||||
|
||||
{:ok, conn: conn, actor: actor, user: user}
|
||||
end
|
||||
|
||||
describe "Member Resolver" do
|
||||
test "join_group/3 should create a member", %{conn: conn, user: user, actor: actor} do
|
||||
group = insert(:group)
|
||||
|
||||
mutation = """
|
||||
mutation {
|
||||
joinGroup(
|
||||
actor_id: #{actor.id},
|
||||
group_id: #{group.id}
|
||||
) {
|
||||
role,
|
||||
person {
|
||||
id
|
||||
},
|
||||
parent {
|
||||
id
|
||||
}
|
||||
}
|
||||
}
|
||||
"""
|
||||
|
||||
res =
|
||||
conn
|
||||
|> auth_conn(user)
|
||||
|> post("/api", AbsintheHelpers.mutation_skeleton(mutation))
|
||||
|
||||
assert json_response(res, 200)["errors"] == nil
|
||||
assert json_response(res, 200)["data"]["joinGroup"]["role"] == "not_approved"
|
||||
assert json_response(res, 200)["data"]["joinGroup"]["parent"]["id"] == group.id
|
||||
assert json_response(res, 200)["data"]["joinGroup"]["person"]["id"] == actor.id
|
||||
|
||||
mutation = """
|
||||
mutation {
|
||||
joinGroup(
|
||||
actor_id: #{actor.id},
|
||||
group_id: #{group.id}
|
||||
) {
|
||||
role
|
||||
}
|
||||
}
|
||||
"""
|
||||
|
||||
res =
|
||||
conn
|
||||
|> auth_conn(user)
|
||||
|> post("/api", AbsintheHelpers.mutation_skeleton(mutation))
|
||||
|
||||
assert hd(json_response(res, 200)["errors"])["message"] =~ "already a member"
|
||||
end
|
||||
|
||||
test "join_group/3 should check the actor is owned by the user", %{
|
||||
conn: conn,
|
||||
user: user
|
||||
} do
|
||||
group = insert(:group)
|
||||
|
||||
mutation = """
|
||||
mutation {
|
||||
joinGroup(
|
||||
actor_id: 1042,
|
||||
group_id: #{group.id}
|
||||
) {
|
||||
role
|
||||
}
|
||||
}
|
||||
"""
|
||||
|
||||
res =
|
||||
conn
|
||||
|> auth_conn(user)
|
||||
|> post("/api", AbsintheHelpers.mutation_skeleton(mutation))
|
||||
|
||||
assert hd(json_response(res, 200)["errors"])["message"] =~ "not owned"
|
||||
end
|
||||
|
||||
test "join_group/3 should check the group is not invite only", %{
|
||||
conn: conn,
|
||||
actor: actor,
|
||||
user: user
|
||||
} do
|
||||
group = insert(:group, %{openness: :invite_only})
|
||||
|
||||
mutation = """
|
||||
mutation {
|
||||
joinGroup(
|
||||
actor_id: #{actor.id},
|
||||
group_id: #{group.id}
|
||||
) {
|
||||
role
|
||||
}
|
||||
}
|
||||
"""
|
||||
|
||||
res =
|
||||
conn
|
||||
|> auth_conn(user)
|
||||
|> post("/api", AbsintheHelpers.mutation_skeleton(mutation))
|
||||
|
||||
assert hd(json_response(res, 200)["errors"])["message"] =~ "cannot join this group"
|
||||
end
|
||||
|
||||
test "join_group/3 should check the group exists", %{
|
||||
conn: conn,
|
||||
user: user,
|
||||
actor: actor
|
||||
} do
|
||||
mutation = """
|
||||
mutation {
|
||||
joinGroup(
|
||||
actor_id: #{actor.id},
|
||||
group_id: 1042
|
||||
) {
|
||||
role
|
||||
}
|
||||
}
|
||||
"""
|
||||
|
||||
res =
|
||||
conn
|
||||
|> auth_conn(user)
|
||||
|> post("/api", AbsintheHelpers.mutation_skeleton(mutation))
|
||||
|
||||
assert hd(json_response(res, 200)["errors"])["message"] =~ "Group id not found"
|
||||
end
|
||||
|
||||
test "leave_group/3 should delete a member from a group", %{
|
||||
conn: conn,
|
||||
user: user,
|
||||
actor: actor
|
||||
} do
|
||||
group = insert(:group)
|
||||
insert(:member, %{actor: actor, parent: group})
|
||||
|
||||
mutation = """
|
||||
mutation {
|
||||
leaveGroup(
|
||||
actor_id: #{actor.id},
|
||||
group_id: #{group.id}
|
||||
) {
|
||||
person {
|
||||
id
|
||||
},
|
||||
parent {
|
||||
id
|
||||
}
|
||||
}
|
||||
}
|
||||
"""
|
||||
|
||||
res =
|
||||
conn
|
||||
|> auth_conn(user)
|
||||
|> post("/api", AbsintheHelpers.mutation_skeleton(mutation))
|
||||
|
||||
assert json_response(res, 200)["errors"] == nil
|
||||
assert json_response(res, 200)["data"]["leaveGroup"]["parent"]["id"] == group.id
|
||||
assert json_response(res, 200)["data"]["leaveGroup"]["person"]["id"] == actor.id
|
||||
end
|
||||
|
||||
test "leave_group/3 should check if the member is the only administrator", %{
|
||||
conn: conn,
|
||||
actor: actor,
|
||||
user: user
|
||||
} do
|
||||
group = insert(:group)
|
||||
insert(:member, %{actor: actor, role: :creator, parent: group})
|
||||
insert(:member, %{parent: group})
|
||||
|
||||
mutation = """
|
||||
mutation {
|
||||
leaveGroup(
|
||||
actor_id: #{actor.id},
|
||||
group_id: #{group.id}
|
||||
) {
|
||||
person {
|
||||
id
|
||||
},
|
||||
parent {
|
||||
id
|
||||
}
|
||||
}
|
||||
}
|
||||
"""
|
||||
|
||||
res =
|
||||
conn
|
||||
|> auth_conn(user)
|
||||
|> post("/api", AbsintheHelpers.mutation_skeleton(mutation))
|
||||
|
||||
assert hd(json_response(res, 200)["errors"])["message"] =~ "only administrator"
|
||||
end
|
||||
|
||||
test "leave_group/3 should check the user is logged in", %{conn: conn, actor: actor} do
|
||||
group = insert(:group)
|
||||
insert(:member, %{actor: actor, parent: group})
|
||||
|
||||
mutation = """
|
||||
mutation {
|
||||
leaveGroup(
|
||||
actor_id: #{actor.id},
|
||||
group_id: #{group.id}
|
||||
) {
|
||||
person {
|
||||
id
|
||||
}
|
||||
}
|
||||
}
|
||||
"""
|
||||
|
||||
res =
|
||||
conn
|
||||
|> post("/api", AbsintheHelpers.mutation_skeleton(mutation))
|
||||
|
||||
assert hd(json_response(res, 200)["errors"])["message"] =~ "logged-in"
|
||||
end
|
||||
|
||||
test "leave_group/3 should check the actor is owned by the user", %{
|
||||
conn: conn,
|
||||
user: user,
|
||||
actor: actor
|
||||
} do
|
||||
group = insert(:group)
|
||||
insert(:member, %{actor: actor, parent: group})
|
||||
|
||||
mutation = """
|
||||
mutation {
|
||||
leaveGroup(
|
||||
actor_id: 1042,
|
||||
group_id: #{group.id}
|
||||
) {
|
||||
person {
|
||||
id
|
||||
}
|
||||
}
|
||||
}
|
||||
"""
|
||||
|
||||
res =
|
||||
conn
|
||||
|> auth_conn(user)
|
||||
|> post("/api", AbsintheHelpers.mutation_skeleton(mutation))
|
||||
|
||||
assert hd(json_response(res, 200)["errors"])["message"] =~ "not owned"
|
||||
end
|
||||
|
||||
test "leave_group/3 should check the member exists", %{
|
||||
conn: conn,
|
||||
user: user,
|
||||
actor: actor
|
||||
} do
|
||||
group = insert(:group)
|
||||
insert(:member, %{actor: actor, parent: group})
|
||||
|
||||
mutation = """
|
||||
mutation {
|
||||
leaveGroup(
|
||||
actor_id: #{actor.id},
|
||||
group_id: 1042
|
||||
) {
|
||||
person {
|
||||
id
|
||||
}
|
||||
}
|
||||
}
|
||||
"""
|
||||
|
||||
res =
|
||||
conn
|
||||
|> auth_conn(user)
|
||||
|> post("/api", AbsintheHelpers.mutation_skeleton(mutation))
|
||||
|
||||
assert hd(json_response(res, 200)["errors"])["message"] =~ "Member not found"
|
||||
end
|
||||
end
|
||||
end
|
||||
@@ -149,7 +149,7 @@ defmodule Mobilizon.Factory do
|
||||
%Mobilizon.Actors.Member{
|
||||
parent: build(:actor),
|
||||
actor: build(:actor),
|
||||
role: 0
|
||||
role: :not_approved
|
||||
}
|
||||
end
|
||||
end
|
||||
|
||||
Reference in New Issue
Block a user