aboutsummaryrefslogtreecommitdiffstats
path: root/app/scripts/lib/tx-utils.js
diff options
context:
space:
mode:
authorsdtsui <szehungdanieltsui@gmail.com>2017-08-14 17:06:14 +0800
committersdtsui <szehungdanieltsui@gmail.com>2017-08-14 17:06:14 +0800
commitdbc539ac558958fee339cb1ab43202385d98d089 (patch)
tree00296e883ff128f141df51915650fd5075f9cdd7 /app/scripts/lib/tx-utils.js
parent2eadf72fb772b5b6bd32f04c9d439cc0f1ab0453 (diff)
parent68c6b2d666719476bff78cbc107a56be3b86dbe1 (diff)
downloadtangerine-wallet-browser-dbc539ac558958fee339cb1ab43202385d98d089.tar
tangerine-wallet-browser-dbc539ac558958fee339cb1ab43202385d98d089.tar.gz
tangerine-wallet-browser-dbc539ac558958fee339cb1ab43202385d98d089.tar.bz2
tangerine-wallet-browser-dbc539ac558958fee339cb1ab43202385d98d089.tar.lz
tangerine-wallet-browser-dbc539ac558958fee339cb1ab43202385d98d089.tar.xz
tangerine-wallet-browser-dbc539ac558958fee339cb1ab43202385d98d089.tar.zst
tangerine-wallet-browser-dbc539ac558958fee339cb1ab43202385d98d089.zip
Merge remote-tracking branch 'mm/master' into NewUI-flat
Diffstat (limited to 'app/scripts/lib/tx-utils.js')
-rw-r--r--app/scripts/lib/tx-utils.js14
1 files changed, 11 insertions, 3 deletions
diff --git a/app/scripts/lib/tx-utils.js b/app/scripts/lib/tx-utils.js
index b64ea6712..5af078dc4 100644
--- a/app/scripts/lib/tx-utils.js
+++ b/app/scripts/lib/tx-utils.js
@@ -20,7 +20,15 @@ module.exports = class txProvideUtil {
async analyzeGasUsage (txMeta) {
const block = await this.query.getBlockByNumber('latest', true)
- const estimatedGasHex = await this.estimateTxGas(txMeta, block.gasLimit)
+ let estimatedGasHex
+ try {
+ estimatedGasHex = await this.estimateTxGas(txMeta, block.gasLimit)
+ } catch (err) {
+ if (err.message.includes('Transaction execution error.')) {
+ txMeta.simulationFails = true
+ return txMeta
+ }
+ }
this.setTxGas(txMeta, block.gasLimit, estimatedGasHex)
return txMeta
}
@@ -35,8 +43,8 @@ module.exports = class txProvideUtil {
const saferGasLimitBN = BnMultiplyByFraction(blockGasLimitBN, 19, 20)
txParams.gas = bnToHex(saferGasLimitBN)
}
- // run tx, see if it will OOG
- return this.query.estimateGas(txParams)
+ // run tx
+ return await this.query.estimateGas(txParams)
}
setTxGas (txMeta, blockGasLimitHex, estimatedGasHex) {