╲!*▓?◆█@?█**▓*○~╳!◇#?*○◇○!▪●○◇#▓▓▒#■*○▫?□*◇%^▓▒◇#◆*■!▪*■▓▒?╱■□▪?
Transaction ID
Execution Error
[Error Code: 1101] error caused by: 1 error occurred: * transaction execute failed: [Error Code: 1101] cadence runtime error: Execution failed: error: assertion failed: evm_error=nonce too low: address 0x869cf1D1eB22F4A70eB230Ef597DF84f748146eE, tx: 1547960 state: 1547961;evm_error_code=201 --> 49e6d2111583c6681b356f28309b18d02a1e2909e7b067237f6faa1e32fee06b:17:12 | 17 | assert( 18 | txResult.status == EVM.Status.failed || txResult.status == EVM.Status.successful, 19 | message: "evm_error=\(txResult.errorMessage);evm_error_code=\(txResult.errorCode)" 20 | ) | ^ Was this error unhelpful? Consider suggesting an improvement here: https://github.com/onflow/cadence/issues.
Script Arguments
[ "f8ee83179eb88405f5e100833cfa39947e8dd69f0675e61efaefe3403f2037f85cc669dd80b884cb67d7ac00000000000000000000000000000000000000000000006c6b935b8bbd4000000000000000000000000000000000000000000000000000000000000000000378000000000000000000000000000000000000000000000000000000000000000100000000000000000000000000000000000000000000000000000000000000008205f9a09ba913c9d5f80067c6bdd21061b64fd1dc5b8a92d752034a07b283ed853e8e44a0642c5d0a93c81d382d5b0cbda4eb7bc2cecba5897a17f4ba296cb22f8c304cfb" ]
Cadence Script
1import EVM from 0xe467b9dd11fa00df
2
3transaction(hexEncodedTxs: [String], coinbase: String) {
4 execute {
5 let txs: [[UInt8]] = []
6 for tx in hexEncodedTxs {
7 txs.append(tx.decodeHex())
8 }
9
10 // If there's only one tx, use `EVM.run`.
11 // If there are more, then use `EVM.batchRun`
12 if txs.length == 1 {
13 let txResult = EVM.run(
14 tx: txs[0],
15 coinbase: EVM.addressFromString(coinbase)
16 )
17 assert(
18 txResult.status == EVM.Status.failed || txResult.status == EVM.Status.successful,
19 message: "evm_error=\(txResult.errorMessage);evm_error_code=\(txResult.errorCode)"
20 )
21 return
22 }
23
24 let txResults = EVM.batchRun(
25 txs: txs,
26 coinbase: EVM.addressFromString(coinbase)
27 )
28
29 // If at least one of the EVM transactions in the batch is either
30 // failed or successful, in other words not invalid, we let the
31 // Cadence transaction succeed.
32 for txResult in txResults {
33 if txResult.status == EVM.Status.failed || txResult.status == EVM.Status.successful {
34 return
35 }
36 }
37
38 // Otherwise, all EVM transactions are invalid txs and can't be
39 // executed (such as nonce too low).
40 // In this case, we fail the Cadence transaction with the error
41 // message from the first EVM transaction.
42 for txResult in txResults {
43 assert(
44 txResult.status == EVM.Status.failed || txResult.status == EVM.Status.successful,
45 message: "evm_error=\(txResult.errorMessage);evm_error_code=\(txResult.errorCode)"
46 )
47 }
48 }
49}