Elixir 插入utc_日期时间值时混合测试中的CaseClauseError
在我的Phoenix应用程序中,我有一个控制器,其Elixir 插入utc_日期时间值时混合测试中的CaseClauseError,elixir,phoenix,Elixir,Phoenix,在我的Phoenix应用程序中,我有一个控制器,其delete功能实际上不会从数据库中删除项目,而是将其存档,并插入一个:utc_datetime值,该值对应于项目被“删除”的日期时间。以下是函数: def delete(conn, %{"id" => contact_id}) do contact = Contact.get(contact_id) case Contact.archive(contact) do {:ok, _contact} ->
delete
功能实际上不会从数据库中删除项目,而是将其存档,并插入一个:utc_datetime
值,该值对应于项目被“删除”的日期时间。以下是函数:
def delete(conn, %{"id" => contact_id}) do
contact = Contact.get(contact_id)
case Contact.archive(contact) do
{:ok, _contact} ->
conn
|> put_flash(:info, "Contact successfully deleted.")
|> redirect(to: contact_path(conn, :index))
{:error, _changeset} ->
conn
|> put_flash(:error, "Contact deletion failed.")
|> redirect(to: contact_path(conn, :index))
end
end
这是联系人。存档
:
def archive(contact) do
contact
|> User.changeset(%{archived_at: DateTime.utc_now()})
|> Repo.update()
end
我的测试失败,出现以下错误:(CaseClauseError)没有匹配的case子句:{{{2018,9,6},{6,39,5,659053}
。以下是我为删除设置测试的方法:
client =
:provider_user
|> build(
provider: conn.assigns.provider,
type: "external",
billable: true,
first_name: "client",
last_name: "user",
email: "client@user.com"
)
|> set_password("password")
|> insert
describe "delete contact" do
test "deletes contact with valid params", %{conn: conn, client: client} do
conn = delete(conn, contact_path(conn, :delete, client))
assert redirected_to(conn) == contact_path(conn, :index)
assert Repo.get(User, client.id).archived_at
end
end
如果有任何关联,下面是联系人的getter函数
:
def get(contact_id, preload \\ []) do
query =
from(
u in User,
where: is_nil(u.archived_at) and u.id == ^contact_id,
preload: ^preload
)
Repo.one!(query)
end
它可能在以下行失败:Repo.get(User,client.id).archived\u位于
。请将IO.inspect(Repo.get(User,client.id).archived\u at)
放在它前面。我建议assert{{{{{{},{{{{},{{{{,},{{,{,{,{,}}}}=Repo.get(User,client.id)。存档在
可能会修复它。@mudasobwa我删除了那一行,我仍然会得到同样的错误。请你首先在哪一行发布错误?@mudasobwa,根据stacktrace,在这一行:test delete contact删除带有有效参数的contact
绘图变厚。您是否实施了setup
或setup\u所有
回调?请分享这些。