1
0
mirror of https://github.com/kremalicious/metamask-extension.git synced 2024-11-23 02:10:12 +01:00

Ensure simulation failure warning is shown on all networks and accounts (#17458)

* Ensure simulation failure warning is shown on all networks and accounts

* Add e2e test to cover failure warning behaviour on non-eip-1559 network

* Fix new e2e test
This commit is contained in:
Dan J Miller 2023-02-10 07:15:54 -08:00 committed by PeterYinusa
parent 72ae54bfa3
commit 48251a4189
2 changed files with 89 additions and 3 deletions

View File

@ -85,3 +85,91 @@ describe('Failing contract interaction ', function () {
); );
}); });
}); });
describe('Failing contract interaction on non-EIP1559 network', function () {
const smartContract = SMART_CONTRACTS.FAILING;
const ganacheOptions = {
hardfork: 'berlin',
accounts: [
{
secretKey:
'0x7C9529A67102755B7E6102D6D950AC5D5863C98713805CEC576B945B15B71EAC',
balance: convertToHexValue(25000000000000000000),
},
],
};
it('should display a warning when the contract interaction is expected to fail', async function () {
await withFixtures(
{
dapp: true,
fixtures: new FixtureBuilder()
.withPermissionControllerConnectedToTestDapp()
.build(),
ganacheOptions,
smartContract,
title: this.test.title,
},
async ({ driver, contractRegistry }) => {
const contractAddress = await contractRegistry.getContractAddress(
smartContract,
);
await driver.navigate();
await driver.fill('#password', 'correct horse battery staple');
await driver.press('#password', driver.Key.ENTER);
await driver.openNewPage(
`http://127.0.0.1:8080/?contract=${contractAddress}`,
);
let windowHandles = await driver.getAllWindowHandles();
const extension = windowHandles[0];
// waits for deployed contract and calls failing contract method
await driver.findClickableElement('#deployButton');
await driver.fill('#toInput', contractAddress);
await driver.fill('#amountInput', '0');
await driver.fill('#gasInput', '100');
await driver.clickElement('#submitForm');
await driver.waitUntilXWindowHandles(3);
windowHandles = await driver.getAllWindowHandles();
await driver.switchToWindowWithTitle(
'MetaMask Notification',
windowHandles,
);
// display warning when transaction is expected to fail
const warningText =
'We were not able to estimate gas. There might be an error in the contract and this transaction may fail.';
const warning = await driver.findElement(
'.actionable-message__message',
);
const confirmButton = await driver.findElement(
'[data-testid="page-container-footer-next"]',
);
assert.equal(await warning.getText(), warningText);
assert.equal(await confirmButton.isEnabled(), false);
// dismiss warning and confirm the transaction
await driver.clickElement({
text: 'I want to proceed anyway',
tag: 'button',
});
await driver.clickElement({ text: 'Confirm', tag: 'button' });
await driver.waitUntilXWindowHandles(2);
await driver.switchToWindow(extension);
await driver.clickElement({ text: 'Activity', tag: 'button' });
await driver.waitForSelector(
'.transaction-list__completed-transactions .transaction-list-item:nth-of-type(1)',
{ timeout: 10000 },
);
// display the transaction status
const transactionStatus = await driver.findElement(
'.transaction-list-item:nth-of-type(1) .transaction-status-label',
);
assert.equal(await transactionStatus.getText(), 'Failed');
},
);
});
});

View File

@ -595,9 +595,7 @@ export default class ConfirmTransactionBase extends Component {
: () => this.handleEditGas() : () => this.handleEditGas()
} }
rows={[ rows={[
renderSimulationFailureWarning && renderSimulationFailureWarning && simulationFailureWarning(),
!this.supportsEIP1559 &&
simulationFailureWarning(),
!renderSimulationFailureWarning && !renderSimulationFailureWarning &&
!isMultiLayerFeeNetwork && !isMultiLayerFeeNetwork &&
renderGasDetailsItem(), renderGasDetailsItem(),