如何使用模式匹配在 Phoenix 控制器测试中断言两个映射

Cha*_*har 3 elixir pattern-matching phoenix-framework ex-unit

在我的凤凰控制器测试中,我正在做这样的事情,

describe "update/2" do
  setup [:create_user]
  test "Edits, and responds with the user if attributes are valid", %{conn: conn, user: user} do

    response = 
      conn
      |> put(user_path(conn, :update, user.id, @update_attrs))
      |> json_response(200)

    expected = %{
      "data" => 
        %{"currentCity" => "pune", "mobileNumber" => "1234567890"}        
      }

  assert expected == response  

end
Run Code Online (Sandbox Code Playgroud)

我的反应图是

%{
  "data" => %{"currentCity" => "pune",
              "mobileNumber" => "1234567890",
              "name" => "xyz",
              "gender" => "male"}}
Run Code Online (Sandbox Code Playgroud)

由于我的响应映射包含预期映射中不存在的额外键,因此断言==失败,因此我尝试使用这样的模式匹配进行断言

assert expected = response
Run Code Online (Sandbox Code Playgroud)

但在这种情况下,无论预期和响应中的值是什么,断言始终为真。

我很困惑在地图的情况下模式匹配发生了什么。

Dog*_*ert 6

我很困惑在地图的情况下模式匹配发生了什么。

模式匹配时,模式必须出现在左侧。你不能“存储”一个模式。您在这里所做的是将模式expected与 的值response匹配,这将始终匹配,因为expected是一个变量,它将匹配右侧的任何值。

要解决此问题,您可以像这样内联模式:

assert %{"data" => 
  %{"currentCity" => "pune", "mobileNumber" => "1234567890"}        
} = response
Run Code Online (Sandbox Code Playgroud)