summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorRoger Braun <roger@rogerbraun.net>2017-03-17 17:09:58 +0100
committerRoger Braun <roger@rogerbraun.net>2017-03-17 17:09:58 +0100
commita93f3421a704d6728a856d5d82cdbf9c43f3f897 (patch)
tree50cab3fed20aeea7722567180b44bda23a21900f /test
downloadpleroma-a93f3421a704d6728a856d5d82cdbf9c43f3f897.tar.gz
pleroma-a93f3421a704d6728a856d5d82cdbf9c43f3f897.zip
Phoenix skeleton
Diffstat (limited to 'test')
-rw-r--r--test/support/channel_case.ex37
-rw-r--r--test/support/conn_case.ex38
-rw-r--r--test/support/data_case.ex53
-rw-r--r--test/test_helper.exs4
-rw-r--r--test/web/views/error_view_test.exs21
5 files changed, 153 insertions, 0 deletions
diff --git a/test/support/channel_case.ex b/test/support/channel_case.ex
new file mode 100644
index 000000000..aec3061b3
--- /dev/null
+++ b/test/support/channel_case.ex
@@ -0,0 +1,37 @@
+defmodule Pleroma.Web.ChannelCase do
+ @moduledoc """
+ This module defines the test case to be used by
+ channel tests.
+
+ Such tests rely on `Phoenix.ChannelTest` and also
+ import other functionality to make it easier
+ to build common datastructures and query the data layer.
+
+ Finally, if the test case interacts with the database,
+ it cannot be async. For this reason, every test runs
+ inside a transaction which is reset at the beginning
+ of the test unless the test case is marked as async.
+ """
+
+ use ExUnit.CaseTemplate
+
+ using do
+ quote do
+ # Import conveniences for testing with channels
+ use Phoenix.ChannelTest
+
+ # The default endpoint for testing
+ @endpoint Pleroma.Web.Endpoint
+ end
+ end
+
+
+ setup tags do
+ :ok = Ecto.Adapters.SQL.Sandbox.checkout(Pleroma.Repo)
+ unless tags[:async] do
+ Ecto.Adapters.SQL.Sandbox.mode(Pleroma.Repo, {:shared, self()})
+ end
+ :ok
+ end
+
+end
diff --git a/test/support/conn_case.ex b/test/support/conn_case.ex
new file mode 100644
index 000000000..8d6969855
--- /dev/null
+++ b/test/support/conn_case.ex
@@ -0,0 +1,38 @@
+defmodule Pleroma.Web.ConnCase do
+ @moduledoc """
+ This module defines the test case to be used by
+ tests that require setting up a connection.
+
+ Such tests rely on `Phoenix.ConnTest` and also
+ import other functionality to make it easier
+ to build common datastructures and query the data layer.
+
+ Finally, if the test case interacts with the database,
+ it cannot be async. For this reason, every test runs
+ inside a transaction which is reset at the beginning
+ of the test unless the test case is marked as async.
+ """
+
+ use ExUnit.CaseTemplate
+
+ using do
+ quote do
+ # Import conveniences for testing with connections
+ use Phoenix.ConnTest
+ import Pleroma.Web.Router.Helpers
+
+ # The default endpoint for testing
+ @endpoint Pleroma.Web.Endpoint
+ end
+ end
+
+
+ setup tags do
+ :ok = Ecto.Adapters.SQL.Sandbox.checkout(Pleroma.Repo)
+ unless tags[:async] do
+ Ecto.Adapters.SQL.Sandbox.mode(Pleroma.Repo, {:shared, self()})
+ end
+ {:ok, conn: Phoenix.ConnTest.build_conn()}
+ end
+
+end
diff --git a/test/support/data_case.ex b/test/support/data_case.ex
new file mode 100644
index 000000000..3f40c3670
--- /dev/null
+++ b/test/support/data_case.ex
@@ -0,0 +1,53 @@
+defmodule Pleroma.DataCase do
+ @moduledoc """
+ This module defines the setup for tests requiring
+ access to the application's data layer.
+
+ You may define functions here to be used as helpers in
+ your tests.
+
+ Finally, if the test case interacts with the database,
+ it cannot be async. For this reason, every test runs
+ inside a transaction which is reset at the beginning
+ of the test unless the test case is marked as async.
+ """
+
+ use ExUnit.CaseTemplate
+
+ using do
+ quote do
+ alias Pleroma.Repo
+
+ import Ecto
+ import Ecto.Changeset
+ import Ecto.Query
+ import Pleroma.DataCase
+ end
+ end
+
+ setup tags do
+ :ok = Ecto.Adapters.SQL.Sandbox.checkout(Pleroma.Repo)
+
+ unless tags[:async] do
+ Ecto.Adapters.SQL.Sandbox.mode(Pleroma.Repo, {:shared, self()})
+ end
+
+ :ok
+ end
+
+ @doc """
+ A helper that transform changeset errors to a map of messages.
+
+ changeset = Accounts.create_user(%{password: "short"})
+ assert "password is too short" in errors_on(changeset).password
+ assert %{password: ["password is too short"]} = errors_on(changeset)
+
+ """
+ def errors_on(changeset) do
+ Ecto.Changeset.traverse_errors(changeset, fn {message, opts} ->
+ Enum.reduce(opts, message, fn {key, value}, acc ->
+ String.replace(acc, "%{#{key}}", to_string(value))
+ end)
+ end)
+ end
+end
diff --git a/test/test_helper.exs b/test/test_helper.exs
new file mode 100644
index 000000000..602c5fca4
--- /dev/null
+++ b/test/test_helper.exs
@@ -0,0 +1,4 @@
+ExUnit.start()
+
+Ecto.Adapters.SQL.Sandbox.mode(Pleroma.Repo, :manual)
+
diff --git a/test/web/views/error_view_test.exs b/test/web/views/error_view_test.exs
new file mode 100644
index 000000000..48cdc5159
--- /dev/null
+++ b/test/web/views/error_view_test.exs
@@ -0,0 +1,21 @@
+defmodule Pleroma.Web.ErrorViewTest do
+ use Pleroma.Web.ConnCase, async: true
+
+ # Bring render/3 and render_to_string/3 for testing custom views
+ import Phoenix.View
+
+ test "renders 404.json" do
+ assert render(Pleroma.Web.ErrorView, "404.json", []) ==
+ %{errors: %{detail: "Page not found"}}
+ end
+
+ test "render 500.json" do
+ assert render(Pleroma.Web.ErrorView, "500.json", []) ==
+ %{errors: %{detail: "Internal server error"}}
+ end
+
+ test "render any other" do
+ assert render(Pleroma.Web.ErrorView, "505.json", []) ==
+ %{errors: %{detail: "Internal server error"}}
+ end
+end