In RSpec, what's the difference between
— include(s) the examples in the current context
— include(s) the examples in a nested context
You probably know how to use
specify to clearly communicate one aspect of your code. The nested context provided by
it_behaves_like can be used to improve this communication with the reader.
I will base my example on the example given in the RSpec documentation for shared examples:
shared_examples "a collection" do context "initialized with 3 items" do it "says it has three items" do # ... end end end describe Array do it_behaves_like "a collection" include_examples "a collection" end
If you run RSpec with
--format documentation you get the following output:
Array behaves like a collection initialized with 3 items says it has three items initialized with 3 items says it has three items
So the difference is how the spec is read eg in case of a failure.
Which style you prefer is a question of aesthetics of how you like your specs to read. Furthermore you would suggest to always use the same style if you work in a team to improve consistency.
Also, are it_should_behave_like and it_behaves_like just synonyms?
Almost, the context is named differently.
it should behave like ... vs
behaves like .... Again a question of aesthetics.