當前位置: 首頁>>代碼示例>>Python>>正文


Python eth_utils.ValidationError方法代碼示例

本文整理匯總了Python中eth_utils.ValidationError方法的典型用法代碼示例。如果您正苦於以下問題:Python eth_utils.ValidationError方法的具體用法?Python eth_utils.ValidationError怎麽用?Python eth_utils.ValidationError使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在eth_utils的用法示例。


在下文中一共展示了eth_utils.ValidationError方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: run_child_service

# 需要導入模塊: import eth_utils [as 別名]
# 或者: from eth_utils import ValidationError [as 別名]
def run_child_service(self, child_service: "BaseService") -> None:
        """
        Run a child service and keep a reference to it to be considered during the cleanup.
        """
        if child_service.is_running:
            raise ValidationError(
                "Can't start service {}, child of {}: it's already running".format(
                    repr(child_service), repr(self)
                )
            )
        elif child_service.is_cancelled:
            raise ValidationError(
                "Can't restart {}, child of {}: it's already completed".format(
                    repr(child_service), repr(self)
                )
            )

        self._child_services.add(child_service)
        self.run_task(child_service.run()) 
開發者ID:QuarkChain,項目名稱:pyquarkchain,代碼行數:21,代碼來源:service.py

示例2: test_chain_builder_disable_pow_check

# 需要導入模塊: import eth_utils [as 別名]
# 或者: from eth_utils import ValidationError [as 別名]
def test_chain_builder_disable_pow_check():
    chain = build(
        MiningChain,
        frontier_at(0),
        disable_pow_check(),
        genesis(),
    )
    block = chain.mine_block()
    with pytest.raises(ValidationError, match='mix hash mismatch'):
        check_pow(
            block.number,
            block.header.mining_hash,
            block.header.mix_hash,
            block.header.nonce,
            block.header.difficulty,
        ) 
開發者ID:ethereum,項目名稱:py-evm,代碼行數:18,代碼來源:test_chain_construction.py

示例3: test_enr_response_handler_does_not_crash_on_invalid_responses

# 需要導入模塊: import eth_utils [as 別名]
# 或者: from eth_utils import ValidationError [as 別名]
def test_enr_response_handler_does_not_crash_on_invalid_responses():
    discovery = MockDiscoveryService([])
    token = b''
    invalid_enr = b'garbage'
    payload = [token, invalid_enr]
    await discovery.recv_enr_response(discovery.this_node, payload, b'')

    enr = ENRFactory()
    enr._kv_pairs.pop(b'secp256k1')
    with pytest.raises(ValidationError):
        ENR.deserialize(ENR.serialize(enr))
    payload = [token, ENR.serialize(enr)]
    await discovery.recv_enr_response(discovery.this_node, payload, b'')

    enr = ENRFactory()
    enr._signature = b'garbage'
    with pytest.raises(eth_keys.exceptions.ValidationError):
        enr.validate_signature()
    payload = [token, ENR.serialize(enr)]
    await discovery.recv_enr_response(discovery.this_node, payload, b'') 
開發者ID:ethereum,項目名稱:trinity,代碼行數:22,代碼來源:test_discovery.py

示例4: wait_tip_info

# 需要導入模塊: import eth_utils [as 別名]
# 或者: from eth_utils import ValidationError [as 別名]
def wait_tip_info(self) -> AsyncIterator[BaseChainPeer]:
        """
        This iterator waits until there is potentially new tip information.
        New tip information means a new peer connected or a new block arrived.
        Then it yields the peer with the highest total difficulty.
        It continues indefinitely, until this service is cancelled.
        """
        if self.manager.is_cancelled:
            raise ValidationError("%s is cancelled, new tip info is impossible", self)
        elif not self.manager.is_running:
            await self.manager.wait_started()

        with self._subscriber() as new_tip_event:
            while self.manager.is_running:
                try:
                    highest_td_peer = self._peer_pool.highest_td_peer
                except NoConnectedPeers:
                    # no peers are available right now, skip the new tip info yield
                    pass
                else:
                    yield highest_td_peer

                await new_tip_event.wait()
                new_tip_event.clear() 
開發者ID:ethereum,項目名稱:trinity,代碼行數:26,代碼來源:monitors.py

示例5: _get_tip_header

# 需要導入模塊: import eth_utils [as 別名]
# 或者: from eth_utils import ValidationError [as 別名]
def _get_tip_header(self) -> BlockHeader:
        try:
            headers = await self.peer.chain_api.get_block_headers(
                self.peer.head_info.head_hash,
                max_headers=1,
                timeout=CHAIN_SPLIT_CHECK_TIMEOUT,
            )

        except (asyncio.TimeoutError, PeerConnectionLost) as err:
            raise DAOForkCheckFailure(
                f"Timed out waiting for tip header from {self.peer}: {err}"
            ) from err
        except ValidationError as err:
            raise DAOForkCheckFailure(
                f"Invalid header response for tip header during DAO fork check: {err}"
            ) from err
        else:
            if len(headers) != 1:
                raise DAOForkCheckFailure(
                    f"{self.peer} returned {headers!r} when asked for tip"
                )
            else:
                return headers[0] 
