1

次のように 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 を再試行して成功します。これを実現するための良い方法は何ですか?

4

1 に答える 1

0

を使用しAgentて、 に対して行われた要求の数を追跡できます/v1/system。次に、最初のリクエストの場合は 401 を返し、それ以外の場合は 200 を返します。

{:ok, counter} = Agent.start_link(fn -> 0 end)

TeslaMock
|> expect(:call, 8, fn env, _opts ->
  case env.url do
    "http://fake.server.com/v1/token" ->
      ...
    "http://fake.server.com/v1/system" ->
      # Increment the counter.
      Agent.update(counter, &(&1 + 1))
      if Agent.get(counter, &(&1)) == 1 do
        # First request.
        %{env | status: 401, body: ...}
      else
        # Second or later request.
        %{env | status: 200, body: Poison.encode!(%{uptime: 10})}
      end
  end
end)
于 2017-10-27T08:46:09.737 に答える