Add from_script method to Address type
This commit is contained in:
		
							parent
							
								
									0e6b472793
								
							
						
					
					
						commit
						63b85b9100
					
				| @ -446,6 +446,9 @@ interface Address { | |||||||
|   [Throws=BdkError] |   [Throws=BdkError] | ||||||
|   constructor(string address); |   constructor(string address); | ||||||
| 
 | 
 | ||||||
|  |   [Name=from_script, Throws=BdkError] | ||||||
|  |   constructor(Script script, Network network); | ||||||
|  | 
 | ||||||
|   Payload payload(); |   Payload payload(); | ||||||
| 
 | 
 | ||||||
|   Network network(); |   Network network(); | ||||||
|  | |||||||
| @ -364,6 +364,13 @@ impl Address { | |||||||
|             .map_err(|e| BdkError::Generic(e.to_string())) |             .map_err(|e| BdkError::Generic(e.to_string())) | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     /// alternative constructor
 | ||||||
|  |     fn from_script(script: Arc<Script>, network: Network) -> Result<Self, BdkError> { | ||||||
|  |         BdkAddress::from_script(&script.script, network) | ||||||
|  |             .map(|a| Address { address: a }) | ||||||
|  |             .map_err(|e| BdkError::Generic(e.to_string())) | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     fn payload(&self) -> Payload { |     fn payload(&self) -> Payload { | ||||||
|         match &self.address.payload.clone() { |         match &self.address.payload.clone() { | ||||||
|             BdkPayload::PubkeyHash(pubkey_hash) => Payload::PubkeyHash { |             BdkPayload::PubkeyHash(pubkey_hash) => Payload::PubkeyHash { | ||||||
|  | |||||||
							
								
								
									
										0
									
								
								bdk-python/tests/__init__.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										0
									
								
								bdk-python/tests/__init__.py
									
									
									
									
									
										Normal file
									
								
							| @ -43,6 +43,21 @@ class TestSimpleBip84Wallet(unittest.TestCase): | |||||||
|         # print(f"Balance is {balance.total} sat") |         # print(f"Balance is {balance.total} sat") | ||||||
|         assert balance.total > 0, "Balance is 0, send testnet coins to tb1qzg4mckdh50nwdm9hkzq06528rsu73hjxxzem3e" |         assert balance.total > 0, "Balance is 0, send testnet coins to tb1qzg4mckdh50nwdm9hkzq06528rsu73hjxxzem3e" | ||||||
| 
 | 
 | ||||||
|  |     def test_output_address_from_script_pubkey(self): | ||||||
|  |         wallet = bdk.Wallet( | ||||||
|  |             descriptor=descriptor, | ||||||
|  |             change_descriptor=None, | ||||||
|  |             network=bdk.Network.TESTNET, | ||||||
|  |             database_config=db_config, | ||||||
|  |         ) | ||||||
|  |         wallet.sync(blockchain, None) | ||||||
|  |         first_tx = list(wallet.list_transactions(True))[0] | ||||||
|  |         assert first_tx.txid == '35d3de8dd429ec4c9684168c1fbb9a4fb6db6f2ce89be214a024657a73ef4908' | ||||||
|  |          | ||||||
|  |         output1, output2 = list(first_tx.transaction.output()) | ||||||
|  |          | ||||||
|  |         assert bdk.Address.from_script(output1.script_pubkey, bdk.Network.TESTNET).as_string() == 'tb1qw6ly2te8k9vy2mwj3g6gx82hj7hc8f5q3vry8t' | ||||||
|  |         assert bdk.Address.from_script(output2.script_pubkey, bdk.Network.TESTNET).as_string() == 'tb1qzsvpnmme78yl60j7ldh9aqvhvxr4mz7mjpmh22' | ||||||
|          |          | ||||||
| if __name__ == '__main__': | if __name__ == '__main__': | ||||||
|     unittest.main() |     unittest.main() | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user