我在phoenix应用中有以下测试:
defmodule TattooBackend.Web.API.V1.PasswordControllerTest do
use TattooBackend.Web.ConnCase, async: true
use Bamboo.Test
alias TattooBackend.Web.Endpoint
alias TattooBackend.Accounts.Account
alias TattooBackend.Repo
alias Phoenix.Token
alias Comeonin.Bcrypt
import TattooBackend.AuthenticationRequiredTest
test "without passwords", %{conn: conn} do
account = insert(:account)
token = Token.sign(Endpoint, "account_id", account.id)
conn =
conn
|> put_req_header("authorization", "#{token}")
|> post(api_v1_password_path(conn, :create))
assert json_response(conn, 422)
end
test "with wrong password confirmation", %{conn: conn} do
account = insert(:account)
token = Token.sign(Endpoint, "account_id", account.id)
params = %{password: "new-password", password_confirmation: "password"}
conn =
conn
|> put_req_header("authorization", "#{token}")
|> post(api_v1_password_path(conn, :create, params))
assert json_response(conn, 422)
end
end在测试中重复这些行:
account = insert(:account)
token = Token.sign(Endpoint, "account_id", account.id)你知道怎么让它更干燥吗?
发布于 2017-07-05 03:26:00
如果您想在所有测试中执行这两行代码,可以将重复的代码放在setup回调中,然后使用模式匹配来获取每个测试中的代码:
defmodule TattooBackend.Web.API.V1.PasswordControllerTest do
...
setup do
account = insert(:account)
token = Token.sign(Endpoint, "account_id", account.id)
[account: account, token: token]
end
test "without passwords", %{conn: conn, account: account, token: token} do
conn =
conn
|> put_req_header("authorization", "#{token}")
|> post(api_v1_password_path(conn, :create))
assert json_response(conn, 422)
end
test "with wrong password confirmation", %{conn: conn, account: account, token: token} do
params = %{password: "new-password", password_confirmation: "password"}
conn =
conn
|> put_req_header("authorization", "#{token}")
|> post(api_v1_password_path(conn, :create, params))
assert json_response(conn, 422)
end
endsetup将在每次测试之前执行其代码,然后将account和token传递给每次测试。
https://stackoverflow.com/questions/44912895
复制相似问题