0a9428093c
git-subtree-dir: RubyFun git-subtree-mainline:a04a502787
git-subtree-split:b01c682613
151 lines
3.4 KiB
Ruby
151 lines
3.4 KiB
Ruby
require File.expand_path(File.dirname(__FILE__) + '/edgecase')
|
|
|
|
def my_global_method(a,b)
|
|
a + b
|
|
end
|
|
|
|
class AboutMethods < EdgeCase::Koan
|
|
|
|
def test_calling_global_methods
|
|
assert_equal __, my_global_method(2,3)
|
|
end
|
|
|
|
def test_calling_global_methods_without_parentheses
|
|
result = my_global_method 2, 3
|
|
assert_equal __, result
|
|
end
|
|
|
|
# (NOTE: We are Using eval below because the example code is
|
|
# considered to be syntactically invalid).
|
|
def test_sometimes_missing_parentheses_are_ambiguous
|
|
eval "assert_equal 5, my_global_method 2, 3" # ENABLE CHECK
|
|
#
|
|
# Ruby doesn't know if you mean:
|
|
#
|
|
# assert_equal(5, my_global_method(2), 3)
|
|
# or
|
|
# assert_equal(5, my_global_method(2, 3))
|
|
#
|
|
# Rewrite the eval string to continue.
|
|
#
|
|
end
|
|
|
|
# NOTE: wrong number of argument is not a SYNTAX error, but a
|
|
# runtime error.
|
|
def test_calling_global_methods_with_wrong_number_of_arguments
|
|
exception = assert_raise(___) do
|
|
my_global_method
|
|
end
|
|
assert_match(/__/, exception.message)
|
|
|
|
exception = assert_raise(___) do
|
|
my_global_method(1,2,3)
|
|
end
|
|
assert_match(/__/, exception.message)
|
|
end
|
|
|
|
# ------------------------------------------------------------------
|
|
|
|
def method_with_defaults(a, b=:default_value)
|
|
[a, b]
|
|
end
|
|
|
|
def test_calling_with_default_values
|
|
assert_equal [1, __], method_with_defaults(1)
|
|
assert_equal [1, __], method_with_defaults(1, 2)
|
|
end
|
|
|
|
# ------------------------------------------------------------------
|
|
|
|
def method_with_var_args(*args)
|
|
args
|
|
end
|
|
|
|
def test_calling_with_variable_arguments
|
|
assert_equal __, method_with_var_args
|
|
assert_equal __, method_with_var_args(:one)
|
|
assert_equal __, method_with_var_args(:one, :two)
|
|
end
|
|
|
|
# ------------------------------------------------------------------
|
|
|
|
def method_with_explicit_return
|
|
:a_non_return_value
|
|
return :return_value
|
|
:another_non_return_value
|
|
end
|
|
|
|
def test_method_with_explicit_return
|
|
assert_equal __, method_with_explicit_return
|
|
end
|
|
|
|
# ------------------------------------------------------------------
|
|
|
|
def method_without_explicit_return
|
|
:a_non_return_value
|
|
:return_value
|
|
end
|
|
|
|
def test_method_without_explicit_return
|
|
assert_equal __, method_without_explicit_return
|
|
end
|
|
|
|
# ------------------------------------------------------------------
|
|
|
|
def my_same_class_method(a, b)
|
|
a * b
|
|
end
|
|
|
|
def test_calling_methods_in_same_class
|
|
assert_equal __, my_same_class_method(3,4)
|
|
end
|
|
|
|
def test_calling_methods_in_same_class_with_explicit_receiver
|
|
assert_equal __, self.my_same_class_method(3,4)
|
|
end
|
|
|
|
# ------------------------------------------------------------------
|
|
|
|
def my_private_method
|
|
"a secret"
|
|
end
|
|
private :my_private_method
|
|
|
|
def test_calling_private_methods_without_receiver
|
|
assert_equal __, my_private_method
|
|
end
|
|
|
|
def test_calling_private_methods_with_an_explicit_receiver
|
|
exception = assert_raise(___) do
|
|
self.my_private_method
|
|
end
|
|
assert_match /__/, exception.message
|
|
end
|
|
|
|
# ------------------------------------------------------------------
|
|
|
|
class Dog
|
|
def name
|
|
"Fido"
|
|
end
|
|
|
|
private
|
|
|
|
def tail
|
|
"tail"
|
|
end
|
|
end
|
|
|
|
def test_calling_methods_in_other_objects_require_explicit_receiver
|
|
rover = Dog.new
|
|
assert_equal __, rover.name
|
|
end
|
|
|
|
def test_calling_private_methods_in_other_objects
|
|
rover = Dog.new
|
|
assert_raise(___) do
|
|
rover.tail
|
|
end
|
|
end
|
|
end
|