From 7c6209f7294f3161d9ac27aa33342bdee0e6543e Mon Sep 17 00:00:00 2001 From: Uxio Fuentefria Date: Wed, 10 Jun 2020 11:40:39 +0200 Subject: [PATCH 1/2] Use Optional for typing on eth.py --- web3/eth.py | 34 ++++++++++++++++++++-------------- 1 file changed, 20 insertions(+), 14 deletions(-) diff --git a/web3/eth.py b/web3/eth.py index 18b4308690..37b96f973f 100644 --- a/web3/eth.py +++ b/web3/eth.py @@ -153,7 +153,8 @@ def chainId(self) -> int: return self.web3.manager.request_blocking(RPC.eth_chainId, []) def getBalance( - self, account: Union[Address, ChecksumAddress, ENS], block_identifier: BlockIdentifier=None + self, account: Union[Address, ChecksumAddress, ENS], + block_identifier: Optional[BlockIdentifier] = None ) -> Wei: if block_identifier is None: block_identifier = self.defaultBlock @@ -166,7 +167,7 @@ def getStorageAt( self, account: Union[Address, ChecksumAddress, ENS], position: int, - block_identifier: BlockIdentifier=None + block_identifier: Optional[BlockIdentifier] = None ) -> bytes: if block_identifier is None: block_identifier = self.defaultBlock @@ -179,7 +180,7 @@ def getProof( self, account: Union[Address, ChecksumAddress, ENS], positions: Sequence[int], - block_identifier: BlockIdentifier=None + block_identifier: Optional[BlockIdentifier] = None ) -> MerkleProof: if block_identifier is None: block_identifier = self.defaultBlock @@ -189,7 +190,8 @@ def getProof( ) def getCode( - self, account: Union[Address, ChecksumAddress, ENS], block_identifier: BlockIdentifier=None + self, account: Union[Address, ChecksumAddress, ENS], + block_identifier: Optional[BlockIdentifier] = None ) -> HexBytes: if block_identifier is None: block_identifier = self.defaultBlock @@ -199,7 +201,7 @@ def getCode( ) def getBlock( - self, block_identifier: BlockIdentifier, full_transactions: bool=False + self, block_identifier: BlockIdentifier, full_transactions: bool = False ) -> BlockData: """ `eth_getBlockByHash` @@ -344,7 +346,8 @@ def getTransactionReceipt(self, transaction_hash: _Hash32) -> TxReceipt: return result def getTransactionCount( - self, account: Union[Address, ChecksumAddress, ENS], block_identifier: BlockIdentifier=None + self, account: Union[Address, ChecksumAddress, ENS], + block_identifier: Optional[BlockIdentifier] = None ) -> Nonce: if block_identifier is None: block_identifier = self.defaultBlock @@ -395,9 +398,9 @@ def sendRawTransaction(self, raw_transaction: HexStr) -> HexBytes: def sign( self, account: Union[Address, ChecksumAddress, ENS], - data: Union[int, bytes]=None, - hexstr: HexStr=None, - text: str=None + data: Optional[Union[int, bytes]] = None, + hexstr: Optional[HexStr] = None, + text: Optional[str] = None ) -> HexStr: message_hex = to_hex(data, hexstr=hexstr, text=text) return self.web3.manager.request_blocking( @@ -417,7 +420,8 @@ def signTypedData( ) @apply_to_return_value(HexBytes) - def call(self, transaction: TxParams, block_identifier: BlockIdentifier=None) -> Sequence[Any]: + def call(self, transaction: TxParams, + block_identifier: Optional[BlockIdentifier] = None) -> Sequence[Any]: # TODO: move to middleware if 'from' not in transaction and is_checksum_address(self.defaultAccount): transaction = assoc(transaction, 'from', self.defaultAccount) @@ -430,7 +434,8 @@ def call(self, transaction: TxParams, block_identifier: BlockIdentifier=None) -> [transaction, block_identifier], ) - def estimateGas(self, transaction: TxParams, block_identifier: BlockIdentifier=None) -> Wei: + def estimateGas(self, transaction: TxParams, + block_identifier: Optional[BlockIdentifier] = None) -> Wei: # TODO: move to middleware if 'from' not in transaction and is_checksum_address(self.defaultAccount): transaction = assoc(transaction, 'from', self.defaultAccount) @@ -446,7 +451,8 @@ def estimateGas(self, transaction: TxParams, block_identifier: BlockIdentifier=N ) def filter( - self, filter_params: Union[str, FilterParams]=None, filter_id: HexStr=None + self, filter_params: Optional[Union[str, FilterParams]] = None, + filter_id: Optional[HexStr] = None ) -> Filter: if filter_id and filter_params: raise TypeError( @@ -519,7 +525,7 @@ def contract(self, address: None=None, **kwargs: Any) -> Type[Contract]: ... # def contract(self, address: Union[Address, ChecksumAddress, ENS], **kwargs: Any) -> Contract: ... # noqa: E704,E501 def contract( # noqa: F811 - self, address: Union[Address, ChecksumAddress, ENS]=None, **kwargs: Any + self, address: Optional[Union[Address, ChecksumAddress, ENS]] = None, **kwargs: Any ) -> Union[Type[Contract], Contract]: ContractFactoryClass = kwargs.pop('ContractFactoryClass', self.defaultContractFactory) @@ -541,7 +547,7 @@ def getCompilers(self) -> NoReturn: def getWork(self) -> List[HexBytes]: return self.web3.manager.request_blocking(RPC.eth_getWork, []) - def generateGasPrice(self, transaction_params: TxParams=None) -> Optional[Wei]: + def generateGasPrice(self, transaction_params: Optional[TxParams] = None) -> Optional[Wei]: if self.gasPriceStrategy: return self.gasPriceStrategy(self.web3, transaction_params) return None From f1b0dfb924c393ad47269ca9d94179377b5c365a Mon Sep 17 00:00:00 2001 From: Marc Garreau Date: Wed, 10 Jun 2020 12:36:50 -0600 Subject: [PATCH 2/2] Add newsfragment --- newsfragments/1668.bugfix.rst | 1 + 1 file changed, 1 insertion(+) create mode 100644 newsfragments/1668.bugfix.rst diff --git a/newsfragments/1668.bugfix.rst b/newsfragments/1668.bugfix.rst new file mode 100644 index 0000000000..bcf17879dd --- /dev/null +++ b/newsfragments/1668.bugfix.rst @@ -0,0 +1 @@ +Fix type annotations within the ``eth.py`` module. Several arguments that defaulted to ``None`` were not declared ``Optional``.