diff options
author | miraikumiko <miraikumiko@disroot.org> | 2025-04-21 10:26:21 +0200 |
---|---|---|
committer | miraikumiko <miraikumiko@disroot.org> | 2025-04-21 10:26:21 +0200 |
commit | fb01bbb290d37f491d603bdf015d994a39e153c7 (patch) | |
tree | fb60b98e20ae6896b08fc46fda6643d36a8a8b34 /test | |
download | nulla-fb01bbb290d37f491d603bdf015d994a39e153c7.tar.gz nulla-fb01bbb290d37f491d603bdf015d994a39e153c7.tar.bz2 |
Init
Diffstat (limited to 'test')
-rw-r--r-- | test/nulla_web/controllers/error_html_test.exs | 14 | ||||
-rw-r--r-- | test/nulla_web/controllers/error_json_test.exs | 12 | ||||
-rw-r--r-- | test/nulla_web/controllers/page_controller_test.exs | 8 | ||||
-rw-r--r-- | test/support/conn_case.ex | 38 | ||||
-rw-r--r-- | test/support/data_case.ex | 58 | ||||
-rw-r--r-- | test/test_helper.exs | 2 |
6 files changed, 132 insertions, 0 deletions
diff --git a/test/nulla_web/controllers/error_html_test.exs b/test/nulla_web/controllers/error_html_test.exs new file mode 100644 index 0000000..4406660 --- /dev/null +++ b/test/nulla_web/controllers/error_html_test.exs @@ -0,0 +1,14 @@ +defmodule NullaWeb.ErrorHTMLTest do + use NullaWeb.ConnCase, async: true + + # Bring render_to_string/4 for testing custom views + import Phoenix.Template + + test "renders 404.html" do + assert render_to_string(NullaWeb.ErrorHTML, "404", "html", []) == "Not Found" + end + + test "renders 500.html" do + assert render_to_string(NullaWeb.ErrorHTML, "500", "html", []) == "Internal Server Error" + end +end diff --git a/test/nulla_web/controllers/error_json_test.exs b/test/nulla_web/controllers/error_json_test.exs new file mode 100644 index 0000000..0734e4d --- /dev/null +++ b/test/nulla_web/controllers/error_json_test.exs @@ -0,0 +1,12 @@ +defmodule NullaWeb.ErrorJSONTest do + use NullaWeb.ConnCase, async: true + + test "renders 404" do + assert NullaWeb.ErrorJSON.render("404.json", %{}) == %{errors: %{detail: "Not Found"}} + end + + test "renders 500" do + assert NullaWeb.ErrorJSON.render("500.json", %{}) == + %{errors: %{detail: "Internal Server Error"}} + end +end diff --git a/test/nulla_web/controllers/page_controller_test.exs b/test/nulla_web/controllers/page_controller_test.exs new file mode 100644 index 0000000..5e8da73 --- /dev/null +++ b/test/nulla_web/controllers/page_controller_test.exs @@ -0,0 +1,8 @@ +defmodule NullaWeb.PageControllerTest do + use NullaWeb.ConnCase + + test "GET /", %{conn: conn} do + conn = get(conn, ~p"/") + assert html_response(conn, 200) =~ "Peace of mind from prototype to production" + end +end diff --git a/test/support/conn_case.ex b/test/support/conn_case.ex new file mode 100644 index 0000000..10ed035 --- /dev/null +++ b/test/support/conn_case.ex @@ -0,0 +1,38 @@ +defmodule NullaWeb.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 data structures and query the data layer. + + Finally, if the test case interacts with the database, + we enable the SQL sandbox, so changes done to the database + are reverted at the end of every test. If you are using + PostgreSQL, you can even run database tests asynchronously + by setting `use NullaWeb.ConnCase, async: true`, although + this option is not recommended for other databases. + """ + + use ExUnit.CaseTemplate + + using do + quote do + # The default endpoint for testing + @endpoint NullaWeb.Endpoint + + use NullaWeb, :verified_routes + + # Import conveniences for testing with connections + import Plug.Conn + import Phoenix.ConnTest + import NullaWeb.ConnCase + end + end + + setup tags do + Nulla.DataCase.setup_sandbox(tags) + {: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 0000000..c17e6b7 --- /dev/null +++ b/test/support/data_case.ex @@ -0,0 +1,58 @@ +defmodule Nulla.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, + we enable the SQL sandbox, so changes done to the database + are reverted at the end of every test. If you are using + PostgreSQL, you can even run database tests asynchronously + by setting `use Nulla.DataCase, async: true`, although + this option is not recommended for other databases. + """ + + use ExUnit.CaseTemplate + + using do + quote do + alias Nulla.Repo + + import Ecto + import Ecto.Changeset + import Ecto.Query + import Nulla.DataCase + end + end + + setup tags do + Nulla.DataCase.setup_sandbox(tags) + :ok + end + + @doc """ + Sets up the sandbox based on the test tags. + """ + def setup_sandbox(tags) do + pid = Ecto.Adapters.SQL.Sandbox.start_owner!(Nulla.Repo, shared: not tags[:async]) + on_exit(fn -> Ecto.Adapters.SQL.Sandbox.stop_owner(pid) end) + end + + @doc """ + A helper that transforms changeset errors into a map of messages. + + assert {:error, 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} -> + Regex.replace(~r"%{(\w+)}", message, fn _, key -> + opts |> Keyword.get(String.to_existing_atom(key), key) |> to_string() + end) + end) + end +end diff --git a/test/test_helper.exs b/test/test_helper.exs new file mode 100644 index 0000000..b0b52da --- /dev/null +++ b/test/test_helper.exs @@ -0,0 +1,2 @@ +ExUnit.start() +Ecto.Adapters.SQL.Sandbox.mode(Nulla.Repo, :manual) |