RSpec - Ayudantes
A veces, sus ejemplos de RSpec necesitan una forma sencilla de compartir código reutilizable. La mejor manera de lograr esto es con ayudantes. Los ayudantes son básicamente métodos Ruby regulares que comparte con los ejemplos. Para ilustrar el beneficio de usar ayudantes, consideremos este código:
class Dog
attr_reader :good_dog, :has_been_walked
def initialize(good_or_not)
@good_dog = good_or_not
@has_been_walked = false
end
def walk_dog
@has_been_walked = true
end
end
describe Dog do
it 'should be able to create and walk a good dog' do
dog = Dog.new(true)
dog.walk_dog
expect(dog.good_dog).to be true
expect(dog.has_been_walked).to be true
end
it 'should be able to create and walk a bad dog' do
dog = Dog.new(false)
dog.walk_dog
expect(dog.good_dog).to be false
expect(dog.has_been_walked).to be true
end
end
Este código es claro, pero siempre es una buena idea reducir el código repetido siempre que sea posible. Podemos tomar el código anterior y reducir parte de esta repetición con un método auxiliar llamado create_and_walk_dog ().
class Dog
attr_reader :good_dog, :has_been_walked
def initialize(good_or_not)
@good_dog = good_or_not
@has_been_walked = false
end
def walk_dog
@has_been_walked = true
end
end
describe Dog do
def create_and_walk_dog(good_or_bad)
dog = Dog.new(good_or_bad)
dog.walk_dog
return dog
end
it 'should be able to create and walk a good dog' do
dog = create_and_walk_dog(true)
expect(dog.good_dog).to be true
expect(dog.has_been_walked).to be true
end
it 'should be able to create and walk a bad dog' do
dog = create_and_walk_dog(false)
expect(dog.good_dog).to be false
expect(dog.has_been_walked).to be true
end
end
Cuando ejecute el código anterior, verá este resultado:
..
Finished in 0.002 seconds (files took 0.11401 seconds to load)
2 examples, 0 failures
Como puede ver, pudimos impulsar la lógica para crear y pasear un objeto de perro en un Helper que permite que nuestros ejemplos sean más cortos y más limpios.