mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
Adding tests for YAML types
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@25963 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
b19b496248
commit
9713d84b5b
3 changed files with 113 additions and 0 deletions
37
test/yaml/test_boolean.rb
Normal file
37
test/yaml/test_boolean.rb
Normal file
|
@ -0,0 +1,37 @@
|
||||||
|
require 'test/unit'
|
||||||
|
require 'yaml'
|
||||||
|
|
||||||
|
module YAML
|
||||||
|
###
|
||||||
|
# Test booleans from YAML spec:
|
||||||
|
# http://yaml.org/type/bool.html
|
||||||
|
class TestBoolean < Test::Unit::TestCase
|
||||||
|
%w{ yes Yes YES true True TRUE on On ON }.each do |truth|
|
||||||
|
define_method(:"test_#{truth}") do
|
||||||
|
assert_equal true, YAML.load("--- #{truth}")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
%w{ no No NO false False FALSE off Off OFF }.each do |truth|
|
||||||
|
define_method(:"test_#{truth}") do
|
||||||
|
assert_equal false, YAML.load("--- #{truth}")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
###
|
||||||
|
# YAML spec says "y" and "Y" may be used as true, but Syck treats them
|
||||||
|
# as literal strings
|
||||||
|
def test_y
|
||||||
|
assert_equal "y", YAML.load("--- y")
|
||||||
|
assert_equal "Y", YAML.load("--- Y")
|
||||||
|
end
|
||||||
|
|
||||||
|
###
|
||||||
|
# YAML spec says "n" and "N" may be used as false, but Syck treats them
|
||||||
|
# as literal strings
|
||||||
|
def test_y
|
||||||
|
assert_equal "n", YAML.load("--- n")
|
||||||
|
assert_equal "N", YAML.load("--- N")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
20
test/yaml/test_null.rb
Normal file
20
test/yaml/test_null.rb
Normal file
|
@ -0,0 +1,20 @@
|
||||||
|
require 'test/unit'
|
||||||
|
require 'yaml'
|
||||||
|
|
||||||
|
module YAML
|
||||||
|
###
|
||||||
|
# Test null from YAML spec:
|
||||||
|
# http://yaml.org/type/null.html
|
||||||
|
class TestNull < Test::Unit::TestCase
|
||||||
|
def test_null_list
|
||||||
|
assert_equal [nil] * 5, YAML.load(<<-eoyml)
|
||||||
|
---
|
||||||
|
- ~
|
||||||
|
- null
|
||||||
|
-
|
||||||
|
- Null
|
||||||
|
- NULL
|
||||||
|
eoyml
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
56
test/yaml/test_omap.rb
Normal file
56
test/yaml/test_omap.rb
Normal file
|
@ -0,0 +1,56 @@
|
||||||
|
require 'test/unit'
|
||||||
|
require 'yaml'
|
||||||
|
|
||||||
|
module YAML
|
||||||
|
class TestOmap < Test::Unit::TestCase
|
||||||
|
def test_keys
|
||||||
|
map = YAML::Omap.new
|
||||||
|
map['foo'] = 'bar'
|
||||||
|
assert_equal 'bar', map['foo']
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_order
|
||||||
|
map = YAML::Omap.new
|
||||||
|
map['a'] = 'b'
|
||||||
|
map['b'] = 'c'
|
||||||
|
assert_equal [%w{a b}, %w{b c}], map.to_a
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_square
|
||||||
|
list = [["a", "b"], ["b", "c"]]
|
||||||
|
map = YAML::Omap[*list.flatten]
|
||||||
|
assert_equal list, map.to_a
|
||||||
|
assert_equal 'b', map['a']
|
||||||
|
assert_equal 'c', map['b']
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_to_yaml
|
||||||
|
map = YAML::Omap['a', 'b', 'c', 'd']
|
||||||
|
yaml = map.to_yaml
|
||||||
|
assert_match('!omap', yaml)
|
||||||
|
assert_match('- a: b', yaml)
|
||||||
|
assert_match('- c: d', yaml)
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_round_trip
|
||||||
|
list = [["a", "b"], ["b", "c"]]
|
||||||
|
map = YAML::Omap[*list.flatten]
|
||||||
|
loaded = YAML.load(YAML.dump(map))
|
||||||
|
|
||||||
|
assert_equal map, loaded
|
||||||
|
assert_equal list, loaded.to_a
|
||||||
|
end
|
||||||
|
|
||||||
|
###
|
||||||
|
# FIXME: Syck should also support !!omap as shorthand
|
||||||
|
def test_load
|
||||||
|
list = [["a", "b"], ["c", "d"]]
|
||||||
|
map = YAML.load(<<-eoyml)
|
||||||
|
--- !omap
|
||||||
|
- a: b
|
||||||
|
- c: d
|
||||||
|
eoyml
|
||||||
|
assert_equal list, map.to_a
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
Loading…
Reference in a new issue