Skip to content
/ injex Public

A simple way to describe dependencies that can be replaced at test time.

License

Notifications You must be signed in to change notification settings

blatyo/injex

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

23 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Injex

A simple way to describe dependencies that can be replaced at test time.

Installation

def deps do
  [{:injex, "~> 1.0"}]
end

Usage

In modules, instead of:

defmodule MyModule do
  def process(data) do
    changeset = # ...

    Repo.insert(changeset)
  end
end

You write:

defmodule MyModule do
  import Injex
  inject :repo, Repo

  def process(data) do
    changeset = # ...

    repo().insert(changeset)
  end
end

Then, in your tests, you can replace Repo with a different one to simplify testing.

defmodule MyModuleTest do
  use ExUnit.Case
  import Injex.Test

  defmodule Repo do
    def insert(changeset), do: send(self, {:insert, changeset})
  end

  describe ".process" do
    test "inserts data" do
      override MyModule, repo: MyModuleTest.Repo do
        MyModule.process(%{})

        assert_received {:insert, changeset}
      end
    end
  end
end

The inject macro will only include overriding capabilities when Mix.env is :test. Otherwise, it inlines the default dependency.

About

A simple way to describe dependencies that can be replaced at test time.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages