Commit 944693c4 authored by igorpeshansky's avatar igorpeshansky Committed by Paul Yang

Add Google::Protobuf::Any.pack convenience class method. (#4719)

parent 0c3db026
...@@ -39,6 +39,12 @@ module Google ...@@ -39,6 +39,12 @@ module Google
module Protobuf module Protobuf
Any.class_eval do Any.class_eval do
def self.pack(msg, type_url_prefix='type.googleapis.com/')
any = self.new
any.pack(msg, type_url_prefix)
any
end
def pack(msg, type_url_prefix='type.googleapis.com/') def pack(msg, type_url_prefix='type.googleapis.com/')
if type_url_prefix.empty? or type_url_prefix[-1] != '/' then if type_url_prefix.empty? or type_url_prefix[-1] != '/' then
self.type_url = "#{type_url_prefix}/#{msg.class.descriptor.name}" self.type_url = "#{type_url_prefix}/#{msg.class.descriptor.name}"
......
...@@ -120,11 +120,17 @@ class TestWellKnownTypes < Test::Unit::TestCase ...@@ -120,11 +120,17 @@ class TestWellKnownTypes < Test::Unit::TestCase
end end
def test_any def test_any
any = Google::Protobuf::Any.new
ts = Google::Protobuf::Timestamp.new(seconds: 12345, nanos: 6789) ts = Google::Protobuf::Timestamp.new(seconds: 12345, nanos: 6789)
any = Google::Protobuf::Any.new
any.pack(ts) any.pack(ts)
assert any.is(Google::Protobuf::Timestamp) assert any.is(Google::Protobuf::Timestamp)
assert_equal ts, any.unpack(Google::Protobuf::Timestamp) assert_equal ts, any.unpack(Google::Protobuf::Timestamp)
any = Google::Protobuf::Any.pack(ts)
assert any.is(Google::Protobuf::Timestamp)
assert_equal ts, any.unpack(Google::Protobuf::Timestamp)
end end
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