aboutsummaryrefslogtreecommitdiff
path: root/test/support/channel_case.ex
diff options
context:
space:
mode:
Diffstat (limited to 'test/support/channel_case.ex')
-rw-r--r--test/support/channel_case.ex43
1 files changed, 43 insertions, 0 deletions
diff --git a/test/support/channel_case.ex b/test/support/channel_case.ex
new file mode 100644
index 0000000..f121634
--- /dev/null
+++ b/test/support/channel_case.ex
@@ -0,0 +1,43 @@
+defmodule TheTranscriberBackend.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 and query models.
+
+ 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
+
+ alias TheTranscriberBackend.Repo
+ import Ecto
+ import Ecto.Changeset
+ import Ecto.Query
+
+
+ # The default endpoint for testing
+ @endpoint TheTranscriberBackend.Endpoint
+ end
+ end
+
+ setup tags do
+ :ok = Ecto.Adapters.SQL.Sandbox.checkout(TheTranscriberBackend.Repo)
+
+ unless tags[:async] do
+ Ecto.Adapters.SQL.Sandbox.mode(TheTranscriberBackend.Repo, {:shared, self()})
+ end
+
+ :ok
+ end
+end