deleteById (existente, não existente e dependente)

Verificando delete (service)

Como o delete é um método void, ele não deve fazer nada... portanto a nomenclatura é ShouldDoNothing.

Além disso, devemos SEMPRE verificar o método na classe original. Por exemplo:

O método da classe Service possui três cenários:

  1. Se o ID não existir, lançará o ResourceNotFound

  2. Daí ele vai pro try. Se existir, ok, ele irá deletar

  3. Caso esse ID caia no catch (ou seja, seja dependente de outra classe no banco de dados), lançará a DataBaseException

ID existente

ID Não existente (ResourceNotFound)

Neste caso, se o id não existe, aí sim terá um comportamento, lançar a exceção.

Ambos os métodos dão trigger nos cenários feitos no setUp:

ID existente (mas dependente)

Lembrar de instanciar um dependentId para reutilizar:

E criar o cenário de trigger no setUp

Atualizado