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:
parent
72ae54bfa3
commit
48251a4189
@ -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');
|
||||||
|
},
|
||||||
|
);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
@ -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(),
|
||||||
|
Loading…
Reference in New Issue
Block a user