Commit 80a48518 authored by Stefan Behnel's avatar Stefan Behnel

Prevent negative CRC32 values in Py2 from messing up the modulo calculation.

parent fa74be3b
...@@ -1652,8 +1652,8 @@ class ShardExcludeSelector(object): ...@@ -1652,8 +1652,8 @@ class ShardExcludeSelector(object):
def __call__(self, testname, tags=None, _hash=zlib.crc32, _is_py2=sys.version_info[0] < 3): def __call__(self, testname, tags=None, _hash=zlib.crc32, _is_py2=sys.version_info[0] < 3):
# Cannot use simple hash() here as shard processes might use different hash seeds. # Cannot use simple hash() here as shard processes might use different hash seeds.
# CRC32 is fast and simple. # CRC32 is fast and simple, but might return negative values in Py2.
hashval = _hash(testname if _is_py2 else testname.encode()) hashval = _hash(testname) & 0x7fffffff if _is_py2 else _hash(testname.encode())
return hashval % self.shard_count != self.shard_num return hashval % self.shard_count != self.shard_num
......
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