[ANN] FlexMock 0.4.0 Released

J

Jim Weirich

= FlexMock 0.4.0 Released

FlexMock is a flexible mocking library for use in Ruby's Test::Unit
test framework. Version 0.4.0 enhances FlexMock with the ability to
stub and mock methods in existing objects.

== New Features in 0.4.0

* You can now use the flexstub(object) method to mock or stub
individual methods in an existing object. The original definitions
of the methods are restored at the end of a test.

* The and_return (and its alias, returns) now accepts a list of
arguments and will return the values in the list one at a time for
each successive call to the mocked method.

* The flexmock() method now accepts an initialization block so that a
mock can be created and configured in one step without using a local
variable. This is really handy when mocking factory or creation
methods that in turn return a mock.

== What is FlexMock?

FlexMock is a flexible Ruby mocking library that works with Ruby's
Test::Unit framework to create easy to use mocks.

=== Features

* Easy integration with Test::Unit. Mocks created with the flexmock
method are automatically verified at the end of the test.

* A fluent interface that allows mock behavior to be specified very
easily.

* A "record mode" where an existing implementation can record its
interaction with a mock for later validation against a new
implementation.

* Easy mocking of individual methods in existing, non-mock objects.

=== Example

Suppose you had a Dog object that wagged a tail when it was happy.
Something like this:

class Dog
def initialize(a_tail)
@tail = a_tail
end
def happy
@tail.wag
end
end

To test the +Dog+ class without a real +Tail+ object (perhaps because
real +Tail+ objects activate servos in some robotic equipment), you
can do something like this:

require 'test/unit'
require 'flexmock'

class TestDog < Test::Unit::TestCase
include FlexMock::TestCase

def test_dog_wags_tail_when_happy
tail = flexmock("tail")
tail.should_receive:)wag).once
dog = Dog.new(tail)
dog.happy
end
end

FlexMock will automatically verify that the mocked tail object
received the message +wag+ exactly one time. If it doesn't, the test
will not pass.

See the FlexMock documentation at
http://onestepback.org/software/flexmock for details on specifying
arguments and return values on mocked methods, as well as a simple
technique for mocking tail objects when the Dog class creates the tail
objects directly.

== Availability

FlexMock is distributed with Rails, or you can make sure you have the
latest version with a quick RubyGems command:

gem install flexmock (you may need root/admin privileges)

Otherwise, you can get it from the more traditional places:

Download:: http://rubyforge.org/project/showfiles.php?group_id=170

You will find documentation at:
http://onestepback.org/software/flexmock/

-- Jim Weirich
 

Ask a Question

Want to reply to this thread or ask your own question?

You'll need to choose a username for the site, which only take a couple of moments. After that, you can post your question and our members will help you out.

Ask a Question

Members online

Forum statistics

Threads
473,774
Messages
2,569,599
Members
45,177
Latest member
OrderGlucea
Top