summaryrefslogtreecommitdiff
path: root/test/psych/json
diff options
context:
space:
mode:
authorAaron Patterson <aaron.patterson@gmail.com>2011-02-25 14:07:59 -0800
committerAaron Patterson <aaron.patterson@gmail.com>2011-02-25 14:07:59 -0800
commit2087329bda3cdc81df4545be68c9450b7ebb5c6f (patch)
tree3328d29b0258caea10f3b478dc7d738a0dcaaca8 /test/psych/json
parent8c60e9fa2a5e4932d8762469000b232d57c696b5 (diff)
downloadpsych-2087329bda3cdc81df4545be68c9450b7ebb5c6f.zip
merging from ruby trunk
Diffstat (limited to 'test/psych/json')
-rw-r--r--test/psych/json/test_stream.rb46
1 files changed, 40 insertions, 6 deletions
diff --git a/test/psych/json/test_stream.rb b/test/psych/json/test_stream.rb
index 712465d..45d0219 100644
--- a/test/psych/json/test_stream.rb
+++ b/test/psych/json/test_stream.rb
@@ -31,12 +31,12 @@ module Psych
def test_string
@stream.push "foo"
- assert_match(/(['"])foo\1/, @io.string)
+ assert_match(/(["])foo\1/, @io.string)
end
def test_symbol
@stream.push :foo
- assert_match(/(['"])foo\1/, @io.string)
+ assert_match(/(["])foo\1/, @io.string)
end
def test_int
@@ -56,8 +56,8 @@ module Psych
json = @io.string
assert_match(/}$/, json)
assert_match(/^--- \{/, json)
- assert_match(/['"]one['"]/, json)
- assert_match(/['"]two['"]/, json)
+ assert_match(/["]one['"]/, json)
+ assert_match(/["]two['"]/, json)
end
def test_list_to_json
@@ -67,8 +67,42 @@ module Psych
json = @io.string
assert_match(/]$/, json)
assert_match(/^--- \[/, json)
- assert_match(/['"]one['"]/, json)
- assert_match(/['"]two['"]/, json)
+ assert_match(/["]one["]/, json)
+ assert_match(/["]two["]/, json)
+ end
+
+ class Foo; end
+
+ def test_json_dump_exclude_tag
+ @stream << Foo.new
+ json = @io.string
+ refute_match('Foo', json)
+ end
+
+ class Bar
+ def encode_with coder
+ coder.represent_seq 'omg', %w{ a b c }
+ end
+ end
+
+ def test_json_list_dump_exclude_tag
+ @stream << Bar.new
+ json = @io.string
+ refute_match('omg', json)
+ end
+
+ def test_time
+ time = Time.utc(2010, 10, 10)
+ @stream.push({'a' => time })
+ json = @io.string
+ assert_match "{\"a\": \"2010-10-10 00:00:00.000000000Z\"}\n", json
+ end
+
+ def test_datetime
+ time = Time.new(2010, 10, 10).to_datetime
+ @stream.push({'a' => time })
+ json = @io.string
+ assert_match "{\"a\": \"#{time.strftime("%Y-%m-%d %H:%M:%S.%9N %:z")}\"}\n", json
end
end
end