测试在Phoenix中返回nil的虚拟字段

时间:2018-11-22 16:51:06

标签: testing phoenix-framework

我有一个基本的user模式,其中包含password_digest,该模式将保存在数据库中,用户将输入,散列并保存为password_digest的虚拟字段password

问题是进行测试时,在比较的一侧我得到的密码为nil,而在另一侧我得到的密码为非nil。我不确定测试虚拟字段时的最佳实践是什么。

错误消息:

...
Assertion with == failed
 code:  assert Accounts.get_user!(user.id()) == user
 left:  ... username: "some username", password: nil}
 right: ... username: "some username", password: "some password"}

  schema "users" do
    field :email, :string
    field :password_digest, :string
    field :username, :string

    timestamps()

    field :password, :string, virtual: true
  end

以下是相关代码:

def changeset(user, attrs) do
    user
    |> cast(attrs, [:username, :email, :password])
    |> hash_password
    |> validate_required([:username, :email, :password, :password_digest])
  end

  defp hash_password(changeset) do
    if password = get_change(changeset, :password) do
      changeset
      |> put_change(:password_digest, hashpwsalt(password))
    else
      changeset
    end
  end

在测试中,我有这些:

@valid_attrs %{email: "some email", password: "some password", username: "some username"}


def user_fixture(attrs \\ %{}) do
  {:ok, user} =
    attrs
    |> Enum.into(@valid_attrs)
    |> Accounts.create_user()

  user
end

...

test "get_user!/1 returns the user with given id" do
  user = user_fixture()
  assert Accounts.get_user!(user.id) == user
end

顺便说一句,get_user直接来自生成器:def get_user!(id), do: Repo.get!(User, id)

测试虚拟字段的正确方法是什么?

1 个答案:

答案 0 :(得分:0)

这是预期的行为,因为Accounts.get_user!(user.id)不会填充虚拟属性。它仅在变更集上发生更改,您未做任何更改。

在这种情况下,我认为与您相关的是测试是否设置了password_digest