Stub
Proxy objects with fallbacks. Useful for creating stubs with partially defined objects.
Installation
Add this line to your application's Gemfile:
gem 'stub'
And then execute:
$ bundle
Or install it yourself as:
$ gem install stub
Usage
Inherit Stub::Abstract
(or Stub::Template::Abstract
) and define __stub__
method:
class MyStub < Stub::Abstract
module Methods
def __stub__ method_name, *args, &block
# Do something when method fails on the proxied object
# or returns nil.
end
end
end
See also Stub::Template::Prototype
as a working example.
Stub::Template::Prototype
Use a proxied object to generate placeholders in place of absent attributes & methods:
render Stub::Template::Prototype.new(MyModel.new)
Later you can use this render
ed template in Prototype's new Template()
and
evaluate
it with data from MyModel.find
. Example (don't forget escaping in
real-life code):
var template = '<%= render Stub::Template::Prototype.new(MyModel.new) %>';
var record = JSON.parse('<%= my_model.to_json %>');
text = new Template(template).evaluate(record);
Contributing
- Fork it
- Create your feature branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am 'Add some feature'
) - Push to the branch (
git push origin my-new-feature
) - Create new Pull Request