mirror of
https://github.com/edgecase/ruby_koans.git
synced 2026-04-15 07:23:19 -04:00
Updated koans from source directory.
This commit is contained in:
@@ -3,7 +3,7 @@ require File.expand_path(File.dirname(__FILE__) + '/edgecase')
|
|||||||
def my_global_method(a,b)
|
def my_global_method(a,b)
|
||||||
a + b
|
a + b
|
||||||
end
|
end
|
||||||
|
|
||||||
class AboutMethods < EdgeCase::Koan
|
class AboutMethods < EdgeCase::Koan
|
||||||
|
|
||||||
def test_calling_global_methods
|
def test_calling_global_methods
|
||||||
@@ -29,19 +29,19 @@ class AboutMethods < EdgeCase::Koan
|
|||||||
# Rewrite the eval string to continue.
|
# Rewrite the eval string to continue.
|
||||||
#
|
#
|
||||||
end
|
end
|
||||||
|
|
||||||
# NOTE: wrong number of argument is not a SYNTAX error, but a
|
# NOTE: wrong number of argument is not a SYNTAX error, but a
|
||||||
# runtime error.
|
# runtime error.
|
||||||
def test_calling_global_methods_with_wrong_number_of_arguments
|
def test_calling_global_methods_with_wrong_number_of_arguments
|
||||||
exception = assert_raise(___) do
|
exception = assert_raise(___) do
|
||||||
my_global_method
|
my_global_method
|
||||||
end
|
end
|
||||||
assert_match(/__/, exception.message)
|
assert_match(/#{__ of arguments")}/, exception.message)
|
||||||
|
|
||||||
exception = assert_raise(___) do
|
exception = assert_raise(___) do
|
||||||
my_global_method(1,2,3)
|
my_global_method(1,2,3)
|
||||||
end
|
end
|
||||||
assert_match(/__/, exception.message)
|
assert_match(/#{__ of arguments")}/, exception.message)
|
||||||
end
|
end
|
||||||
|
|
||||||
# ------------------------------------------------------------------
|
# ------------------------------------------------------------------
|
||||||
@@ -135,7 +135,7 @@ class AboutMethods < EdgeCase::Koan
|
|||||||
"tail"
|
"tail"
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_calling_methods_in_other_objects_require_explicit_receiver
|
def test_calling_methods_in_other_objects_require_explicit_receiver
|
||||||
rover = Dog.new
|
rover = Dog.new
|
||||||
assert_equal __, rover.name
|
assert_equal __, rover.name
|
||||||
|
|||||||
@@ -25,15 +25,21 @@ class AboutSymbols < EdgeCase::Koan
|
|||||||
|
|
||||||
def test_method_names_become_symbols
|
def test_method_names_become_symbols
|
||||||
all_symbols = Symbol.all_symbols
|
all_symbols = Symbol.all_symbols
|
||||||
|
assert_equal __, all_symbols.include?(:test_method_names_become_symbols)
|
||||||
assert_equal __, all_symbols.include?(:test_method_names_are_symbols)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
RubyConstant = "What is the sound of one hand clapping?"
|
# THINK ABOUT IT:
|
||||||
def test_constants_become_symbols
|
#
|
||||||
all_symbols = Symbol.all_symbols
|
# Why do we capture the list of symbols before we check for the
|
||||||
|
# method name?
|
||||||
|
|
||||||
assert_equal true, all_symbols.include?(__)
|
in_ruby_version("mri") do
|
||||||
|
RubyConstant = "What is the sound of one hand clapping?"
|
||||||
|
def test_constants_become_symbols
|
||||||
|
all_symbols = Symbol.all_symbols
|
||||||
|
|
||||||
|
assert_equal __, all_symbols.include?(__)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_symbols_can_be_made_from_strings
|
def test_symbols_can_be_made_from_strings
|
||||||
@@ -47,6 +53,13 @@ class AboutSymbols < EdgeCase::Koan
|
|||||||
assert_equal symbol, __.to_sym
|
assert_equal symbol, __.to_sym
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def test_symbols_with_spaces_can_be_built
|
||||||
|
value = "and"
|
||||||
|
symbol = :"cats #{value} dogs"
|
||||||
|
|
||||||
|
assert_equal symbol, __.to_sym
|
||||||
|
end
|
||||||
|
|
||||||
def test_to_s_is_called_on_interpolated_symbols
|
def test_to_s_is_called_on_interpolated_symbols
|
||||||
symbol = :cats
|
symbol = :cats
|
||||||
string = "It is raining #{symbol} and dogs."
|
string = "It is raining #{symbol} and dogs."
|
||||||
@@ -65,13 +78,23 @@ class AboutSymbols < EdgeCase::Koan
|
|||||||
assert_equal __, symbol.respond_to?(:each_char)
|
assert_equal __, symbol.respond_to?(:each_char)
|
||||||
assert_equal __, symbol.respond_to?(:reverse)
|
assert_equal __, symbol.respond_to?(:reverse)
|
||||||
end
|
end
|
||||||
|
|
||||||
# It's important to realize that symbols are not "immutable
|
# It's important to realize that symbols are not "immutable
|
||||||
# strings", though they are immutable. None of the
|
# strings", though they are immutable. None of the
|
||||||
# interesting string operations are available on symbols.
|
# interesting string operations are available on symbols.
|
||||||
|
|
||||||
def test_symbols_cannot_be_concatenated
|
def test_symbols_cannot_be_concatenated
|
||||||
# Exceptions will be pondered further father down the path
|
# Exceptions will be pondered further father down the path
|
||||||
assert_raise(___) do
|
assert_raise(___) do
|
||||||
:cats + :dogs
|
:cats + :dogs
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def test_symbols_can_be_dynamically_created
|
||||||
|
assert_equal __, ("cats" + "dogs").to_sym
|
||||||
|
end
|
||||||
|
|
||||||
|
# THINK ABOUT IT:
|
||||||
|
#
|
||||||
|
# Why is it not a good idea to dynamically create a lot of symbols?
|
||||||
end
|
end
|
||||||
|
|||||||
@@ -6,8 +6,14 @@ require 'test/unit/assertions'
|
|||||||
class FillMeInError < StandardError
|
class FillMeInError < StandardError
|
||||||
end
|
end
|
||||||
|
|
||||||
def in_ruby_version(version)
|
def ruby_version?(version)
|
||||||
yield if RUBY_VERSION =~ /^#{version}/
|
RUBY_VERSION =~ /^#{version}/ ||
|
||||||
|
(version == 'jruby' && defined?(JRUBY_VERSION)) ||
|
||||||
|
(version == 'mri' && ! defined?(JRUBY_VERSION))
|
||||||
|
end
|
||||||
|
|
||||||
|
def in_ruby_version(*versions)
|
||||||
|
yield if versions.any? { |v| ruby_version?(v) }
|
||||||
end
|
end
|
||||||
|
|
||||||
def __(value="FILL ME IN", value19=:mu)
|
def __(value="FILL ME IN", value19=:mu)
|
||||||
@@ -248,6 +254,7 @@ ENDTEXT
|
|||||||
end
|
end
|
||||||
|
|
||||||
def indent(text)
|
def indent(text)
|
||||||
|
text = text.split(/\n/) if text.is_a?(String)
|
||||||
text.collect{|t| " #{t}"}
|
text.collect{|t| " #{t}"}
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user