aboutsummaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
Diffstat (limited to 'test')
-rw-r--r--test/support/channel_case.ex33
-rw-r--r--test/support/conn_case.ex34
-rw-r--r--test/test_helper.exs1
-rw-r--r--test/waev_web/controllers/page_controller_test.exs8
-rw-r--r--test/waev_web/views/error_view_test.exs14
-rw-r--r--test/waev_web/views/layout_view_test.exs8
-rw-r--r--test/waev_web/views/page_view_test.exs3
7 files changed, 101 insertions, 0 deletions
diff --git a/test/support/channel_case.ex b/test/support/channel_case.ex
new file mode 100644
index 0000000..d1d767f
--- /dev/null
+++ b/test/support/channel_case.ex
@@ -0,0 +1,33 @@
+defmodule WaevWeb.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 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 WaevWeb.ChannelCase, async: true`, although
+ this option is not recommended for other databases.
+ """
+
+ use ExUnit.CaseTemplate
+
+ using do
+ quote do
+ # Import conveniences for testing with channels
+ use Phoenix.ChannelTest
+
+ # The default endpoint for testing
+ @endpoint WaevWeb.Endpoint
+ end
+ end
+
+ setup _tags do
+ :ok
+ end
+end
diff --git a/test/support/conn_case.ex b/test/support/conn_case.ex
new file mode 100644
index 0000000..91a3833
--- /dev/null
+++ b/test/support/conn_case.ex
@@ -0,0 +1,34 @@
+defmodule WaevWeb.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 WaevWeb.ConnCase, async: true`, although
+ this option is not recommended for other databases.
+ """
+
+ use ExUnit.CaseTemplate
+
+ using do
+ quote do
+ # Import conveniences for testing with connections
+ use Phoenix.ConnTest
+ alias WaevWeb.Router.Helpers, as: Routes
+
+ # The default endpoint for testing
+ @endpoint WaevWeb.Endpoint
+ end
+ end
+
+ setup _tags do
+ {:ok, conn: Phoenix.ConnTest.build_conn()}
+ end
+end
diff --git a/test/test_helper.exs b/test/test_helper.exs
new file mode 100644
index 0000000..869559e
--- /dev/null
+++ b/test/test_helper.exs
@@ -0,0 +1 @@
+ExUnit.start()
diff --git a/test/waev_web/controllers/page_controller_test.exs b/test/waev_web/controllers/page_controller_test.exs
new file mode 100644
index 0000000..9999b40
--- /dev/null
+++ b/test/waev_web/controllers/page_controller_test.exs
@@ -0,0 +1,8 @@
+defmodule WaevWeb.PageControllerTest do
+ use WaevWeb.ConnCase
+
+ test "GET /", %{conn: conn} do
+ conn = get(conn, "/")
+ assert html_response(conn, 200) =~ "Welcome to Phoenix!"
+ end
+end
diff --git a/test/waev_web/views/error_view_test.exs b/test/waev_web/views/error_view_test.exs
new file mode 100644
index 0000000..ec43959
--- /dev/null
+++ b/test/waev_web/views/error_view_test.exs
@@ -0,0 +1,14 @@
+defmodule WaevWeb.ErrorViewTest do
+ use WaevWeb.ConnCase, async: true
+
+ # Bring render/3 and render_to_string/3 for testing custom views
+ import Phoenix.View
+
+ test "renders 404.html" do
+ assert render_to_string(WaevWeb.ErrorView, "404.html", []) == "Not Found"
+ end
+
+ test "renders 500.html" do
+ assert render_to_string(WaevWeb.ErrorView, "500.html", []) == "Internal Server Error"
+ end
+end
diff --git a/test/waev_web/views/layout_view_test.exs b/test/waev_web/views/layout_view_test.exs
new file mode 100644
index 0000000..3c02187
--- /dev/null
+++ b/test/waev_web/views/layout_view_test.exs
@@ -0,0 +1,8 @@
+defmodule WaevWeb.LayoutViewTest do
+ use WaevWeb.ConnCase, async: true
+
+ # When testing helpers, you may want to import Phoenix.HTML and
+ # use functions such as safe_to_string() to convert the helper
+ # result into an HTML string.
+ # import Phoenix.HTML
+end
diff --git a/test/waev_web/views/page_view_test.exs b/test/waev_web/views/page_view_test.exs
new file mode 100644
index 0000000..ad634b5
--- /dev/null
+++ b/test/waev_web/views/page_view_test.exs
@@ -0,0 +1,3 @@
+defmodule WaevWeb.PageViewTest do
+ use WaevWeb.ConnCase, async: true
+end