View Source Credo.Execution.Task behaviour (Credo v1.7.5)

A Task is a step in a pipeline, which is given an Credo.Execution struct and must return one as well.

Tasks in a pipeline are only called if they are not "halted" (see Credo.Execution.halt/2).

It implements a call/1 or call/2 callback, which is called with the Credo.Execution struct as first parameter (and the Task's options as the second in case of call/2).

Summary

Callbacks

Is called by the pipeline and contains the Task's actual code.

Works like call/1, but receives the options, which are optional when registering the Task, as second argument.

Gets called if call holds the execution via Credo.Execution.halt/1 or Credo.Execution.halt/2.

Works like error/1, but receives the options, which were given during pipeline registration, as second argument.

Callbacks

@callback call(exec :: Credo.Execution.t()) :: Credo.Execution.t()

Is called by the pipeline and contains the Task's actual code.

defmodule FooTask do
  use Credo.Execution.Task

  def call(exec) do
    IO.inspect(exec)
  end
end

The call/1 functions receives an exec struct and must return a (modified) Credo.Execution.

@callback call(exec :: Credo.Execution.t(), opts :: Keyword.t()) :: Credo.Execution.t()

Works like call/1, but receives the options, which are optional when registering the Task, as second argument.

defmodule FooTask do
  use Credo.Execution.Task

  def call(exec, opts) do
    IO.inspect(opts)

    exec
  end
end
@callback error(exec :: Credo.Execution.t()) :: Credo.Execution.t()

Gets called if call holds the execution via Credo.Execution.halt/1 or Credo.Execution.halt/2.

@callback error(exec :: Credo.Execution.t(), opts :: Keyword.t()) :: Credo.Execution.t()

Works like error/1, but receives the options, which were given during pipeline registration, as second argument.