Merge pull request #2045 from mike07026/master
fix #1342 cause by ownership issues
This commit is contained in:
commit
fa6428ed2a
2 changed files with 32 additions and 1 deletions
|
@ -165,7 +165,10 @@ DefaultValueObjectWriter* DefaultValueObjectWriter::RenderBytes(
|
|||
if (current_ == NULL) {
|
||||
ow_->RenderBytes(name, value);
|
||||
} else {
|
||||
RenderDataPiece(name, DataPiece(value, false, true));
|
||||
// Since StringPiece is essentially a pointer, takes a copy of "value" to
|
||||
// avoid ownership issues.
|
||||
string_values_.push_back(new string(value.ToString()));
|
||||
RenderDataPiece(name, DataPiece(*string_values_.back(), false, true));
|
||||
}
|
||||
return this;
|
||||
}
|
||||
|
|
|
@ -128,6 +128,34 @@ TEST_F(JsonUtilTest, TestDefaultValues) {
|
|||
"\"repeatedMessageValue\":[]"
|
||||
"}",
|
||||
ToJson(m, options));
|
||||
|
||||
options.always_print_primitive_fields = true;
|
||||
m.set_string_value("i am a test string value");
|
||||
m.set_bytes_value("i am a test bytes value");
|
||||
EXPECT_EQ(
|
||||
"{\"boolValue\":false,"
|
||||
"\"int32Value\":0,"
|
||||
"\"int64Value\":\"0\","
|
||||
"\"uint32Value\":0,"
|
||||
"\"uint64Value\":\"0\","
|
||||
"\"floatValue\":0,"
|
||||
"\"doubleValue\":0,"
|
||||
"\"stringValue\":\"i am a test string value\","
|
||||
"\"bytesValue\":\"aSBhbSBhIHRlc3QgYnl0ZXMgdmFsdWU=\","
|
||||
"\"enumValue\":\"FOO\","
|
||||
"\"repeatedBoolValue\":[],"
|
||||
"\"repeatedInt32Value\":[],"
|
||||
"\"repeatedInt64Value\":[],"
|
||||
"\"repeatedUint32Value\":[],"
|
||||
"\"repeatedUint64Value\":[],"
|
||||
"\"repeatedFloatValue\":[],"
|
||||
"\"repeatedDoubleValue\":[],"
|
||||
"\"repeatedStringValue\":[],"
|
||||
"\"repeatedBytesValue\":[],"
|
||||
"\"repeatedEnumValue\":[],"
|
||||
"\"repeatedMessageValue\":[]"
|
||||
"}",
|
||||
ToJson(m, options));
|
||||
}
|
||||
|
||||
TEST_F(JsonUtilTest, ParseMessage) {
|
||||
|
|
Loading…
Add table
Reference in a new issue