added from and to to Receipt (#8756)
This commit is contained in:
parent
c8877d4098
commit
a6d267abc0
@ -2336,6 +2336,11 @@ fn transaction_receipt(machine: &::machine::EthereumMachine, mut tx: LocalizedTr
|
|||||||
let transaction_index = tx.transaction_index;
|
let transaction_index = tx.transaction_index;
|
||||||
|
|
||||||
LocalizedReceipt {
|
LocalizedReceipt {
|
||||||
|
from: sender,
|
||||||
|
to: match tx.action {
|
||||||
|
Action::Create => None,
|
||||||
|
Action::Call(ref address) => Some(address.clone().into())
|
||||||
|
},
|
||||||
transaction_hash: transaction_hash,
|
transaction_hash: transaction_hash,
|
||||||
transaction_index: transaction_index,
|
transaction_index: transaction_index,
|
||||||
block_hash: block_hash,
|
block_hash: block_hash,
|
||||||
@ -2461,6 +2466,11 @@ mod tests {
|
|||||||
|
|
||||||
// then
|
// then
|
||||||
assert_eq!(receipt, LocalizedReceipt {
|
assert_eq!(receipt, LocalizedReceipt {
|
||||||
|
from: tx1.sender().into(),
|
||||||
|
to: match tx1.action {
|
||||||
|
Action::Create => None,
|
||||||
|
Action::Call(ref address) => Some(address.clone().into())
|
||||||
|
},
|
||||||
transaction_hash: tx1.hash(),
|
transaction_hash: tx1.hash(),
|
||||||
transaction_index: 1,
|
transaction_index: 1,
|
||||||
block_hash: block_hash,
|
block_hash: block_hash,
|
||||||
|
@ -16,7 +16,7 @@
|
|||||||
|
|
||||||
//! Receipt
|
//! Receipt
|
||||||
|
|
||||||
use ethereum_types::{H256, U256, Address, Bloom};
|
use ethereum_types::{H160, H256, U256, Address, Bloom};
|
||||||
use heapsize::HeapSizeOf;
|
use heapsize::HeapSizeOf;
|
||||||
use rlp::{Rlp, RlpStream, Encodable, Decodable, DecoderError};
|
use rlp::{Rlp, RlpStream, Encodable, Decodable, DecoderError};
|
||||||
|
|
||||||
@ -157,6 +157,10 @@ pub struct LocalizedReceipt {
|
|||||||
pub log_bloom: Bloom,
|
pub log_bloom: Bloom,
|
||||||
/// Transaction outcome.
|
/// Transaction outcome.
|
||||||
pub outcome: TransactionOutcome,
|
pub outcome: TransactionOutcome,
|
||||||
|
/// Receiver address
|
||||||
|
pub to: Option<H160>,
|
||||||
|
/// Sender
|
||||||
|
pub from: H160
|
||||||
}
|
}
|
||||||
|
|
||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
|
@ -19,7 +19,7 @@ use std::collections::HashMap;
|
|||||||
use std::sync::Arc;
|
use std::sync::Arc;
|
||||||
use std::time::{Instant, Duration, SystemTime, UNIX_EPOCH};
|
use std::time::{Instant, Duration, SystemTime, UNIX_EPOCH};
|
||||||
|
|
||||||
use ethereum_types::{H256, U256, Address};
|
use ethereum_types::{H160, H256, U256, Address};
|
||||||
use parking_lot::Mutex;
|
use parking_lot::Mutex;
|
||||||
use ethcore::account_provider::AccountProvider;
|
use ethcore::account_provider::AccountProvider;
|
||||||
use ethcore::client::{BlockChainClient, BlockId, EachBlockWith, Executed, TestBlockChainClient, TransactionId};
|
use ethcore::client::{BlockChainClient, BlockId, EachBlockWith, Executed, TestBlockChainClient, TransactionId};
|
||||||
@ -1004,6 +1004,8 @@ fn rpc_eth_send_raw_transaction() {
|
|||||||
#[test]
|
#[test]
|
||||||
fn rpc_eth_transaction_receipt() {
|
fn rpc_eth_transaction_receipt() {
|
||||||
let receipt = LocalizedReceipt {
|
let receipt = LocalizedReceipt {
|
||||||
|
from: H160::from_str("b60e8dd61c5d32be8058bb8eb970870f07233155").unwrap(),
|
||||||
|
to: Some(H160::from_str("d46e8dd67c5d32be8058bb8eb970870f07244567").unwrap()),
|
||||||
transaction_hash: H256::zero(),
|
transaction_hash: H256::zero(),
|
||||||
transaction_index: 0,
|
transaction_index: 0,
|
||||||
block_hash: H256::from_str("ed76641c68a1c641aee09a94b3b471f4dc0316efe5ac19cf488e2674cf8d05b5").unwrap(),
|
block_hash: H256::from_str("ed76641c68a1c641aee09a94b3b471f4dc0316efe5ac19cf488e2674cf8d05b5").unwrap(),
|
||||||
@ -1041,7 +1043,7 @@ fn rpc_eth_transaction_receipt() {
|
|||||||
"params": ["0xb903239f8543d04b5dc1ba6579132b143087c68db1b2168786408fcbce568238"],
|
"params": ["0xb903239f8543d04b5dc1ba6579132b143087c68db1b2168786408fcbce568238"],
|
||||||
"id": 1
|
"id": 1
|
||||||
}"#;
|
}"#;
|
||||||
let response = r#"{"jsonrpc":"2.0","result":{"blockHash":"0xed76641c68a1c641aee09a94b3b471f4dc0316efe5ac19cf488e2674cf8d05b5","blockNumber":"0x4510c","contractAddress":null,"cumulativeGasUsed":"0x20","gasUsed":"0x10","logs":[{"address":"0x33990122638b9132ca29c723bdf037f1a891a70c","blockHash":"0xed76641c68a1c641aee09a94b3b471f4dc0316efe5ac19cf488e2674cf8d05b5","blockNumber":"0x4510c","data":"0x","logIndex":"0x1","topics":["0xa6697e974e6a320f454390be03f74955e8978f1a6971ea6730542e37b66179bc","0x4861736852656700000000000000000000000000000000000000000000000000"],"transactionHash":"0x0000000000000000000000000000000000000000000000000000000000000000","transactionIndex":"0x0","transactionLogIndex":"0x0","type":"mined"}],"logsBloom":"0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000","root":"0x0000000000000000000000000000000000000000000000000000000000000000","status":null,"transactionHash":"0x0000000000000000000000000000000000000000000000000000000000000000","transactionIndex":"0x0"},"id":1}"#;
|
let response = r#"{"jsonrpc":"2.0","result":{"blockHash":"0xed76641c68a1c641aee09a94b3b471f4dc0316efe5ac19cf488e2674cf8d05b5","blockNumber":"0x4510c","contractAddress":null,"cumulativeGasUsed":"0x20","from":"0xb60e8dd61c5d32be8058bb8eb970870f07233155","gasUsed":"0x10","logs":[{"address":"0x33990122638b9132ca29c723bdf037f1a891a70c","blockHash":"0xed76641c68a1c641aee09a94b3b471f4dc0316efe5ac19cf488e2674cf8d05b5","blockNumber":"0x4510c","data":"0x","logIndex":"0x1","topics":["0xa6697e974e6a320f454390be03f74955e8978f1a6971ea6730542e37b66179bc","0x4861736852656700000000000000000000000000000000000000000000000000"],"transactionHash":"0x0000000000000000000000000000000000000000000000000000000000000000","transactionIndex":"0x0","transactionLogIndex":"0x0","type":"mined"}],"logsBloom":"0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000","root":"0x0000000000000000000000000000000000000000000000000000000000000000","status":null,"to":"0xd46e8dd67c5d32be8058bb8eb970870f07244567","transactionHash":"0x0000000000000000000000000000000000000000000000000000000000000000","transactionIndex":"0x0"},"id":1}"#;
|
||||||
|
|
||||||
assert_eq!(tester.io.handle_request_sync(request), Some(response.to_owned()));
|
assert_eq!(tester.io.handle_request_sync(request), Some(response.to_owned()));
|
||||||
}
|
}
|
||||||
|
@ -29,6 +29,10 @@ pub struct Receipt {
|
|||||||
/// Block hash
|
/// Block hash
|
||||||
#[serde(rename="blockHash")]
|
#[serde(rename="blockHash")]
|
||||||
pub block_hash: Option<H256>,
|
pub block_hash: Option<H256>,
|
||||||
|
/// Sender
|
||||||
|
pub from: Option<H160>,
|
||||||
|
/// Recipient
|
||||||
|
pub to: Option<H160>,
|
||||||
/// Block number
|
/// Block number
|
||||||
#[serde(rename="blockNumber")]
|
#[serde(rename="blockNumber")]
|
||||||
pub block_number: Option<U256>,
|
pub block_number: Option<U256>,
|
||||||
@ -73,6 +77,8 @@ impl Receipt {
|
|||||||
impl From<LocalizedReceipt> for Receipt {
|
impl From<LocalizedReceipt> for Receipt {
|
||||||
fn from(r: LocalizedReceipt) -> Self {
|
fn from(r: LocalizedReceipt) -> Self {
|
||||||
Receipt {
|
Receipt {
|
||||||
|
to: r.to.map(Into::into),
|
||||||
|
from: Some(r.from.into()),
|
||||||
transaction_hash: Some(r.transaction_hash.into()),
|
transaction_hash: Some(r.transaction_hash.into()),
|
||||||
transaction_index: Some(r.transaction_index.into()),
|
transaction_index: Some(r.transaction_index.into()),
|
||||||
block_hash: Some(r.block_hash.into()),
|
block_hash: Some(r.block_hash.into()),
|
||||||
@ -91,6 +97,8 @@ impl From<LocalizedReceipt> for Receipt {
|
|||||||
impl From<RichReceipt> for Receipt {
|
impl From<RichReceipt> for Receipt {
|
||||||
fn from(r: RichReceipt) -> Self {
|
fn from(r: RichReceipt) -> Self {
|
||||||
Receipt {
|
Receipt {
|
||||||
|
from: None,
|
||||||
|
to: None,
|
||||||
transaction_hash: Some(r.transaction_hash.into()),
|
transaction_hash: Some(r.transaction_hash.into()),
|
||||||
transaction_index: Some(r.transaction_index.into()),
|
transaction_index: Some(r.transaction_index.into()),
|
||||||
block_hash: None,
|
block_hash: None,
|
||||||
@ -109,6 +117,8 @@ impl From<RichReceipt> for Receipt {
|
|||||||
impl From<EthReceipt> for Receipt {
|
impl From<EthReceipt> for Receipt {
|
||||||
fn from(r: EthReceipt) -> Self {
|
fn from(r: EthReceipt) -> Self {
|
||||||
Receipt {
|
Receipt {
|
||||||
|
from: None,
|
||||||
|
to: None,
|
||||||
transaction_hash: None,
|
transaction_hash: None,
|
||||||
transaction_index: None,
|
transaction_index: None,
|
||||||
block_hash: None,
|
block_hash: None,
|
||||||
@ -131,9 +141,11 @@ mod tests {
|
|||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn receipt_serialization() {
|
fn receipt_serialization() {
|
||||||
let s = r#"{"transactionHash":"0x0000000000000000000000000000000000000000000000000000000000000000","transactionIndex":"0x0","blockHash":"0xed76641c68a1c641aee09a94b3b471f4dc0316efe5ac19cf488e2674cf8d05b5","blockNumber":"0x4510c","cumulativeGasUsed":"0x20","gasUsed":"0x10","contractAddress":null,"logs":[{"address":"0x33990122638b9132ca29c723bdf037f1a891a70c","topics":["0xa6697e974e6a320f454390be03f74955e8978f1a6971ea6730542e37b66179bc","0x4861736852656700000000000000000000000000000000000000000000000000"],"data":"0x","blockHash":"0xed76641c68a1c641aee09a94b3b471f4dc0316efe5ac19cf488e2674cf8d05b5","blockNumber":"0x4510c","transactionHash":"0x0000000000000000000000000000000000000000000000000000000000000000","transactionIndex":"0x0","logIndex":"0x1","transactionLogIndex":null,"type":"mined"}],"root":"0x000000000000000000000000000000000000000000000000000000000000000a","logsBloom":"0x0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000f","status":"0x1"}"#;
|
let s = r#"{"transactionHash":"0x0000000000000000000000000000000000000000000000000000000000000000","transactionIndex":"0x0","blockHash":"0xed76641c68a1c641aee09a94b3b471f4dc0316efe5ac19cf488e2674cf8d05b5","from":null,"to":null,"blockNumber":"0x4510c","cumulativeGasUsed":"0x20","gasUsed":"0x10","contractAddress":null,"logs":[{"address":"0x33990122638b9132ca29c723bdf037f1a891a70c","topics":["0xa6697e974e6a320f454390be03f74955e8978f1a6971ea6730542e37b66179bc","0x4861736852656700000000000000000000000000000000000000000000000000"],"data":"0x","blockHash":"0xed76641c68a1c641aee09a94b3b471f4dc0316efe5ac19cf488e2674cf8d05b5","blockNumber":"0x4510c","transactionHash":"0x0000000000000000000000000000000000000000000000000000000000000000","transactionIndex":"0x0","logIndex":"0x1","transactionLogIndex":null,"type":"mined"}],"root":"0x000000000000000000000000000000000000000000000000000000000000000a","logsBloom":"0x0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000f","status":"0x1"}"#;
|
||||||
|
|
||||||
let receipt = Receipt {
|
let receipt = Receipt {
|
||||||
|
from: None,
|
||||||
|
to: None,
|
||||||
transaction_hash: Some(0.into()),
|
transaction_hash: Some(0.into()),
|
||||||
transaction_index: Some(0.into()),
|
transaction_index: Some(0.into()),
|
||||||
block_hash: Some("ed76641c68a1c641aee09a94b3b471f4dc0316efe5ac19cf488e2674cf8d05b5".parse().unwrap()),
|
block_hash: Some("ed76641c68a1c641aee09a94b3b471f4dc0316efe5ac19cf488e2674cf8d05b5".parse().unwrap()),
|
||||||
|
Loading…
Reference in New Issue
Block a user