mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
* ext/psych/lib/psych.rb: updated to released version.
* ext/psych/psych.gemspec: ditto
* ext/psych/emitter.c (initialize): allow a configuration object to be
passed to the constructor so that mutation isn't required after
instantiation.
* ext/psych/lib/psych/handler.rb: add configuration object
* ext/psych/lib/psych/visitors/emitter.rb: use configuration object if
extra configuration is present.
* ext/psych/lib/psych/visitors/to_ruby.rb: strings with YAML anchors
are properly referenced. Patched by Joe Rafaniello via Github:
https://github.com/tenderlove/psych/pull/69
* ext/psych/lib/psych/visitors/yaml_tree.rb: ditto
* test/psych/test_alias_and_anchor.rb: test for change
* ext/psych/lib/psych.rb: bumping psych to 1.3.3
* ext/psych/psych.gemspec: ditto
* ext/psych/extconf.rb: Use an exception instaed of bare abort.
* ext/psych/parser.c (transcode_string): fix encoding index names.
Thanks markizko for reporting.
* ext/psych/lib/psych/visitors/to_ruby.rb: fix a bug with string
subclass dumping and loading.
* test/psych/test_array.rb: pertinent tests
* test/psych/test_string.rb: ditto
* ext/psych/lib/psych/visitors/to_ruby.rb: convert omap tagged maps to
Psych::Omap objects rather than hashes. [Bug #6425]
* test/psych/test_omap.rb: pertinent test.
* ext/psych/lib/psych/visitors/yaml_tree.rb: keep a reference to
custom coders so that GC does not impact dumped yaml reference ids.
* ext/psych/lib/psych/json/yaml_events.rb: implicit styles should not
be changeable for JSON events.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_9_3@36654 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
95 lines
2.3 KiB
Ruby
95 lines
2.3 KiB
Ruby
require 'psych/helper'
|
|
|
|
module Psych
|
|
class TestString < TestCase
|
|
class X < String
|
|
end
|
|
|
|
class Y < String
|
|
attr_accessor :val
|
|
end
|
|
|
|
def test_another_subclass_with_attributes
|
|
y = Psych.load Psych.dump Y.new("foo").tap {|y| y.val = 1}
|
|
assert_equal "foo", y
|
|
assert_equal Y, y.class
|
|
assert_equal 1, y.val
|
|
end
|
|
|
|
def test_backwards_with_syck
|
|
x = Psych.load "--- !str:#{X.name} foo\n\n"
|
|
assert_equal X, x.class
|
|
assert_equal 'foo', x
|
|
end
|
|
|
|
def test_empty_subclass
|
|
assert_match "!ruby/string:#{X}", Psych.dump(X.new)
|
|
x = Psych.load Psych.dump X.new
|
|
assert_equal X, x.class
|
|
end
|
|
|
|
def test_subclass_with_attributes
|
|
y = Psych.load Psych.dump Y.new.tap {|y| y.val = 1}
|
|
assert_equal Y, y.class
|
|
assert_equal 1, y.val
|
|
end
|
|
|
|
def test_string_with_base_60
|
|
yaml = Psych.dump '01:03:05'
|
|
assert_match "'01:03:05'", yaml
|
|
assert_equal '01:03:05', Psych.load(yaml)
|
|
end
|
|
|
|
def test_tagged_binary_should_be_dumped_as_binary
|
|
string = "hello world!"
|
|
string.force_encoding 'ascii-8bit'
|
|
yml = Psych.dump string
|
|
assert_match(/binary/, yml)
|
|
assert_equal string, Psych.load(yml)
|
|
end
|
|
|
|
def test_binary_string_null
|
|
string = "\x00"
|
|
yml = Psych.dump string
|
|
assert_match(/binary/, yml)
|
|
assert_equal string, Psych.load(yml)
|
|
end
|
|
|
|
def test_binary_string
|
|
string = binary_string
|
|
yml = Psych.dump string
|
|
assert_match(/binary/, yml)
|
|
assert_equal string, Psych.load(yml)
|
|
end
|
|
|
|
def test_non_binary_string
|
|
string = binary_string(0.29)
|
|
yml = Psych.dump string
|
|
refute_match(/binary/, yml)
|
|
assert_equal string, Psych.load(yml)
|
|
end
|
|
|
|
def test_string_with_ivars
|
|
food = "is delicious"
|
|
ivar = "on rock and roll"
|
|
food.instance_variable_set(:@we_built_this_city, ivar)
|
|
|
|
str = Psych.load Psych.dump food
|
|
assert_equal ivar, food.instance_variable_get(:@we_built_this_city)
|
|
end
|
|
|
|
def test_binary
|
|
string = [0, 123,22, 44, 9, 32, 34, 39].pack('C*')
|
|
assert_cycle string
|
|
end
|
|
|
|
def binary_string percentage = 0.31, length = 100
|
|
string = ''
|
|
(percentage * length).to_i.times do |i|
|
|
string << "\b"
|
|
end
|
|
string << 'a' * (length - string.length)
|
|
string
|
|
end
|
|
end
|
|
end
|