mirror of
https://github.com/edgecase/ruby_koans.git
synced 2026-04-15 07:23:19 -04:00
Updated koans from src.
This commit is contained in:
@@ -5,7 +5,7 @@ class AboutArrayAssignment < EdgeCase::Koan
|
|||||||
names = ["John", "Smith"]
|
names = ["John", "Smith"]
|
||||||
assert_equal __, names
|
assert_equal __, names
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_parallel_assignments
|
def test_parallel_assignments
|
||||||
first_name, last_name = ["John", "Smith"]
|
first_name, last_name = ["John", "Smith"]
|
||||||
assert_equal __, first_name
|
assert_equal __, first_name
|
||||||
@@ -18,13 +18,19 @@ class AboutArrayAssignment < EdgeCase::Koan
|
|||||||
assert_equal __, last_name
|
assert_equal __, last_name
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_parallel_assignments_with_extra_variables
|
def test_parallel_assignments_with_splat_operator
|
||||||
|
first_name, *last_name = ["John", "Smith", "III"]
|
||||||
|
assert_equal "John", first_name
|
||||||
|
assert_equal ["Smith","III"], last_name
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_parallel_assignments_with_too_few_variables
|
||||||
first_name, last_name = ["Cher"]
|
first_name, last_name = ["Cher"]
|
||||||
assert_equal __, first_name
|
assert_equal __, first_name
|
||||||
assert_equal __, last_name
|
assert_equal __, last_name
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_parallel_assignements_with_subarrays
|
def test_parallel_assignments_with_subarrays
|
||||||
first_name, last_name = [["Willie", "Rae"], "Johnson"]
|
first_name, last_name = [["Willie", "Rae"], "Johnson"]
|
||||||
assert_equal __, first_name
|
assert_equal __, first_name
|
||||||
assert_equal __, last_name
|
assert_equal __, last_name
|
||||||
|
|||||||
@@ -45,9 +45,9 @@ class AboutArrays < EdgeCase::Koan
|
|||||||
end
|
end
|
||||||
|
|
||||||
def test_arrays_and_ranges
|
def test_arrays_and_ranges
|
||||||
assert_equal Range, (1..5).class
|
assert_equal __, (1..5).class
|
||||||
assert_not_equal [1,2,3,4,5], (1..5)
|
assert_not_equal [1,2,3,4,5], (1..5)
|
||||||
assert_equal [1,2,3,4,5], (1..5).to_a
|
assert_equal __, (1..5).to_a
|
||||||
assert_equal __, (1...5).to_a
|
assert_equal __, (1...5).to_a
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|||||||
@@ -130,7 +130,7 @@ class AboutClasses < EdgeCase::Koan
|
|||||||
fido = Dog6.new("Fido")
|
fido = Dog6.new("Fido")
|
||||||
rover = Dog6.new("Rover")
|
rover = Dog6.new("Rover")
|
||||||
|
|
||||||
assert_not_equal rover.name, fido.name
|
assert_equal __, rover.name != fido.name
|
||||||
end
|
end
|
||||||
|
|
||||||
# ------------------------------------------------------------------
|
# ------------------------------------------------------------------
|
||||||
@@ -164,12 +164,12 @@ class AboutClasses < EdgeCase::Koan
|
|||||||
|
|
||||||
def test_to_s_provides_a_string_version_of_the_object
|
def test_to_s_provides_a_string_version_of_the_object
|
||||||
fido = Dog7.new("Fido")
|
fido = Dog7.new("Fido")
|
||||||
assert_equal "Fido", fido.to_s
|
assert_equal __, fido.to_s
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_to_s_is_used_in_string_interpolation
|
def test_to_s_is_used_in_string_interpolation
|
||||||
fido = Dog7.new("Fido")
|
fido = Dog7.new("Fido")
|
||||||
assert_equal "My dog is Fido", "My dog is #{fido}"
|
assert_equal __, "My dog is #{fido}"
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_inspect_provides_a_more_complete_string_version
|
def test_inspect_provides_a_more_complete_string_version
|
||||||
|
|||||||
@@ -22,12 +22,12 @@ class AboutExceptions < EdgeCase::Koan
|
|||||||
|
|
||||||
assert_equal __, result
|
assert_equal __, result
|
||||||
|
|
||||||
assert ex.is_a?(StandardError), "Failure message."
|
assert ex.is_a?(___), "Failure message."
|
||||||
assert ex.is_a?(RuntimeError), "Failure message."
|
assert ex.is_a?(___), "Failure message."
|
||||||
|
|
||||||
assert RuntimeError.ancestors.include?(StandardError),
|
assert RuntimeError.ancestors.include?(StandardError),
|
||||||
"RuntimeError is a subclass of StandardError"
|
"RuntimeError is a subclass of StandardError"
|
||||||
|
|
||||||
assert_equal __, ex.message
|
assert_equal __, ex.message
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|||||||
@@ -3,7 +3,7 @@ require File.expand_path(File.dirname(__FILE__) + '/edgecase')
|
|||||||
class AboutHashes < EdgeCase::Koan
|
class AboutHashes < EdgeCase::Koan
|
||||||
def test_creating_hashes
|
def test_creating_hashes
|
||||||
empty_hash = Hash.new
|
empty_hash = Hash.new
|
||||||
assert_equal Hash, empty_hash.class
|
assert_equal __, empty_hash.class
|
||||||
assert_equal({}, empty_hash)
|
assert_equal({}, empty_hash)
|
||||||
assert_equal __, empty_hash.size
|
assert_equal __, empty_hash.size
|
||||||
end
|
end
|
||||||
@@ -25,7 +25,7 @@ class AboutHashes < EdgeCase::Koan
|
|||||||
hash[:one] = "eins"
|
hash[:one] = "eins"
|
||||||
|
|
||||||
expected = { :one => __, :two => "dos" }
|
expected = { :one => __, :two => "dos" }
|
||||||
assert_equal expected, hash
|
assert_equal __, expected == hash
|
||||||
|
|
||||||
# Bonus Question: Why was "expected" broken out into a variable
|
# Bonus Question: Why was "expected" broken out into a variable
|
||||||
# rather than used as a literal?
|
# rather than used as a literal?
|
||||||
@@ -35,7 +35,7 @@ class AboutHashes < EdgeCase::Koan
|
|||||||
hash1 = { :one => "uno", :two => "dos" }
|
hash1 = { :one => "uno", :two => "dos" }
|
||||||
hash2 = { :two => "dos", :one => "uno" }
|
hash2 = { :two => "dos", :one => "uno" }
|
||||||
|
|
||||||
assert_equal hash1, hash2
|
assert_equal __, hash1 == hash2
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_hash_keys
|
def test_hash_keys
|
||||||
@@ -43,7 +43,7 @@ class AboutHashes < EdgeCase::Koan
|
|||||||
assert_equal __, hash.keys.size
|
assert_equal __, hash.keys.size
|
||||||
assert_equal __, hash.keys.include?(:one)
|
assert_equal __, hash.keys.include?(:one)
|
||||||
assert_equal __, hash.keys.include?(:two)
|
assert_equal __, hash.keys.include?(:two)
|
||||||
assert_equal Array, hash.keys.class
|
assert_equal __, hash.keys.class
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_hash_values
|
def test_hash_values
|
||||||
@@ -51,16 +51,16 @@ class AboutHashes < EdgeCase::Koan
|
|||||||
assert_equal __, hash.values.size
|
assert_equal __, hash.values.size
|
||||||
assert_equal __, hash.values.include?("uno")
|
assert_equal __, hash.values.include?("uno")
|
||||||
assert_equal __, hash.values.include?("dos")
|
assert_equal __, hash.values.include?("dos")
|
||||||
assert_equal Array, hash.values.class
|
assert_equal __, hash.values.class
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_combining_hashes
|
def test_combining_hashes
|
||||||
hash = { "jim" => 53, "amy" => 20, "dan" => 23 }
|
hash = { "jim" => 53, "amy" => 20, "dan" => 23 }
|
||||||
new_hash = hash.merge({ "jim" => 54, "jenny" => 26 })
|
new_hash = hash.merge({ "jim" => 54, "jenny" => 26 })
|
||||||
|
|
||||||
assert_not_equal hash, new_hash
|
assert_equal __, hash != new_hash
|
||||||
|
|
||||||
expected = { "jim" => __, "amy" => 20, "dan" => 23, "jenny" => __ }
|
expected = { "jim" => __, "amy" => 20, "dan" => 23, "jenny" => __ }
|
||||||
assert_equal expected, new_hash
|
assert_equal __, expected == new_hash
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|||||||
@@ -12,7 +12,7 @@ class AboutIteration < EdgeCase::Koan
|
|||||||
array.each do |item|
|
array.each do |item|
|
||||||
sum += item
|
sum += item
|
||||||
end
|
end
|
||||||
assert_equal 6, sum
|
assert_equal __, sum
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_each_can_use_curly_brace_blocks_too
|
def test_each_can_use_curly_brace_blocks_too
|
||||||
|
|||||||
98
koans/about_java_interop.rb
Normal file
98
koans/about_java_interop.rb
Normal file
@@ -0,0 +1,98 @@
|
|||||||
|
require File.expand_path(File.dirname(__FILE__) + '/edgecase')
|
||||||
|
|
||||||
|
include Java
|
||||||
|
|
||||||
|
# Concepts
|
||||||
|
# * Pull in a java class
|
||||||
|
# * calling a method, Camel vs snake
|
||||||
|
# * Resovling module/class name conflicts
|
||||||
|
# * Showing what gets returned
|
||||||
|
# * Ruby Strings VS Java Strings
|
||||||
|
# * Calling custom java class
|
||||||
|
# * Calling Ruby from java???
|
||||||
|
|
||||||
|
class AboutJavaInterop < EdgeCase::Koan
|
||||||
|
def test_using_a_java_library_class
|
||||||
|
java_array = java.util.ArrayList.new
|
||||||
|
assert_equal __, java_array.class
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_java_class_can_be_referenced_using_both_ruby_and_java_like_syntax
|
||||||
|
assert_equal __, Java::JavaUtil::ArrayList == java.util.ArrayList
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_include_class_includes_class_in_module_scope
|
||||||
|
assert_nil defined?(TreeSet)
|
||||||
|
include_class "java.util.TreeSet"
|
||||||
|
assert_equal __, defined?(TreeSet)
|
||||||
|
end
|
||||||
|
|
||||||
|
# THINK ABOUT IT:
|
||||||
|
#
|
||||||
|
# What if we use:
|
||||||
|
#
|
||||||
|
# include_class "java.lang.String"
|
||||||
|
#
|
||||||
|
# What would be the value of the String constant after this
|
||||||
|
# include_class is run? Would it be useful to provide a way of
|
||||||
|
# aliasing java classes to different names?
|
||||||
|
|
||||||
|
JString = java.lang.String
|
||||||
|
def test_also_java_class_can_be_given_ruby_aliases
|
||||||
|
java_string = JString.new("A Java String")
|
||||||
|
assert_equal __, java_string.class
|
||||||
|
assert_equal __, JString
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_can_directly_call_java_methods_on_java_objects
|
||||||
|
java_string = JString.new("A Java String")
|
||||||
|
assert_equal __, java_string.toLowerCase
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_jruby_provides_snake_case_versions_of_java_methods
|
||||||
|
java_string = JString.new("A Java String")
|
||||||
|
assert_equal __, java_string.to_lower_case
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_jruby_provides_question_mark_versions_of_boolean_methods
|
||||||
|
java_string = JString.new("A Java String")
|
||||||
|
assert_equal __, java_string.endsWith("String")
|
||||||
|
assert_equal __, java_string.ends_with("String")
|
||||||
|
assert_equal __, java_string.ends_with?("String")
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_java_string_are_not_ruby_strings
|
||||||
|
ruby_string = "A Java String"
|
||||||
|
java_string = java.lang.String.new(ruby_string)
|
||||||
|
assert_equal __, java_string.is_a?(java.lang.String)
|
||||||
|
assert_equal __, java_string.is_a?(String)
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_java_strings_can_be_compared_to_ruby_strings_maybe
|
||||||
|
ruby_string = "A Java String"
|
||||||
|
java_string = java.lang.String.new(ruby_string)
|
||||||
|
assert_equal __, ruby_string == java_string
|
||||||
|
assert_equal __, java_string == ruby_string
|
||||||
|
|
||||||
|
# THINK ABOUT IT:
|
||||||
|
#
|
||||||
|
# Is there any possible way for this to be more wrong?
|
||||||
|
#
|
||||||
|
# SERIOUSLY, THINK ABOUT IT:
|
||||||
|
#
|
||||||
|
# Why do you suppose that Ruby and Java strings compare like that?
|
||||||
|
#
|
||||||
|
# ADVANCED THINK ABOUT IT:
|
||||||
|
#
|
||||||
|
# Is there a way to make Ruby/Java string comparisons commutative?
|
||||||
|
# How would you do it?
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_however_most_methods_returning_strings_return_ruby_strings
|
||||||
|
java_array = java.util.ArrayList.new
|
||||||
|
assert_equal __, java_array.toString
|
||||||
|
assert_equal __, java_array.toString.is_a?(String)
|
||||||
|
assert_equal __, java_array.toString.is_a?(java.lang.String)
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
||||||
@@ -45,7 +45,7 @@ class AboutModules < EdgeCase::Koan
|
|||||||
def test_module_methods_are_also_availble_in_the_object
|
def test_module_methods_are_also_availble_in_the_object
|
||||||
fido = Dog.new
|
fido = Dog.new
|
||||||
assert_nothing_raised(Exception) do
|
assert_nothing_raised(Exception) do
|
||||||
fido.set_name("Rover")
|
fido.set_name("Rover")
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|||||||
@@ -3,11 +3,11 @@ require File.expand_path(File.dirname(__FILE__) + '/edgecase')
|
|||||||
|
|
||||||
class AboutRegularExpressions < EdgeCase::Koan
|
class AboutRegularExpressions < EdgeCase::Koan
|
||||||
def test_a_pattern_is_a_regular_expression
|
def test_a_pattern_is_a_regular_expression
|
||||||
assert_equal Regexp, /pattern/.class
|
assert_equal __, /pattern/.class
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_a_regexp_can_search_a_string_for_matching_content
|
def test_a_regexp_can_search_a_string_for_matching_content
|
||||||
assert_equal "match", "some matching content"[/match/]
|
assert_equal __, "some matching content"[/match/]
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_a_failed_match_returns_nil
|
def test_a_failed_match_returns_nil
|
||||||
|
|||||||
@@ -29,8 +29,8 @@ class AboutScope < EdgeCase::Koan
|
|||||||
assert_equal __, fido.identify
|
assert_equal __, fido.identify
|
||||||
assert_equal __, rover.identify
|
assert_equal __, rover.identify
|
||||||
|
|
||||||
assert_not_equal fido.class, rover.class
|
assert_equal __, fido.class != rover.class
|
||||||
assert_not_equal Jims::Dog, Joes::Dog
|
assert_equal __, Jims::Dog != Joes::Dog
|
||||||
end
|
end
|
||||||
|
|
||||||
# ------------------------------------------------------------------
|
# ------------------------------------------------------------------
|
||||||
|
|||||||
@@ -3,6 +3,10 @@
|
|||||||
|
|
||||||
require 'test/unit/assertions'
|
require 'test/unit/assertions'
|
||||||
|
|
||||||
|
# --------------------------------------------------------------------
|
||||||
|
# Support code for the Ruby Koans.
|
||||||
|
# --------------------------------------------------------------------
|
||||||
|
|
||||||
class FillMeInError < StandardError
|
class FillMeInError < StandardError
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -16,6 +20,8 @@ def in_ruby_version(*versions)
|
|||||||
yield if versions.any? { |v| ruby_version?(v) }
|
yield if versions.any? { |v| ruby_version?(v) }
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Standard, generic replacement value.
|
||||||
|
# If value19 is given, it is used inplace of value for Ruby 1.9.
|
||||||
def __(value="FILL ME IN", value19=:mu)
|
def __(value="FILL ME IN", value19=:mu)
|
||||||
if RUBY_VERSION < "1.9"
|
if RUBY_VERSION < "1.9"
|
||||||
value
|
value
|
||||||
@@ -24,6 +30,7 @@ def __(value="FILL ME IN", value19=:mu)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Numeric replacement value.
|
||||||
def _n_(value=999999, value19=:mu)
|
def _n_(value=999999, value19=:mu)
|
||||||
if RUBY_VERSION < "1.9"
|
if RUBY_VERSION < "1.9"
|
||||||
value
|
value
|
||||||
@@ -32,10 +39,12 @@ def _n_(value=999999, value19=:mu)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Error object replacement value.
|
||||||
def ___(value=FillMeInError)
|
def ___(value=FillMeInError)
|
||||||
value
|
value
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Method name replacement.
|
||||||
class Object
|
class Object
|
||||||
def ____(method=nil)
|
def ____(method=nil)
|
||||||
if method
|
if method
|
||||||
@@ -48,7 +57,25 @@ class Object
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
class String
|
||||||
|
def side_padding(width)
|
||||||
|
extra = width - self.size
|
||||||
|
if width < 0
|
||||||
|
self
|
||||||
|
else
|
||||||
|
left_padding = extra / 2
|
||||||
|
right_padding = (extra+1)/2
|
||||||
|
(" " * left_padding) + self + (" " *right_padding)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
module EdgeCase
|
module EdgeCase
|
||||||
|
class << self
|
||||||
|
def simple_output
|
||||||
|
ENV['SIMPLE_KOAN_OUTPUT'] == 'true'
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
module Color
|
module Color
|
||||||
#shamelessly stolen (and modified) from redgreen
|
#shamelessly stolen (and modified) from redgreen
|
||||||
@@ -176,6 +203,21 @@ module EdgeCase
|
|||||||
end
|
end
|
||||||
|
|
||||||
def end_screen
|
def end_screen
|
||||||
|
if EdgeCase.simple_output
|
||||||
|
boring_end_screen
|
||||||
|
else
|
||||||
|
artistic_end_screen
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def boring_end_screen
|
||||||
|
puts "Mountains are again merely mountains"
|
||||||
|
end
|
||||||
|
|
||||||
|
def artistic_end_screen
|
||||||
|
"JRuby 1.9.x Koans"
|
||||||
|
ruby_version = "(in #{'J' if defined?(JRUBY_VERSION)}Ruby #{defined?(JRUBY_VERSION) ? JRUBY_VERSION : RUBY_VERSION})"
|
||||||
|
ruby_version = ruby_version.side_padding(54)
|
||||||
completed = <<-ENDTEXT
|
completed = <<-ENDTEXT
|
||||||
,, , ,,
|
,, , ,,
|
||||||
: ::::, :::,
|
: ::::, :::,
|
||||||
@@ -192,8 +234,8 @@ module EdgeCase
|
|||||||
,:::::::::::, ::::::::::::,
|
,:::::::::::, ::::::::::::,
|
||||||
:::::::::::, ,::::::::::::
|
:::::::::::, ,::::::::::::
|
||||||
::::::::::::: ,::::::::::::
|
::::::::::::: ,::::::::::::
|
||||||
:::::::::::: Ruby Koans ::::::::::::,
|
:::::::::::: Ruby Koans ::::::::::::,
|
||||||
:::::::::::: ,::::::::::::,
|
::::::::::::#{ ruby_version },::::::::::::,
|
||||||
:::::::::::, , ::::::::::::
|
:::::::::::, , ::::::::::::
|
||||||
,:::::::::::::, brought to you by ,,::::::::::::,
|
,:::::::::::::, brought to you by ,,::::::::::::,
|
||||||
:::::::::::::: ,::::::::::::
|
:::::::::::::: ,::::::::::::
|
||||||
@@ -260,7 +302,7 @@ ENDTEXT
|
|||||||
|
|
||||||
def find_interesting_lines(backtrace)
|
def find_interesting_lines(backtrace)
|
||||||
backtrace.reject { |line|
|
backtrace.reject { |line|
|
||||||
line =~ /test\/unit\/|edgecase\.rb/
|
line =~ /test\/unit\/|edgecase\.rb|minitest/
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user