diff options
author | kumavis <kumavis@users.noreply.github.com> | 2016-11-11 13:37:09 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2016-11-11 13:37:09 +0800 |
commit | f88079c6b9c0e7bf5d7765f8ea8471b64624d8d0 (patch) | |
tree | ed4164447d8a06ba9120d00ac2091eb66521bbda | |
parent | 3775a4bf799efc99cfe3d46b35fc0b39a82c94c2 (diff) | |
parent | 1d0abc47711fd93f99289f9c59a58fb4fa2d1587 (diff) | |
download | tangerine-wallet-browser-f88079c6b9c0e7bf5d7765f8ea8471b64624d8d0.tar tangerine-wallet-browser-f88079c6b9c0e7bf5d7765f8ea8471b64624d8d0.tar.gz tangerine-wallet-browser-f88079c6b9c0e7bf5d7765f8ea8471b64624d8d0.tar.bz2 tangerine-wallet-browser-f88079c6b9c0e7bf5d7765f8ea8471b64624d8d0.tar.lz tangerine-wallet-browser-f88079c6b9c0e7bf5d7765f8ea8471b64624d8d0.tar.xz tangerine-wallet-browser-f88079c6b9c0e7bf5d7765f8ea8471b64624d8d0.tar.zst tangerine-wallet-browser-f88079c6b9c0e7bf5d7765f8ea8471b64624d8d0.zip |
Merge pull request #805 from MetaMask/i804
detect tx error - show warning and fix gasLimit
-rw-r--r-- | CHANGELOG.md | 1 | ||||
-rw-r--r-- | app/scripts/lib/idStore.js | 18 | ||||
-rw-r--r-- | ui/app/components/pending-tx.js | 9 |
3 files changed, 26 insertions, 2 deletions
diff --git a/CHANGELOG.md b/CHANGELOG.md index d0dbb5706..d7da7df7b 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,6 +1,7 @@ # Changelog ## Current Master +- Show a warning when a transaction fails during simulation. - Fix bug where 20% of gas estimate was not being added properly. ## 2.13.7 2016-11-8 diff --git a/app/scripts/lib/idStore.js b/app/scripts/lib/idStore.js index dd895a6c0..cd717df28 100644 --- a/app/scripts/lib/idStore.js +++ b/app/scripts/lib/idStore.js @@ -259,10 +259,24 @@ IdentityStore.prototype.addUnconfirmedTransaction = function (txParams, onTxDone } function estimateGas(cb){ - query.estimateGas(txParams, function(err, result){ + var estimationParams = extend(txParams) + // 1 billion gas for estimation + var gasLimit = '0x3b9aca00' + estimationParams.gas = gasLimit + query.estimateGas(estimationParams, function(err, result){ if (err) return cb(err) + if (result === estimationParams.gas) { + txData.simulationFails = true + query.getBlockByNumber('latest', true, function(err, block){ + if (err) return cb(err) + txData.estimatedGas = block.gasLimit + txData.txParams.gas = block.gasLimit + cb() + }) + return + } txData.estimatedGas = self.addGasBuffer(result) - txData.txParams.gasLimit = txData.estimatedGas + txData.txParams.gas = txData.estimatedGas cb() }) } diff --git a/ui/app/components/pending-tx.js b/ui/app/components/pending-tx.js index 4c27a8092..b619020d1 100644 --- a/ui/app/components/pending-tx.js +++ b/ui/app/components/pending-tx.js @@ -30,6 +30,15 @@ PendingTx.prototype.render = function () { } `), + txData.simulationFails ? + h('span.error', { + style: { + marginLeft: 50, + fontSize: '0.9em', + }, + }, 'Transaction Error. Exception thrown in contract code.') + : null, + state.insufficientBalance ? h('span.error', { style: { |