Skip to content

Commit

Permalink
Use prepend instead of include for helpers. Fixes sinatra#1213
Browse files Browse the repository at this point in the history
  • Loading branch information
mwpastore committed Dec 7, 2016
1 parent 63e81bc commit 512e093
Show file tree
Hide file tree
Showing 2 changed files with 23 additions and 1 deletion.
2 changes: 1 addition & 1 deletion lib/sinatra/base.rb
Original file line number Diff line number Diff line change
Expand Up @@ -1416,7 +1416,7 @@ def unlink(path, opts = {}, &bk) route 'UNLINK', path, opts, &bk end
# in `extensions` available to the handlers and templates
def helpers(*extensions, &block)
class_eval(&block) if block_given?
include(*extensions) if extensions.any?
prepend(*extensions) if extensions.any?
end

# Register an extension. Alternatively take a block from which an
Expand Down
22 changes: 22 additions & 0 deletions test/helpers_test.rb
Original file line number Diff line number Diff line change
Expand Up @@ -1941,5 +1941,27 @@ def foo
assert ok?
assert_equal '42 < 43', body
end

it 'prepends modules so previously-defined methods can be overridden consistently' do
mock_app do
helpers do
def one; nil; end
def two; nil; end
end

helpers ::HelperOne do
def two; '2' end
end

get('/one') { one }
get('/two') { two }
end

get '/one'
assert_equal '1', body

get '/two'
assert_equal '2', body
end
end
end

0 comments on commit 512e093

Please sign in to comment.