開發者ID:ethereum,項目名稱:trinity,代碼行數:25,代碼來源:boot.py

示例6: send_get_block_headers

# 需要導入模塊: import eth_utils [as 別名]
# 或者: from eth_utils import ValidationError [as 別名]
def send_get_block_headers(
            self,
            block_number_or_hash: Union[BlockNumber, Hash32],
            max_headers: int,
            skip: int,
            reverse: bool) -> int:
        if max_headers > MAX_HEADERS_FETCH:
            raise ValidationError(
                f"Cannot ask for more than {MAX_HEADERS_FETCH} headers in a single request"
            )
        query = BlockHeadersQuery(
            block_number_or_hash=block_number_or_hash,
            max_headers=max_headers,
            skip=skip,
            reverse=reverse,
        )
        payload = GetBlockHeadersPayload(
            request_id=gen_request_id(),
            query=query,
        )
        self.protocol.send(GetBlockHeaders(payload))
        return payload.request_id 
開發者ID:ethereum,項目名稱:trinity,代碼行數:24,代碼來源:api.py

示例7: _get_new_root

# 需要導入模塊: import eth_utils [as 別名]
# 或者: from eth_utils import ValidationError [as 別名]
def _get_new_root(self, node_id: TNodeID, parent_id: TNodeID) -> Tuple[TreeRoot[TNodeID], int]:
        if self._tree.has_parent(node_id):
            try:
                parent_root = self._roots[parent_id]
            except KeyError as e:
                tree_parent = self._tree.parent_of(node_id)
                raise ValidationError(
                    f"When adding node {node_id} with parent {parent_id}, The tree says that "
                    f"parent {tree_parent} is present, but the parent is missing from roots."
                ) from e

            if len(self._tree.children_of(parent_id)) > 1:
                node_root = TreeRoot(node_id)
                node_root.extend(parent_root, 0)
            else:
                node_root = parent_root
            original_depth = self._original_depth_to_root[parent_id] + 1
        else:
            node_root = TreeRoot(node_id)
            original_depth = 0

        return node_root, original_depth 
開發者ID:ethereum,項目名稱:trinity,代碼行數:24,代碼來源:tree_root.py

示例8: _link_children

# 需要導入模塊: import eth_utils [as 別名]
# 或者: from eth_utils import ValidationError [as 別名]
def _link_children(
            self,
            parent_root: TreeRoot[TNodeID],
            parent_original_depth: int,
            children: Tuple[TNodeID, ...]) -> None:

        for child in children:
            child_root = self._roots[child]

            if child_root.depth_offset + self._original_depth_to_root[child] != 0:
                raise ValidationError(
                    "children without parents must have net depth 0: "
                    f"but offset was {child_root.depth_offset} and original depth "
                    f"was {self._original_depth_to_root[child]}."
                )
            else:
                # original depth was 0, needs to be adjusted based on parent's original depth
                ideal_original_depth = parent_original_depth + 1
                actual_original_depth = self._original_depth_to_root[child]
                # extension length = ideal - actual = ideal - 0
                child_root.extend(parent_root, ideal_original_depth - actual_original_depth) 
開發者ID:ethereum,項目名稱:trinity,代碼行數:23,代碼來源:tree_root.py

示例9: run_import

# 需要導入模塊: import eth_utils [as 別名]
# 或者: from eth_utils import ValidationError [as 別名]
def run_import(cls, args: Namespace, trinity_config: TrinityConfig) -> None:
        with open(args.file_path, 'rb') as import_file:
            # This won't handle large files.
            # TODO: Make this stream based: https://github.com/ethereum/trinity/issues/1282
            file_bytes = import_file.read()

        blocks = decode_all(file_bytes, sedes=FrontierBlock)

        cls.logger.info("Importing %s blocks", len(blocks))

        chain = get_chain(trinity_config)

        for block in blocks:
            try:
                chain.import_block(block)
            except (EVMMissingData, ValidationError) as exc:
                cls.logger.error(exc)
                cls.logger.error("Import failed")
            else:
                cls.logger.info("Successfully imported %s", block) 
開發者ID:ethereum,項目名稱:trinity,代碼行數:22,代碼來源:component.py

示例10: handle_slot_tick

# 需要導入模塊: import eth_utils [as 別名]
# 或者: from eth_utils import ValidationError [as 別名]
def handle_slot_tick(self) -> None:
        """
        The callback for `SlotTicker` and it's expected to be called twice for one slot.
        """
        async for event in self.event_bus.stream(SlotTickEvent):
            try:
                self._check_and_update_data_per_slot(event.slot)
                if event.tick_type.is_start:
                    await self.handle_first_tick(event.slot)
                elif event.tick_type.is_one_third:
                    await self.handle_second_tick(event.slot)
                elif event.tick_type.is_two_third:
                    await self.handle_third_tick(event.slot)
            except ValidationError as e:
                self.logger.warn("%s", e)
                self.logger.warn(
                    "SHOULD NOT GET A VALIDATION ERROR"
                    " HERE AS IT IS INTERNAL TO OUR OWN CODE"
                ) 
