From 27cc13ee95f6dbd522b37ae6317dcfeefdb2c12f Mon Sep 17 00:00:00 2001 From: Yordis Prieto Date: Wed, 19 Jun 2024 17:02:08 -0400 Subject: [PATCH] fix: json decoder middleware for uppercase content type (#685) closes #680 --- lib/tesla/middleware/json.ex | 11 +++++++++-- mix.exs | 2 +- test/tesla/middleware/json_test.exs | 9 +++++++++ 3 files changed, 19 insertions(+), 3 deletions(-) diff --git a/lib/tesla/middleware/json.ex b/lib/tesla/middleware/json.ex index c720b2d8f..ac183cbe0 100644 --- a/lib/tesla/middleware/json.ex +++ b/lib/tesla/middleware/json.ex @@ -129,8 +129,15 @@ defmodule Tesla.Middleware.JSON do defp decodable_content_type?(env, opts) do case Tesla.get_header(env, "content-type") do - nil -> false - content_type -> Enum.any?(content_types(opts), &String.starts_with?(content_type, &1)) + nil -> + false + + content_type -> + content_type = String.downcase(content_type) + + opts + |> content_types() + |> Enum.any?(&String.starts_with?(content_type, &1)) end end diff --git a/mix.exs b/mix.exs index 281323472..cdf01a371 100644 --- a/mix.exs +++ b/mix.exs @@ -2,7 +2,7 @@ defmodule Tesla.Mixfile do use Mix.Project @source_url "https://github.com/teamon/tesla" - @version "1.10.1" + @version "1.10.2" def project do [ diff --git a/test/tesla/middleware/json_test.exs b/test/tesla/middleware/json_test.exs index e23b3dd1d..b5c9f910b 100644 --- a/test/tesla/middleware/json_test.exs +++ b/test/tesla/middleware/json_test.exs @@ -10,6 +10,10 @@ defmodule Tesla.Middleware.JsonTest do adapter fn env -> {status, headers, body} = case env.url do + # GET https://testlajson.free.beeceptor.com/todos to see the response + "/uppercased-content-type" -> + {200, [{"content-type", "application/JSON"}], "{\"value\": 123}"} + "/decode" -> {200, [{"content-type", "application/json"}], "{\"value\": 123}"} @@ -48,6 +52,11 @@ defmodule Tesla.Middleware.JsonTest do end end + test "decoding json with insensitive content type" do + assert {:ok, env} = Client.get("/uppercased-content-type") + assert env.body == %{"value" => 123} + end + test "decode JSON body" do assert {:ok, env} = Client.get("/decode") assert env.body == %{"value" => 123}