39 lines
		
	
	
	
		
			1 KiB
		
	
	
	
		
			Elixir
		
	
	
	
	
	
			
		
		
	
	
			39 lines
		
	
	
	
		
			1 KiB
		
	
	
	
		
			Elixir
		
	
	
	
	
	
| 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
 | |
|     Cachex.clear(:user_cache)
 | |
|     :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
 |