1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
|
defmodule Chessh.Auth.UserRegistrationTest do
use Chessh.RepoCase
use ExUnit.Case
alias Chessh.{Player, Repo}
@valid_user %{username: "logan", password: "password"}
@invalid_username %{username: "a", password: "password"}
@invalid_password %{username: "aasdf", password: "pass"}
@repeated_username %{username: "LoGan", password: "password"}
test "Password must be at least 8 characters and username must be at least 2" do
refute Player.registration_changeset(%Player{}, @invalid_password).valid?
refute Player.registration_changeset(%Player{}, @invalid_username).valid?
end
test "Password changeset must match" do
refute Player.password_changeset(
%Player{},
Map.put(@valid_user, :password_confirmation,
password_confirmation: @valid_user.password <> "a"
)
).valid?
valid_user_changed_password = Map.put(@valid_user, :password, "a_new_password")
assert Player.password_changeset(
%Player{},
Map.put(
valid_user_changed_password,
:password_confirmation,
valid_user_changed_password.password
)
).valid?
end
test "Password is hashed" do
changeset = Player.registration_changeset(%Player{}, @valid_user)
assert_raise KeyError, fn -> changeset.changes.password end
assert changeset.changes.hashed_password
refute changeset.changes.hashed_password == @valid_user.password
end
test "Username is uniquely case insensitive" do
assert Repo.insert(Player.registration_changeset(%Player{}, @valid_user))
assert {:error,
%{errors: [{:username, {_, [{:constraint, :unique}, {:constraint_name, _}]}}]}} =
Repo.insert(Player.registration_changeset(%Player{}, @repeated_username))
end
end
|