Skip to content

cleanup parameters

cleanup parameters #51

GitHub Actions / Test Results failed Feb 4, 2024 in 0s

1 fail, 11 skipped, 1β€ˆ077 pass in 1m 7s

1β€ˆ089 tests  Β±0   1β€ˆ077 βœ… Β±0   1m 7s ⏱️ -2s
β€‡β€ˆβ€‡β€‡4 suites Β±0β€‚β€ƒβ€ƒβ€‡β€ˆβ€‡11 πŸ’€ Β±0 
β€‡β€ˆβ€‡β€‡4 files   Β±0β€‚β€ƒβ€ƒβ€‡β€ˆβ€‡β€‡1 ❌ Β±0 

Results for commit 586d4b6. ± Comparison against earlier commit 42b13ce.

Annotations

Check warning on line 0 in tests.sandbox_tests.test_concurrent.ConcurrentTransactionsTestCase

See this annotation in the file changed.

@github-actions github-actions / Test Results

test_1_originate_contract (tests.sandbox_tests.test_concurrent.ConcurrentTransactionsTestCase) failed

sandbox_test_results.xml [took 11s]
Raw output
TimeoutError: [Errno Reached timeout (%d sec) while waiting for the next block] 5
self = <test_concurrent.ConcurrentTransactionsTestCase testMethod=test_1_originate_contract>

    def test_1_originate_contract(self) -> None:
        ci = ContractInterface.from_michelson(code)
        res = (
            self.client.origination(ci.script())
            .autofill()
            .sign()
>           .inject(
                time_between_blocks=self.TIME_BETWEEN_BLOCKS,
                min_confirmations=1,
                block_timeout=5,
            )
        )

tests/sandbox_tests/test_concurrent.py:28: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 
src/pytezos/jupyter.py:90: in __call__
    return method(self.obj, *args, **kwargs)
src/pytezos/operation/group.py:444: in inject
    operations = self.shell.wait_operations(
src/pytezos/jupyter.py:90: in __call__
    return method(self.obj, *args, **kwargs)
src/pytezos/rpc/shell.py:164: in wait_operations
    for block_hash in self.wait_blocks(  # noqa: B020
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 

self = <pytezos.rpc.shell.ShellQuery object at 0x7f2678744b50>

Properties
.path	/
.node	['http://localhost:8732']

RPC endpo...ls
.stats
.version
.workers

Helpers
.block()
.get_confirmations()
.wait_blocks()
.wait_next_block()
.wait_operations()
current_block_hash = 'BKr4J1zypxB3ZwzgAj7RVLSS7Q6gdLrLLP3ktxWZSd9SPEg13gU'
max_blocks = 5, yield_current = True, time_between_blocks = 3, block_timeout = 5

    def wait_blocks(
        self,
        current_block_hash: str,
        max_blocks: int = 1,
        yield_current=False,
        time_between_blocks: Optional[int] = None,
        block_timeout: Optional[int] = None,
    ) -> Generator[str, None, None]:
        """Iterates over future blocks (waits and yields block hash), handles reorgs
    
        :param current_block_hash: hash of the current block (head)
        :param max_blocks: number of blocks to iterate (not including the current one)
        :param yield_current: yield current block hash at the very beginning
        :param time_between_blocks: override protocol constant
        :param block_timeout: set block timeout (by default Pytezos will wait for a long time)
        :return: block hashes
        """
        if time_between_blocks is None:
            constants = self.blocks[current_block_hash].context.constants()
            time_between_blocks = int(constants.get('minimal_block_delay', 0))
    
        if block_timeout is None:
            block_timeout = MAX_BLOCK_TIMEOUT
    
        if yield_current:
            yield current_block_hash
    
        current_header = self.blocks[current_block_hash].header()
        max_level = current_header['level'] + max_blocks
    
        while current_header['level'] < max_level:
            logger.info('Current level: %d (max %d)', current_header['level'], max_level)
            prev_block_dt = datetime.strptime(current_header['timestamp'], '%Y-%m-%dT%H:%M:%SZ')
            elapsed_sec = (datetime.utcnow() - prev_block_dt).seconds
            sleep_sec = 1 if elapsed_sec > time_between_blocks else (time_between_blocks - elapsed_sec + 1)
    
            logger.info('Sleep %d seconds until block %s is superseded', sleep_sec, current_block_hash)
            sleep(sleep_sec)
    
            next_block_hash: Optional[str] = None
    
            for delay in range(block_timeout):
                next_block_hash = self.head.hash()
                if current_block_hash == next_block_hash:
                    sleep(1)
                else:
                    logger.info('Found new block %s (%d sec delay)', next_block_hash, delay)
                    break
    
            if current_block_hash != next_block_hash:
                assert next_block_hash
                yield next_block_hash
                current_block_hash = next_block_hash
                current_header = self.blocks[current_block_hash].header()
            else:
>               raise TimeoutError('Reached timeout (%d sec) while waiting for the next block', block_timeout)
E               TimeoutError: [Errno Reached timeout (%d sec) while waiting for the next block] 5

src/pytezos/rpc/shell.py:134: TimeoutError