Commit ce441670 authored by Jisi Liu's avatar Jisi Liu

Merge remote-tracking branch 'origin/3.4.x' into vb

parents 11b4d5ec 4ae94d69
...@@ -819,7 +819,7 @@ def MapEncoder(field_descriptor): ...@@ -819,7 +819,7 @@ def MapEncoder(field_descriptor):
encode_message = MessageEncoder(field_descriptor.number, False, False) encode_message = MessageEncoder(field_descriptor.number, False, False)
def EncodeField(write, value, deterministic): def EncodeField(write, value, deterministic):
value_keys = sorted(value.iterkeys()) if deterministic else value.iterkeys() value_keys = sorted(value.keys()) if deterministic else value.keys()
for key in value_keys: for key in value_keys:
entry_msg = message_type._concrete_class(key=key, value=value[key]) entry_msg = message_type._concrete_class(key=key, value=value[key])
encode_message(write, entry_msg, deterministic) encode_message(write, entry_msg, deterministic)
......
...@@ -166,6 +166,9 @@ class MessageTest(BaseTestCase): ...@@ -166,6 +166,9 @@ class MessageTest(BaseTestCase):
def __nonzero__(self): def __nonzero__(self):
raise BadArgError() raise BadArgError()
def __bool__(self):
raise BadArgError()
with self.assertRaises(BadArgError): with self.assertRaises(BadArgError):
golden_message.SerializeToString(deterministic=BadArg()) golden_message.SerializeToString(deterministic=BadArg())
......
...@@ -59,32 +59,42 @@ $PROTOC \ ...@@ -59,32 +59,42 @@ $PROTOC \
|| fail 'protoc failed.' || fail 'protoc failed.'
echo "Testing output to zip..." echo "Testing output to zip..."
$UNZIP -t $TEST_TMPDIR/testzip.zip > $TEST_TMPDIR/testzip.list || fail 'unzip failed.' if $UNZIP -h > /dev/null; then
$UNZIP -t $TEST_TMPDIR/testzip.zip > $TEST_TMPDIR/testzip.list \
|| fail 'unzip failed.'
grep 'testing: testzip\.pb\.cc *OK$' $TEST_TMPDIR/testzip.list > /dev/null \ grep 'testing: testzip\.pb\.cc *OK$' $TEST_TMPDIR/testzip.list > /dev/null \
|| fail 'testzip.pb.cc not found in output zip.' || fail 'testzip.pb.cc not found in output zip.'
grep 'testing: testzip\.pb\.h *OK$' $TEST_TMPDIR/testzip.list > /dev/null \ grep 'testing: testzip\.pb\.h *OK$' $TEST_TMPDIR/testzip.list > /dev/null \
|| fail 'testzip.pb.h not found in output zip.' || fail 'testzip.pb.h not found in output zip.'
grep 'testing: testzip_pb2\.py *OK$' $TEST_TMPDIR/testzip.list > /dev/null \ grep 'testing: testzip_pb2\.py *OK$' $TEST_TMPDIR/testzip.list > /dev/null \
|| fail 'testzip_pb2.py not found in output zip.' || fail 'testzip_pb2.py not found in output zip.'
grep -i 'manifest' $TEST_TMPDIR/testzip.list > /dev/null \ grep -i 'manifest' $TEST_TMPDIR/testzip.list > /dev/null \
&& fail 'Zip file contained manifest.' && fail 'Zip file contained manifest.'
else
echo "Warning: 'unzip' command not available. Skipping test."
fi
echo "Testing output to jar..." echo "Testing output to jar..."
$JAR tf $TEST_TMPDIR/testzip.jar > $TEST_TMPDIR/testzip.list || fail 'jar failed.' if $JAR c $TEST_TMPDIR/testzip.proto > /dev/null; then
$JAR tf $TEST_TMPDIR/testzip.jar > $TEST_TMPDIR/testzip.list \
|| fail 'jar failed.'
# Check that -interface.jar timestamps are normalized: # Check that -interface.jar timestamps are normalized:
if [[ "$(TZ=UTC $JAR tvf $TEST_TMPDIR/testzip.jar)" != *'Tue Jan 01 00:00:00 UTC 1980'* ]]; then if [[ "$(TZ=UTC $JAR tvf $TEST_TMPDIR/testzip.jar)" != *'Tue Jan 01 00:00:00 UTC 1980'* ]]; then
fail 'Zip did not contain normalized timestamps' fail 'Zip did not contain normalized timestamps'
fi fi
grep '^test/jar/Foo\.java$' $TEST_TMPDIR/testzip.list > /dev/null \ grep '^test/jar/Foo\.java$' $TEST_TMPDIR/testzip.list > /dev/null \
|| fail 'Foo.java not found in output jar.' || fail 'Foo.java not found in output jar.'
grep '^test/jar/Bar\.java$' $TEST_TMPDIR/testzip.list > /dev/null \ grep '^test/jar/Bar\.java$' $TEST_TMPDIR/testzip.list > /dev/null \
|| fail 'Bar.java not found in output jar.' || fail 'Bar.java not found in output jar.'
grep '^test/jar/Outer\.java$' $TEST_TMPDIR/testzip.list > /dev/null \ grep '^test/jar/Outer\.java$' $TEST_TMPDIR/testzip.list > /dev/null \
|| fail 'Outer.java not found in output jar.' || fail 'Outer.java not found in output jar.'
grep '^META-INF/MANIFEST\.MF$' $TEST_TMPDIR/testzip.list > /dev/null \ grep '^META-INF/MANIFEST\.MF$' $TEST_TMPDIR/testzip.list > /dev/null \
|| fail 'Manifest not found in output jar.' || fail 'Manifest not found in output jar.'
else
echo "Warning: 'jar' command not available. Skipping test."
fi
echo PASS echo PASS
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