summaryrefslogtreecommitdiff
path: root/test/support/helpers.ex
diff options
context:
space:
mode:
authormarcin mikołajczak <me@mkljczk.pl>2024-01-19 16:36:37 +0000
committermarcin mikołajczak <me@mkljczk.pl>2024-01-19 16:36:37 +0000
commit250a4873a6f50f71cb5c387de46d711dc1bd1a39 (patch)
tree15364aea4ca2ad364517099f090716de0900b8ef /test/support/helpers.ex
parent51aef6b78dcf709872de32a02533e943f08858d4 (diff)
parent81a13b4b9eb066e7827251c054eb04fd70613532 (diff)
downloadpleroma-250a4873a6f50f71cb5c387de46d711dc1bd1a39.tar.gz
pleroma-250a4873a6f50f71cb5c387de46d711dc1bd1a39.zip
Merge branch 'develop' into 'post-languages'
# Conflicts: # lib/pleroma/web/activity_pub/transmogrifier.ex # test/pleroma/web/activity_pub/transmogrifier/note_handling_test.exs
Diffstat (limited to 'test/support/helpers.ex')
-rw-r--r--test/support/helpers.ex33
1 files changed, 33 insertions, 0 deletions
diff --git a/test/support/helpers.ex b/test/support/helpers.ex
index e3bfa73d2..7fa6c31a4 100644
--- a/test/support/helpers.ex
+++ b/test/support/helpers.ex
@@ -10,6 +10,39 @@ defmodule Pleroma.Tests.Helpers do
require Logger
+ @doc "Accepts two URLs/URIs and sorts the query parameters before comparing"
+ def uri_equal?(a, b) do
+ a_sorted = uri_query_sort(a)
+ b_sorted = uri_query_sort(b)
+
+ match?(^a_sorted, b_sorted)
+ end
+
+ @doc "Accepts a URL/URI and sorts the query parameters"
+ def uri_query_sort(uri) do
+ parsed = URI.parse(uri)
+
+ sorted_query =
+ String.split(parsed.query, "&")
+ |> Enum.sort()
+ |> Enum.join("&")
+
+ parsed
+ |> Map.put(:query, sorted_query)
+ |> URI.to_string()
+ end
+
+ @doc "Returns the value of the specified query parameter for the provided URL"
+ def get_query_parameter(url, param) do
+ url
+ |> URI.parse()
+ |> Map.get(:query)
+ |> URI.query_decoder()
+ |> Enum.to_list()
+ |> Enum.into(%{}, fn {x, y} -> {x, y} end)
+ |> Map.get(param)
+ end
+
defmacro clear_config(config_path) do
quote do
clear_config(unquote(config_path)) do