1
0
Fork 0
mirror of https://github.com/ruby/ruby.git synced 2022-11-09 12:17:21 -05:00

Merge psych-3.0.0.beta2 from https://github.com/ruby/psych

It contains following changes from 3.0.0.beta1

    * Preserve time zone offset when deserializing times
      https://github.com/ruby/psych/pull/316

    * Enable YAML serialization of Ruby delegators
      https://github.com/ruby/psych/pull/158

git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@59101 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
hsbt 2017-06-16 07:02:22 +00:00
parent ab8e756de0
commit 5a13c6bcd9
6 changed files with 54 additions and 4 deletions

View file

@ -143,7 +143,7 @@ module Psych
offset += ((tz[1] || 0) * 60)
end
klass.at((time - offset).to_i, us)
klass.new(yy, m, dd, hh, mm, ss+us/(1_000_000r), offset)
end
end
end

View file

@ -1,7 +1,7 @@
# frozen_string_literal: false
module Psych
# The version is Psych you're using
VERSION = '3.0.0.beta1'
VERSION = '3.0.0.beta2'
if RUBY_ENGINE == 'jruby'
DEFAULT_SNAKEYAML_VERSION = '1.18'.freeze

View file

@ -164,6 +164,8 @@ module Psych
@emitter.end_mapping
end
alias :visit_Delegator :visit_Object
def visit_Struct o
tag = ['!ruby/struct', o.class.name].compact.join(':')

View file

@ -2,10 +2,10 @@
Gem::Specification.new do |s|
s.name = "psych"
s.version = "3.0.0.beta1"
s.version = "3.0.0.beta2"
s.authors = ["Aaron Patterson", "SHIBATA Hiroshi", "Charles Oliver Nutter"]
s.email = ["aaron@tenderlovemaking.com", "hsbt@ruby-lang.org", "headius@headius.com"]
s.date = "2016-11-14"
s.date = "2017-06-16"
s.summary = "Psych is a YAML parser and emitter"
s.description = <<-DESCRIPTION
Psych is a YAML parser and emitter. Psych leverages libyaml[http://pyyaml.org/wiki/LibYAML]

View file

@ -9,10 +9,41 @@ module Psych
assert_cycle time
end
def test_usec
time = Time.utc(2017, 4, 13, 12, 0, 0, 5)
assert_cycle time
end
def test_non_utc
time = Time.new(2017, 4, 13, 12, 0, 0.5, "+09:00")
assert_cycle time
end
def test_timezone_offset
times = [Time.new(2017, 4, 13, 12, 0, 0, "+09:00"),
Time.new(2017, 4, 13, 12, 0, 0, "-05:00")]
cycled = Psych::load(Psych.dump times)
assert_match(/12:00:00 \+0900/, cycled.first.to_s)
assert_match(/12:00:00 -0500/, cycled.last.to_s)
end
def test_new_datetime
assert_cycle DateTime.new
end
def test_datetime_non_utc
dt = DateTime.new(2017, 4, 13, 12, 0, 0.5, "+09:00")
assert_cycle dt
end
def test_datetime_timezone_offset
times = [DateTime.new(2017, 4, 13, 12, 0, 0, "+09:00"),
DateTime.new(2017, 4, 13, 12, 0, 0, "-05:00")]
cycled = Psych::load(Psych.dump times)
assert_match(/12:00:00\+09:00/, cycled.first.to_s)
assert_match(/12:00:00-05:00/, cycled.last.to_s)
end
def test_invalid_date
assert_cycle "2013-10-31T10:40:07-000000000000033"
end

View file

@ -4,6 +4,15 @@ require 'psych/helper'
module Psych
module Visitors
class TestYAMLTree < TestCase
class TestDelegatorClass < Delegator
def initialize(obj); super; @obj = obj; end
def __setobj__(obj); @obj = obj; end
def __getobj__; @obj; end
end
class TestSimpleDelegatorClass < SimpleDelegator
end
def setup
super
@v = Visitors::YAMLTree.create
@ -175,6 +184,14 @@ module Psych
assert_cycle 'nUll'
assert_cycle '~'
end
def test_delegator
assert_cycle(TestDelegatorClass.new([1, 2, 3]))
end
def test_simple_delegator
assert_cycle(TestSimpleDelegatorClass.new([1, 2, 3]))
end
end
end
end