mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-11-22 09:57:02 +01:00
[E2E]: Revoke nft approval (#15995)
This commit is contained in:
parent
bec2d0cc3e
commit
1295fabfb5
@ -255,7 +255,7 @@
|
||||
"@metamask/eslint-config-typescript": "^9.0.1",
|
||||
"@metamask/forwarder": "^1.1.0",
|
||||
"@metamask/phishing-warning": "^1.2.1",
|
||||
"@metamask/test-dapp": "^5.2.0",
|
||||
"@metamask/test-dapp": "^5.2.1",
|
||||
"@sentry/cli": "^1.58.0",
|
||||
"@storybook/addon-a11y": "^6.5.10",
|
||||
"@storybook/addon-actions": "^6.5.10",
|
||||
|
@ -1,9 +1,5 @@
|
||||
const { strict: assert } = require('assert');
|
||||
const {
|
||||
convertToHexValue,
|
||||
withFixtures,
|
||||
veryLargeDelayMs,
|
||||
} = require('../helpers');
|
||||
const { convertToHexValue, withFixtures } = require('../helpers');
|
||||
const { SMART_CONTRACTS } = require('../seeder/smart-contracts');
|
||||
|
||||
describe('Collectibles', function () {
|
||||
@ -33,18 +29,16 @@ describe('Collectibles', function () {
|
||||
await driver.fill('#password', 'correct horse battery staple');
|
||||
await driver.press('#password', driver.Key.ENTER);
|
||||
|
||||
// Click transfer
|
||||
// Open Dapp and wait for deployed contract
|
||||
await driver.openNewPage(`http://127.0.0.1:8080/?contract=${contract}`);
|
||||
await driver.waitForSelector({
|
||||
css: '#collectiblesStatus',
|
||||
text: 'Deployed',
|
||||
});
|
||||
await driver.delay(veryLargeDelayMs);
|
||||
await driver.findClickableElement('#deployButton');
|
||||
|
||||
// Click Transer
|
||||
await driver.fill('#transferTokenInput', '1');
|
||||
await driver.clickElement('#transferFromButton');
|
||||
await driver.waitUntilXWindowHandles(3);
|
||||
const windowHandles = await driver.getAllWindowHandles();
|
||||
const extension = windowHandles[0];
|
||||
const [extension] = windowHandles;
|
||||
await driver.switchToWindowWithTitle(
|
||||
'MetaMask Notification',
|
||||
windowHandles,
|
||||
@ -87,18 +81,16 @@ describe('Collectibles', function () {
|
||||
await driver.fill('#password', 'correct horse battery staple');
|
||||
await driver.press('#password', driver.Key.ENTER);
|
||||
|
||||
// Click approve
|
||||
// Open Dapp and wait for deployed contract
|
||||
await driver.openNewPage(`http://127.0.0.1:8080/?contract=${contract}`);
|
||||
await driver.waitForSelector({
|
||||
css: '#collectiblesStatus',
|
||||
text: 'Deployed',
|
||||
});
|
||||
await driver.delay(veryLargeDelayMs);
|
||||
await driver.findClickableElement('#deployButton');
|
||||
|
||||
// Click Approve
|
||||
await driver.fill('#approveTokenInput', '1');
|
||||
await driver.clickElement('#approveButton');
|
||||
await driver.waitUntilXWindowHandles(3);
|
||||
const windowHandles = await driver.getAllWindowHandles();
|
||||
const extension = windowHandles[0];
|
||||
const [extension] = windowHandles;
|
||||
await driver.switchToWindowWithTitle(
|
||||
'MetaMask Notification',
|
||||
windowHandles,
|
||||
@ -112,14 +104,14 @@ describe('Collectibles', function () {
|
||||
text: 'View full transaction details',
|
||||
css: '.confirm-approve-content__small-blue-text',
|
||||
});
|
||||
const data = await driver.findElements(
|
||||
const [func] = await driver.findElements(
|
||||
'.confirm-approve-content__data .confirm-approve-content__small-text',
|
||||
);
|
||||
assert.equal(
|
||||
await title.getText(),
|
||||
'Give permission to access your TestDappCollectibles (#1)?',
|
||||
);
|
||||
assert.equal(await data[0].getText(), 'Function: Approve');
|
||||
assert.equal(await func.getText(), 'Function: Approve');
|
||||
|
||||
// Confirm approval
|
||||
await driver.clickElement({ text: 'Confirm', tag: 'button' });
|
||||
@ -138,7 +130,7 @@ describe('Collectibles', function () {
|
||||
},
|
||||
);
|
||||
});
|
||||
it('should approve an address to transfer all NFTs', async function () {
|
||||
it('should enable approval for a third party address to manage all NFTs', async function () {
|
||||
await withFixtures(
|
||||
{
|
||||
dapp: true,
|
||||
@ -154,17 +146,15 @@ describe('Collectibles', function () {
|
||||
await driver.fill('#password', 'correct horse battery staple');
|
||||
await driver.press('#password', driver.Key.ENTER);
|
||||
|
||||
// Click set approval for all
|
||||
// Open Dapp and wait for deployed contract
|
||||
await driver.openNewPage(`http://127.0.0.1:8080/?contract=${contract}`);
|
||||
await driver.waitForSelector({
|
||||
css: '#collectiblesStatus',
|
||||
text: 'Deployed',
|
||||
});
|
||||
await driver.delay(veryLargeDelayMs);
|
||||
await driver.findClickableElement('#deployButton');
|
||||
|
||||
// Enable Set approval for all
|
||||
await driver.clickElement('#setApprovalForAllButton');
|
||||
await driver.waitUntilXWindowHandles(3);
|
||||
const windowHandles = await driver.getAllWindowHandles();
|
||||
const extension = windowHandles[0];
|
||||
const [extension] = windowHandles;
|
||||
await driver.switchToWindowWithTitle(
|
||||
'MetaMask Notification',
|
||||
windowHandles,
|
||||
@ -178,17 +168,90 @@ describe('Collectibles', function () {
|
||||
text: 'View full transaction details',
|
||||
css: '.confirm-approve-content__small-blue-text',
|
||||
});
|
||||
const data = await driver.findElements(
|
||||
const [func, params] = await driver.findElements(
|
||||
'.confirm-approve-content__data .confirm-approve-content__small-text',
|
||||
);
|
||||
const proceedWithCautionIsDisplayed = await driver.isElementPresent(
|
||||
'.dialog--error',
|
||||
);
|
||||
assert.equal(
|
||||
await title.getText(),
|
||||
'Allow access to and transfer of all your TestDappCollectibles?',
|
||||
);
|
||||
assert.equal(await data[0].getText(), 'Function: SetApprovalForAll');
|
||||
assert.equal(await data[1].getText(), 'Parameters: true');
|
||||
assert.equal(await func.getText(), 'Function: SetApprovalForAll');
|
||||
assert.equal(await params.getText(), 'Parameters: true');
|
||||
assert.equal(proceedWithCautionIsDisplayed, true);
|
||||
|
||||
// Confirmation set approval for all
|
||||
// Confirm enabling set approval for all
|
||||
await driver.clickElement({ text: 'Confirm', tag: 'button' });
|
||||
await driver.waitUntilXWindowHandles(2);
|
||||
await driver.switchToWindow(extension);
|
||||
await driver.clickElement('[data-testid="home__activity-tab"]');
|
||||
await driver.waitForSelector(
|
||||
'.transaction-list__completed-transactions .transaction-list-item:nth-of-type(1)',
|
||||
{ timeout: 10000 },
|
||||
);
|
||||
|
||||
// Verify transaction
|
||||
const completedTx = await driver.findElement('.list-item__title');
|
||||
const completedTxText = await completedTx.getText();
|
||||
assert.equal(completedTxText, 'Approve Token with no spend limit');
|
||||
},
|
||||
);
|
||||
});
|
||||
it('should disable approval for a third party address to manage all NFTs', async function () {
|
||||
await withFixtures(
|
||||
{
|
||||
dapp: true,
|
||||
fixtures: 'connected-state',
|
||||
ganacheOptions,
|
||||
smartContract,
|
||||
title: this.test.title,
|
||||
failOnConsoleError: false,
|
||||
},
|
||||
async ({ driver, _, contractRegistry }) => {
|
||||
const contract = contractRegistry.getContractAddress(smartContract);
|
||||
await driver.navigate();
|
||||
await driver.fill('#password', 'correct horse battery staple');
|
||||
await driver.press('#password', driver.Key.ENTER);
|
||||
|
||||
// Open Dapp and wait for deployed contract
|
||||
await driver.openNewPage(`http://127.0.0.1:8080/?contract=${contract}`);
|
||||
await driver.findClickableElement('#deployButton');
|
||||
|
||||
// Disable Set approval for all
|
||||
await driver.clickElement('#revokeButton');
|
||||
await driver.waitUntilXWindowHandles(3);
|
||||
const windowHandles = await driver.getAllWindowHandles();
|
||||
const [extension] = windowHandles;
|
||||
await driver.switchToWindowWithTitle(
|
||||
'MetaMask Notification',
|
||||
windowHandles,
|
||||
);
|
||||
|
||||
// Verify dialog
|
||||
const title = await driver.findElement(
|
||||
'[data-testid="confirm-approve-title"]',
|
||||
);
|
||||
await driver.clickElement({
|
||||
text: 'View full transaction details',
|
||||
css: '.confirm-approve-content__small-blue-text',
|
||||
});
|
||||
const [func, params] = await driver.findElements(
|
||||
'.confirm-approve-content__data .confirm-approve-content__small-text',
|
||||
);
|
||||
const proceedWithCautionIsDisplayed = await driver.isElementPresent(
|
||||
'.dialog--error',
|
||||
);
|
||||
assert.equal(
|
||||
await title.getText(),
|
||||
'Revoke permission to access all of your TestDappCollectibles?',
|
||||
);
|
||||
assert.equal(await func.getText(), 'Function: SetApprovalForAll');
|
||||
assert.equal(await params.getText(), 'Parameters: false');
|
||||
assert.equal(proceedWithCautionIsDisplayed, false);
|
||||
|
||||
// Confirm disabling set approval for all
|
||||
await driver.clickElement({ text: 'Confirm', tag: 'button' });
|
||||
await driver.waitUntilXWindowHandles(2);
|
||||
await driver.switchToWindow(extension);
|
||||
|
@ -254,9 +254,9 @@ class Driver {
|
||||
assert.ok(!dataTab, 'Found element that should not be present');
|
||||
}
|
||||
|
||||
async isElementPresent(element) {
|
||||
async isElementPresent(rawLocator) {
|
||||
try {
|
||||
await this.findElement(element);
|
||||
await this.findElement(rawLocator);
|
||||
return true;
|
||||
} catch (err) {
|
||||
return false;
|
||||
|
@ -3538,10 +3538,10 @@
|
||||
semver "^7.3.7"
|
||||
ses "^0.15.17"
|
||||
|
||||
"@metamask/test-dapp@^5.2.0":
|
||||
version "5.2.0"
|
||||
resolved "https://registry.yarnpkg.com/@metamask/test-dapp/-/test-dapp-5.2.0.tgz#ecae2525e7b4d5ef42b7f478b33e3a25152789f8"
|
||||
integrity sha512-/1nUFm6kzYB0xigrLHc+yzkunnrUoqfnsiLs7eUD+Qfl2Qn5G6C9tIj9cgAx72lWVtqoo2vBTP+55ZW8lDroYw==
|
||||
"@metamask/test-dapp@^5.2.1":
|
||||
version "5.2.1"
|
||||
resolved "https://registry.yarnpkg.com/@metamask/test-dapp/-/test-dapp-5.2.1.tgz#a7591393eec6d15f5e4bddee567018444db372ff"
|
||||
integrity sha512-p9Jt31RDAyVfzbNrPL3pFsYgFuren+saxSbeMlytU2LyKXkMIvxdpEYmyqWIvCoZvdBAc9LH/arXbeSSXJ+aMA==
|
||||
|
||||
"@metamask/types@^1.1.0":
|
||||
version "1.1.0"
|
||||
|
Loading…
Reference in New Issue
Block a user