Shot (Piotr Szotkowski) wrote:
I’m trying to spec a system from outside-in as an excercise in ‘emergent
design’ – and so far I love it; it made me think about the design for
two days before I even wrote the first spec… :)
My most-outside class seems to be a prime candidate for an #each method.
The attached (stripped) spec carrying two of the approaches I came up
with passes, and raises the following quesitions – any answer would be
most appreciated!
1. A philosophical/kosherness question: In the finished system
Decomposer#each will yield Decomposition objects, but as I’m specing
from outside-in, the Decomposition class is not yet created. In the
attached example I’m using an Array as a poor man’s Decomposition
replacement. Is this a sane approach, or should I rather create
a skeletal Decomposition#initialize instead?
2. The first spec shows my initial approach, with a variable polling the
stuff yielded by #each and then validating its contents, but it seems
clumsy…
3. …so I came up with the second, Decomposer.new.to_enum approach, which
simply validates the enumrator’s #next objects. Unfortunately, this does
not seem to trigger #should_receive(:each) on the *_gen mocks and made
me #stub!(:each) on them instead. Is this because I’m using RSpec 1.1.12
with Ruby 1.9.1, or am I missing something on how message expectations
work with lazy iterators (and, thus, #should_receive fail properly)?
4. Is there any better or more elegant
way to spec an #each (or #next) method?
Hmm.. maybe this is what you are looking for (From
http://rspec.info/documentation/mocks/message_expectations.html):
Yielding
my_mock.should_receive(:msg).once.and_yield(<value-1>, <value-2>, ...,
<value-n>)
When the expected message is received, the mock will yield the values to
the passed block.
To mock a method which yields values multiple times, and_yield can be
chained.
my_mock.should_receive(:msg).once.and_yield(<value-0-1>, <value-0-2>,
..., <value-0-n>).
and_yield(<value-1-1>, <value-1-2>, ..., <value-1-n>).
and_yield(<value-2-1>, <value-2-2>, ..., <value-2-n>)
HTH,
Ben
_______________________________________________
rspec-users mailing list
[email protected]
http://rubyforge.org/mailman/listinfo/rspec-users