View Source Credo.Check.Refactor.NegatedConditionsWithElse (Credo v1.7.10)

Basics

This check is enabled by default.

Learn how to disable it via .credo.exs.

This check has a base priority of high and works with any version of Elixir.

Explanation

An if block with a negated condition should not contain an else block.

So while this is fine:

if not allowed? do
  raise "Not allowed!"
end

The code in this example ...

if not allowed? do
  raise "Not allowed!"
else
  proceed_as_planned()
end

... should be refactored to look like this:

if allowed? do
  proceed_as_planned()
else
  raise "Not allowed!"
end

The same goes for negation through ! instead of not.

The reason for this is not a technical but a human one. It is easier to wrap your head around a positive condition and then thinking "and else we do ...".

In the above example raising the error in case something is not allowed might seem so important to put it first. But when you revisit this code a while later or have to introduce a colleague to it, you might be surprised how much clearer things get when the "happy path" comes first.

Check-Specific Parameters

There are no specific parameters for this check.

General Parameters

Like with all checks, general params can be applied.

Parameters can be configured via the .credo.exs config file.