failing test for #2036:

* add a repeated field to the tested hash
* also assert that two messages with identical values produce identical hashes
This commit is contained in:
Brendan Ribera 2016-08-30 16:21:33 -07:00
parent c0a6a6b462
commit 047419a172

View File

@ -183,12 +183,15 @@ module BasicTest
def test_hash def test_hash
m1 = TestMessage.new(:optional_int32 => 42) m1 = TestMessage.new(:optional_int32 => 42)
m2 = TestMessage.new(:optional_int32 => 102) m2 = TestMessage.new(:optional_int32 => 102, repeated_string: ['please', 'work', 'ok?'])
m3 = TestMessage.new(:optional_int32 => 102, repeated_string: ['please', 'work', 'ok?'])
assert m1.hash != 0 assert m1.hash != 0
assert m2.hash != 0 assert m2.hash != 0
assert m3.hash != 0
# relying on the randomness here -- if hash function changes and we are # relying on the randomness here -- if hash function changes and we are
# unlucky enough to get a collision, then change the values above. # unlucky enough to get a collision, then change the values above.
assert m1.hash != m2.hash assert m1.hash != m2.hash
assert_equal m2.hash, m3.hash
end end
def test_unknown_field_errors def test_unknown_field_errors