Page MenuHomeSoftware Heritage

Jenkins > .tox.py3.lib.python3.7.site-packages.swh.storage.tests.test_tenacious.TestTenaciousStorage::test_content_find_with_duplicate_blake2s256
Failed

TEST RESULT

Run At
Sep 9 2021, 3:38 PM
Details
self = <swh.storage.tests.test_tenacious.TestTenaciousStorage object at 0x7f6bb5ac7c18> swh_storage = <swh.storage.proxies.tenacious.TenaciousProxyStorage object at 0x7f6bb5ac7b00> sample_data = <swh.storage.tests.storage_data.StorageData object at 0x7f6bb5ac72b0> def test_content_find_with_duplicate_blake2s256(self, swh_storage, sample_data): content = sample_data.content # Create fake data with colliding sha256 and blake2s256 sha1_array = bytearray(content.sha1) sha1_array[0] += 1 sha1git_array = bytearray(content.sha1_git) sha1git_array[0] += 1 sha256_array = bytearray(content.sha256) sha256_array[0] += 1 duplicated_content = attr.evolve( content, sha1=bytes(sha1_array), sha1_git=bytes(sha1git_array), sha256=bytes(sha256_array), ) swh_storage.content_add([content, duplicated_content]) actual_result = swh_storage.content_find( > {"blake2s256": duplicated_content.blake2s256} ) .tox/py3/lib/python3.7/site-packages/swh/storage/tests/storage_tests.py:3871: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ .tox/py3/lib/python3.7/site-packages/swh/storage/metrics.py:24: in d return f(*a, **kw) .tox/py3/lib/python3.7/site-packages/swh/storage/cassandra/storage.py:351: in content_find return self._content_find_many([content]) .tox/py3/lib/python3.7/site-packages/swh/storage/cassandra/storage.py:370: in _content_find_many for row in rows: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = <swh.storage.in_memory.InMemoryStorage object at 0x7f6bb5ac7ac8> algo = 'blake2s256' hashes = [b"\xd5\xfe\x199We'\xe4,\xfdv\xa9EZ$2\xfe\x7fVf\x95dW}\xd9<B\x80\xe7mf\x1d"] def _content_get_from_hashes(self, algo, hashes: List[bytes]) -> Iterable: """From the name of a hash algorithm and a value of that hash, looks up the "hash -> token" secondary table (content_by_{algo}) to get tokens. Then, looks up the main table (content) to get all contents with that token, and filters out contents whose hash doesn't match.""" > found_tokens = self._cql_runner.content_get_tokens_from_single_algo( algo, hashes ) E AttributeError: 'InMemoryCqlRunner' object has no attribute 'content_get_tokens_from_single_algo' .tox/py3/lib/python3.7/site-packages/swh/storage/cassandra/storage.py:166: AttributeError