[flori/json] Make OpenStruct support as optional

https://github.com/flori/json/commit/202ffe2335
This commit is contained in:
Hiroshi SHIBATA 2024-01-31 10:50:06 +09:00
Родитель f3df218f48
Коммит 7c8f9603b1
5 изменённых файлов: 50 добавлений и 39 удалений

Просмотреть файл

@ -2,7 +2,10 @@
unless defined?(::JSON::JSON_LOADED) and ::JSON::JSON_LOADED
require 'json'
end
require 'ostruct'
begin
require 'ostruct'
rescue LoadError
end
class OpenStruct
@ -48,4 +51,4 @@ class OpenStruct
def to_json(*args)
as_json.to_json(*args)
end
end
end if defined?(::OpenStruct)

Просмотреть файл

@ -1,5 +1,8 @@
#frozen_string_literal: false
require 'ostruct'
begin
require 'ostruct'
rescue LoadError
end
module JSON
class GenericObject < OpenStruct
@ -67,5 +70,5 @@ module JSON
def to_json(*a)
as_json.to_json(*a)
end
end
end if defined?(::OpenStruct)
end

Просмотреть файл

@ -190,7 +190,7 @@ class JSONAdditionTest < Test::Unit::TestCase
# XXX this won't work; o.foo = { :bar => true }
o.foo = { 'bar' => true }
assert_equal o, parse(JSON(o), :create_additions => true)
end
end if defined?(::OpenStruct)
def test_set
s = Set.new([:a, :b, :c, :a])

Просмотреть файл

@ -79,4 +79,4 @@ class JSONGenericObjectTest < Test::Unit::TestCase
ensure
JSON::GenericObject.json_creatable = false
end
end
end if defined?(JSON::GenericObject)

Просмотреть файл

@ -3,7 +3,10 @@
require_relative 'test_helper'
require 'stringio'
require 'tempfile'
require 'ostruct'
begin
require 'ostruct'
rescue LoadError
end
begin
require 'bigdecimal'
rescue LoadError
@ -412,21 +415,6 @@ EOT
end
end
class SubOpenStruct < OpenStruct
def [](k)
__send__(k)
end
def []=(k, v)
@item_set = true
__send__("#{k}=", v)
end
def item_set?
@item_set
end
end
def test_parse_object_custom_hash_derived_class
res = parse('{"foo":"bar"}', :object_class => SubHash)
assert_equal({"foo" => "bar"}, res)
@ -434,24 +422,41 @@ EOT
assert res.item_set?
end
def test_parse_object_custom_non_hash_derived_class
res = parse('{"foo":"bar"}', :object_class => SubOpenStruct)
assert_equal "bar", res.foo
assert_equal(SubOpenStruct, res.class)
assert res.item_set?
end
if defined?(::OpenStruct)
class SubOpenStruct < OpenStruct
def [](k)
__send__(k)
end
def test_parse_generic_object
res = parse(
'{"foo":"bar", "baz":{}}',
:object_class => JSON::GenericObject
)
assert_equal(JSON::GenericObject, res.class)
assert_equal "bar", res.foo
assert_equal "bar", res["foo"]
assert_equal "bar", res[:foo]
assert_equal "bar", res.to_hash[:foo]
assert_equal(JSON::GenericObject, res.baz.class)
def []=(k, v)
@item_set = true
__send__("#{k}=", v)
end
def item_set?
@item_set
end
end
def test_parse_object_custom_non_hash_derived_class
res = parse('{"foo":"bar"}', :object_class => SubOpenStruct)
assert_equal "bar", res.foo
assert_equal(SubOpenStruct, res.class)
assert res.item_set?
end
def test_parse_generic_object
res = parse(
'{"foo":"bar", "baz":{}}',
:object_class => JSON::GenericObject
)
assert_equal(JSON::GenericObject, res.class)
assert_equal "bar", res.foo
assert_equal "bar", res["foo"]
assert_equal "bar", res[:foo]
assert_equal "bar", res.to_hash[:foo]
assert_equal(JSON::GenericObject, res.baz.class)
end
end
def test_generate_core_subclasses_with_new_to_json