From a515b086dc43bc648cfabdca4037f21e61be491f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Almir=20Saraj=C4=8Di=C4=87?= Date: Fri, 15 Nov 2024 13:08:49 +0100 Subject: [PATCH] Do it the Elixir-way --- lib/phx_tools_web/plugs/curl_detector.ex | 4 ++-- test/phx_tools_web/plugs/curl_detector_test.exs | 5 +++++ 2 files changed, 7 insertions(+), 2 deletions(-) diff --git a/lib/phx_tools_web/plugs/curl_detector.ex b/lib/phx_tools_web/plugs/curl_detector.ex index 28eb033c..a4e704e8 100644 --- a/lib/phx_tools_web/plugs/curl_detector.ex +++ b/lib/phx_tools_web/plugs/curl_detector.ex @@ -27,8 +27,8 @@ defmodule PhxToolsWeb.CurlDetector do end end - defp request_sent_from_curl?(nil), do: false - defp request_sent_from_curl?(user_agent), do: String.starts_with?(user_agent, "curl") + defp request_sent_from_curl?("curl" <> _rest), do: true + defp request_sent_from_curl?(_user_agent), do: false defp script_content do :phx_tools diff --git a/test/phx_tools_web/plugs/curl_detector_test.exs b/test/phx_tools_web/plugs/curl_detector_test.exs index 8aa774b3..c2426ffa 100644 --- a/test/phx_tools_web/plugs/curl_detector_test.exs +++ b/test/phx_tools_web/plugs/curl_detector_test.exs @@ -44,5 +44,10 @@ defmodule PhxToolsWeb.CurlDetectorTest do assert conn.status == 200 assert String.contains?(conn.resp_body, @script_content) end + + test "doesn't crash when User-Agent is nil", %{conn: conn} do + conn = get(conn, "/") + assert conn.status == 200 + end end end