Commit a8e23593 authored by Erik Benoist's avatar Erik Benoist Committed by Paul Yang

Allows the json marshaller to be passed json marshal options (#4252)

parent dd2dc0f1
......@@ -60,8 +60,8 @@ module Google
msg.to_proto
end
def self.encode_json(msg)
msg.to_json
def self.encode_json(msg, options = {})
msg.to_json(options)
end
def self.decode(klass, proto)
......
......@@ -40,8 +40,8 @@ module Google
module ClassMethods
end
def to_json
self.class.encode_json(self)
def to_json(options = {})
self.class.encode_json(self, options)
end
def to_proto
......
......@@ -60,4 +60,28 @@ class EncodeDecodeTest < Test::Unit::TestCase
to = A::B::C::TestMessage.encode(m.oneof_msg)
assert_equal '', to
end
def test_encode_json
msg = A::B::C::TestMessage.new({ optional_int32: 22 })
json = msg.to_json
to = A::B::C::TestMessage.decode_json(json)
assert_equal to.optional_int32, 22
msg = A::B::C::TestMessage.new({ optional_int32: 22 })
json = msg.to_json({ preserve_proto_fieldnames: true })
assert_match 'optional_int32', json
to = A::B::C::TestMessage.decode_json(json)
assert_equal 22, to.optional_int32
msg = A::B::C::TestMessage.new({ optional_int32: 22 })
json = A::B::C::TestMessage.encode_json(
msg,
{ preserve_proto_fieldnames: true, emit_defaults: true }
)
assert_match 'optional_int32', json
end
end
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment