memEx/test/memex/accounts/invites_test.exs

205 lines
7.6 KiB
Elixir
Raw Permalink Normal View History

2023-02-26 00:47:51 -05:00
defmodule Memex.InvitesTest do
2023-02-04 14:14:45 -05:00
@moduledoc """
2023-02-26 00:47:51 -05:00
This module tests the Memex.Accounts.Invites context
2023-02-04 14:14:45 -05:00
"""
2023-04-14 23:50:16 -04:00
use Memex.DataCase, async: true
2023-02-04 14:14:45 -05:00
alias Ecto.Changeset
2023-02-26 00:47:51 -05:00
alias Memex.Accounts
alias Memex.Accounts.{Invite, Invites}
2023-02-04 14:14:45 -05:00
@moduletag :invites_test
@valid_attrs %{
2023-03-22 22:08:37 -04:00
name: "some name"
2023-02-04 14:14:45 -05:00
}
@invalid_attrs %{
2023-03-22 22:08:37 -04:00
name: nil,
token: nil
2023-02-04 14:14:45 -05:00
}
describe "invites" do
setup do
current_user = admin_fixture()
{:ok, invite} = Invites.create_invite(current_user, @valid_attrs)
[invite: invite, current_user: current_user]
end
test "list_invites/0 returns all invites", %{invite: invite, current_user: current_user} do
assert Invites.list_invites(current_user) == [invite]
end
test "get_invite!/1 returns the invite with given id",
%{invite: invite, current_user: current_user} do
assert Invites.get_invite!(invite.id, current_user) == invite
end
test "valid_invite_token? returns for valid and invalid invite tokens",
%{invite: %{token: token}} do
refute Invites.valid_invite_token?(nil)
refute Invites.valid_invite_token?("")
assert Invites.valid_invite_token?(token)
end
test "valid_invite_token? does not return true for a disabled invite by token",
%{invite: %{token: token} = invite, current_user: current_user} do
assert Invites.valid_invite_token?(token)
{:ok, _invite} = Invites.update_invite(invite, %{uses_left: 1}, current_user)
{:ok, _invite} = Invites.use_invite(token)
refute Invites.valid_invite_token?(token)
end
2023-02-04 16:11:58 -05:00
test "get_use_count/2 returns the correct invite usage",
%{invite: %{token: token} = invite, current_user: current_user} do
2023-03-18 13:46:26 -04:00
assert Invites.get_use_count(invite, current_user) |> is_nil()
2023-02-04 16:11:58 -05:00
assert {:ok, _user} =
Accounts.register_user(
2023-03-22 22:08:37 -04:00
%{email: unique_user_email(), password: valid_user_password()},
2023-02-04 16:11:58 -05:00
token
)
assert 1 == Invites.get_use_count(invite, current_user)
assert {:ok, _user} =
Accounts.register_user(
2023-03-22 22:08:37 -04:00
%{email: unique_user_email(), password: valid_user_password()},
2023-02-04 16:11:58 -05:00
token
)
assert 2 == Invites.get_use_count(invite, current_user)
end
2023-03-18 13:46:26 -04:00
test "get_use_counts/2 returns the correct invite usage",
%{invite: %{id: invite_id, token: token} = invite, current_user: current_user} do
{:ok, %{id: another_invite_id, token: another_token} = another_invite} =
Invites.create_invite(current_user, @valid_attrs)
assert [invite, another_invite] |> Invites.get_use_counts(current_user) == %{}
assert {:ok, _user} =
Accounts.register_user(
2023-03-22 22:08:37 -04:00
%{email: unique_user_email(), password: valid_user_password()},
2023-03-18 13:46:26 -04:00
token
)
assert {:ok, _user} =
Accounts.register_user(
2023-03-22 22:08:37 -04:00
%{email: unique_user_email(), password: valid_user_password()},
2023-03-18 13:46:26 -04:00
another_token
)
use_counts = [invite, another_invite] |> Invites.get_use_counts(current_user)
assert %{^invite_id => 1} = use_counts
assert %{^another_invite_id => 1} = use_counts
assert {:ok, _user} =
Accounts.register_user(
2023-03-22 22:08:37 -04:00
%{email: unique_user_email(), password: valid_user_password()},
2023-03-18 13:46:26 -04:00
token
)
use_counts = [invite, another_invite] |> Invites.get_use_counts(current_user)
assert %{^invite_id => 2} = use_counts
assert %{^another_invite_id => 1} = use_counts
end
2023-02-04 14:14:45 -05:00
test "use_invite/1 successfully uses an unlimited invite",
%{invite: %{token: token} = invite, current_user: current_user} do
{:ok, invite} = Invites.update_invite(invite, %{uses_left: nil}, current_user)
assert {:ok, ^invite} = Invites.use_invite(token)
assert {:ok, ^invite} = Invites.use_invite(token)
assert {:ok, ^invite} = Invites.use_invite(token)
end
2023-02-04 16:11:58 -05:00
test "use_invite/1 successfully decrements an invite",
%{invite: %{token: token} = invite, current_user: current_user} do
{:ok, _invite} = Invites.update_invite(invite, %{uses_left: 10}, current_user)
2023-02-04 14:14:45 -05:00
assert {:ok, %{uses_left: 9}} = Invites.use_invite(token)
assert {:ok, %{uses_left: 8}} = Invites.use_invite(token)
assert {:ok, %{uses_left: 7}} = Invites.use_invite(token)
end
test "use_invite/1 successfully disactivates an invite",
%{invite: %{token: token} = invite, current_user: current_user} do
{:ok, _invite} = Invites.update_invite(invite, %{uses_left: 1}, current_user)
assert {:ok, %{uses_left: 0, disabled_at: disabled_at}} = Invites.use_invite(token)
assert not is_nil(disabled_at)
end
test "use_invite/1 does not work on disactivated invite",
%{invite: %{token: token} = invite, current_user: current_user} do
{:ok, _invite} = Invites.update_invite(invite, %{uses_left: 1}, current_user)
{:ok, _invite} = Invites.use_invite(token)
assert {:error, :invalid_token} = Invites.use_invite(token)
end
2023-02-04 16:11:58 -05:00
test "create_invite/1 with valid data creates an unlimited invite",
%{current_user: current_user} do
2023-03-22 22:08:37 -04:00
assert {:ok, %Invite{} = invite} = Invites.create_invite(current_user, %{name: "some name"})
2023-02-04 16:11:58 -05:00
assert invite.name == "some name"
end
test "create_invite/1 with valid data creates a limited invite",
2023-02-04 14:14:45 -05:00
%{current_user: current_user} do
2023-02-04 16:11:58 -05:00
assert {:ok, %Invite{} = invite} =
2023-03-22 22:08:37 -04:00
Invites.create_invite(current_user, %{name: "some name", uses_left: 10})
2023-02-04 16:11:58 -05:00
2023-02-04 14:14:45 -05:00
assert invite.name == "some name"
2023-02-04 16:11:58 -05:00
assert invite.uses_left == 10
2023-02-04 14:14:45 -05:00
end
test "create_invite/1 with invalid data returns error changeset",
%{current_user: current_user} do
assert {:error, %Changeset{}} = Invites.create_invite(current_user, @invalid_attrs)
end
2023-02-04 16:11:58 -05:00
test "update_invite/2 can set an invite to be limited",
2023-02-04 14:14:45 -05:00
%{invite: invite, current_user: current_user} do
assert {:ok, %Invite{} = new_invite} =
2023-02-04 16:11:58 -05:00
Invites.update_invite(
invite,
2023-03-22 22:08:37 -04:00
%{name: "some updated name", uses_left: 5},
2023-02-04 16:11:58 -05:00
current_user
)
2023-02-04 14:14:45 -05:00
assert new_invite.name == "some updated name"
assert new_invite.uses_left == 5
end
2023-02-04 16:11:58 -05:00
test "update_invite/2 can set an invite to be unlimited",
%{invite: invite, current_user: current_user} do
{:ok, invite} = Invites.update_invite(invite, %{"uses_left" => 5}, current_user)
assert {:ok, %Invite{} = new_invite} =
Invites.update_invite(
invite,
2023-03-22 22:08:37 -04:00
%{name: "some updated name", uses_left: nil},
2023-02-04 16:11:58 -05:00
current_user
)
assert new_invite.name == "some updated name"
assert new_invite.uses_left |> is_nil()
end
2023-02-04 14:14:45 -05:00
test "update_invite/2 with invalid data returns error changeset",
%{invite: invite, current_user: current_user} do
assert {:error, %Changeset{}} = Invites.update_invite(invite, @invalid_attrs, current_user)
assert invite == Invites.get_invite!(invite.id, current_user)
end
test "delete_invite/1 deletes the invite", %{invite: invite, current_user: current_user} do
assert {:ok, %Invite{}} = Invites.delete_invite(invite, current_user)
assert_raise Ecto.NoResultsError, fn -> Invites.get_invite!(invite.id, current_user) end
end
test "delete_invite!/1 deletes the invite", %{invite: invite, current_user: current_user} do
assert %Invite{} = Invites.delete_invite!(invite, current_user)
assert_raise Ecto.NoResultsError, fn -> Invites.get_invite!(invite.id, current_user) end
end
end
end