次のように Mox を使用して (Tesla を使用して) HTTP 呼び出しをモックしています。
test "Token expiry is handled by re-applying for a token on the fly", %{conn: conn} do
TeslaMock
|> expect(:call, 8, fn env, _opts ->
case env.url do
"http://fake.server.com/v1/token" ->
%{env | status: 200, body: Poison.encode!(
%{token_type: "Bearer",
access_token: "cHBtKbMDNdc3uX2LIhCy9eVwkodhEc87s6e5Fk0lRS",
expires_in: 86400})
}
"http://fake.server.com/v1/system" ->
%{env | status: 200, body: Poison.encode!(%{uptime: 10})}
end
end)
assert json_response(get(conn, "/v1/system"), 200) == %{"uptime" => 10}
偽のサーバーが最初に応答する必要があります: 401 トークンが /v1/system に期限切れになり、モジュールが /v1/token を発行し、/v1/system を再試行して成功します。これを実現するための良い方法は何ですか?