2024-03-13 14:59:27 +01:00
|
|
|
from hashlib import sha3_256
|
2024-02-12 15:35:23 +01:00
|
|
|
from unittest import TestCase
|
2024-03-13 14:59:27 +01:00
|
|
|
|
2024-03-15 11:34:43 +01:00
|
|
|
from da.encoder import DAEncoderParams, DAEncoder
|
|
|
|
|
from da.test_encoder import TestEncoder
|
|
|
|
|
from da.verifier import DAVerifier, DABlob
|
2025-01-24 15:53:00 +00:00
|
|
|
from da.common import NodeId, NomosDaG2ProofOfPossession as bls_pop
|
|
|
|
|
from da.dispersal import Dispersal, DispersalSettings
|
2024-03-13 14:59:27 +01:00
|
|
|
|
2024-02-12 15:35:23 +01:00
|
|
|
|
|
|
|
|
class TestDispersal(TestCase):
|
2024-03-13 14:59:27 +01:00
|
|
|
def setUp(self):
|
|
|
|
|
self.n_nodes = 16
|
|
|
|
|
self.nodes_ids = [NodeId(x.to_bytes(length=32, byteorder='big')) for x in range(self.n_nodes)]
|
|
|
|
|
dispersal_settings = DispersalSettings(
|
|
|
|
|
self.nodes_ids,
|
|
|
|
|
self.n_nodes // 2 + 1
|
|
|
|
|
)
|
|
|
|
|
self.dispersal = Dispersal(dispersal_settings)
|
|
|
|
|
self.encoder_test = TestEncoder()
|
|
|
|
|
self.encoder_test.setUp()
|
2024-02-12 15:35:23 +01:00
|
|
|
|
2024-03-13 14:59:27 +01:00
|
|
|
def test_disperse(self):
|
|
|
|
|
data = self.encoder_test.data
|
2024-03-20 11:03:39 +01:00
|
|
|
encoding_params = DAEncoderParams(column_count=self.n_nodes // 2, bytes_per_chunk=31)
|
2024-03-13 14:59:27 +01:00
|
|
|
encoded_data = DAEncoder(encoding_params).encode(data)
|
2024-02-12 15:35:23 +01:00
|
|
|
|
2024-03-13 14:59:27 +01:00
|
|
|
# mock send and await method with local verifiers
|
2025-01-24 15:53:00 +00:00
|
|
|
def __send_and_await_response(blob: DABlob):
|
|
|
|
|
verifier = DAVerifier()
|
2024-03-13 14:59:27 +01:00
|
|
|
return verifier.verify(blob)
|
|
|
|
|
# inject mock send and await method
|
|
|
|
|
self.dispersal._send_and_await_response = __send_and_await_response
|
|
|
|
|
|
2025-01-24 15:53:00 +00:00
|
|
|
self.assertTrue(self.dispersal.disperse(encoded_data))
|
2024-02-12 15:35:23 +01:00
|
|
|
|