開發者ID:ethereum,項目名稱:trinity,代碼行數:21,代碼來源:validator.py

示例11: handle_slot_tick

# 需要導入模塊: import eth_utils [as 別名]
# 或者: from eth_utils import ValidationError [as 別名]
def handle_slot_tick(self) -> None:
        """
        The callback for `SlotTicker` and it's expected to be called twice for one slot.
        """
        async for event in self.event_bus.stream(SlotTickEvent):
            try:
                self._check_and_update_data_per_slot(event.slot)
                if event.tick_type.is_start:
                    pass
                elif event.tick_type.is_one_third:
                    await self.handle_second_tick(event.slot)
                elif event.tick_type.is_two_third:
                    pass
            except ValidationError as e:
                self.logger.warn("%s", e)
                self.logger.warn(
                    "SHOULD NOT GET A VALIDATION ERROR"
                    " HERE AS IT IS INTERNAL TO OUR OWN CODE"
                ) 
開發者ID:ethereum,項目名稱:trinity,代碼行數:21,代碼來源:chain_maintainer.py

示例12: apply

# 需要導入模塊: import eth_utils [as 別名]
# 或者: from eth_utils import ValidationError [as 別名]
def apply(self, connection: ConnectionAPI) -> AsyncIterator[asyncio.Future[None]]:
        if self._applied_to is not None:
            raise ValidationError(
                f"Reentrance: Behavior has already been applied to a "
                f"connection: {self._applied_to}"
            )
        else:
            # this acts as re-entrance protection for for the `Behavior` instance.
            self._applied_to = connection

        if hasattr(self.logic, '_behavior'):
            raise ValidationError(
                f"Reentrance: Logic already bound to a behavior: "
                f"{self.logic._behavior}"
            )
        else:
            # this acts as re-entrance protection on the actual `LogicAPI` instance
            self.logic._behavior = self

        # once the logic is bound to the connection we enter it's context.
        async with self.logic.apply(connection) as task:
            yield task 
開發者ID:ethereum,項目名稱:trinity,代碼行數:24,代碼來源:behaviors.py

示例13: test_validate_attestation_slot

# 需要導入模塊: import eth_utils [as 別名]
# 或者: from eth_utils import ValidationError [as 別名]
def test_validate_attestation_slot(
    attestation_slot,
    state_slot,
    slots_per_epoch,
    min_attestation_inclusion_delay,
    is_valid,
):

    if is_valid:
        validate_attestation_slot(
            attestation_slot,
            state_slot,
            slots_per_epoch,
            min_attestation_inclusion_delay,
        )
    else:
        with pytest.raises(ValidationError):
            validate_attestation_slot(
                attestation_slot,
                state_slot,
                slots_per_epoch,
                min_attestation_inclusion_delay,
            ) 
開發者ID:ethereum,項目名稱:trinity,代碼行數:25,代碼來源:test_serenity_block_attestation_validation.py

示例14: test_validate_validator_has_not_exited

# 需要導入模塊: import eth_utils [as 別名]
# 或者: from eth_utils import ValidationError [as 別名]
def test_validate_validator_has_not_exited(
    genesis_state, validator_exit_epoch, success
):
    state = genesis_state

    validator_index = 0

    validator = state.validators[validator_index].set(
        "exit_epoch", validator_exit_epoch
    )

    if success:
        _validate_validator_has_not_exited(validator)
    else:
        with pytest.raises(ValidationError):
            _validate_validator_has_not_exited(validator) 
開發者ID:ethereum,項目名稱:trinity,代碼行數:18,代碼來源:test_serenity_block_voluntary_exit_validation.py

示例15: test_validate_voluntary_exit_signature

# 需要導入模塊: import eth_utils [as 別名]
# 或者: from eth_utils import ValidationError [as 別名]
def test_validate_voluntary_exit_signature(genesis_state, keymap, config, success):
    slots_per_epoch = config.SLOTS_PER_EPOCH
    state = genesis_state
    validator_index = 0
    voluntary_exit = create_mock_voluntary_exit(state, config, keymap, validator_index)
    validator = state.validators[validator_index]
    if success:
        _validate_voluntary_exit_signature(
            state, voluntary_exit, validator, slots_per_epoch
        )
    else:
        # Use wrong signature
        voluntary_exit = voluntary_exit.set(
            "signature", b"\x12" * 96
        )  # wrong signature
        with pytest.raises(ValidationError):
            _validate_voluntary_exit_signature(
                state, voluntary_exit, validator, slots_per_epoch
            ) 
開發者ID:ethereum,項目名稱:trinity,代碼行數:21,代碼來源:test_serenity_block_voluntary_exit_validation.py


注:本文中的eth_utils.ValidationError方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。