mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-11-28 23:06:37 +01:00
5bc0ba7f3a
* moved import nft to modal * fixed modal state * updated port-nft-popup * updated onChange for import nft modal * updated tests * updated tests * updated tests * added story and updated spec file * updated spec file * updated spec file * updated spec file for import-nft * added focus to form field * added autofocus to tokenId
106 lines
3.8 KiB
JavaScript
106 lines
3.8 KiB
JavaScript
const { strict: assert } = require('assert');
|
||
const { convertToHexValue, withFixtures } = require('../helpers');
|
||
const { SMART_CONTRACTS } = require('../seeder/smart-contracts');
|
||
const FixtureBuilder = require('../fixture-builder');
|
||
|
||
describe('Import NFT', function () {
|
||
const smartContract = SMART_CONTRACTS.NFTS;
|
||
const ganacheOptions = {
|
||
accounts: [
|
||
{
|
||
secretKey:
|
||
'0x7C9529A67102755B7E6102D6D950AC5D5863C98713805CEC576B945B15B71EAC',
|
||
balance: convertToHexValue(25000000000000000000),
|
||
},
|
||
],
|
||
};
|
||
|
||
it('should be able to import an NFT that user owns', async function () {
|
||
await withFixtures(
|
||
{
|
||
dapp: true,
|
||
fixtures: new FixtureBuilder()
|
||
.withPermissionControllerConnectedToTestDapp()
|
||
.build(),
|
||
ganacheOptions,
|
||
smartContract,
|
||
title: this.test.title,
|
||
},
|
||
async ({ driver, _, contractRegistry }) => {
|
||
const contractAddress =
|
||
contractRegistry.getContractAddress(smartContract);
|
||
await driver.navigate();
|
||
await driver.fill('#password', 'correct horse battery staple');
|
||
await driver.press('#password', driver.Key.ENTER);
|
||
|
||
// After login, go to NFTs tab, open the import NFT form
|
||
await driver.clickElement('[data-testid="home__nfts-tab"]');
|
||
await driver.clickElement({ text: 'Import NFT', tag: 'button' });
|
||
|
||
// Enter a valid NFT that belongs to user and check success message appears
|
||
await driver.fill('#address', contractAddress);
|
||
await driver.fill('#token-id', '1');
|
||
await driver.clickElement(
|
||
'[data-testid="import-nfts-modal-import-button"]',
|
||
);
|
||
|
||
const newNftNotification = await driver.findElement({
|
||
text: 'NFT was successfully added!',
|
||
tag: 'h6',
|
||
});
|
||
assert.equal(await newNftNotification.isDisplayed(), true);
|
||
|
||
// Check the imported NFT and its image are displayed in the NFT tab
|
||
const importedNft = await driver.waitForSelector({
|
||
css: 'h5',
|
||
text: 'TestDappNFTs',
|
||
});
|
||
const importedNftImage = await driver.findElement(
|
||
'.nft-item__item-image',
|
||
);
|
||
assert.equal(await importedNft.isDisplayed(), true);
|
||
assert.equal(await importedNftImage.isDisplayed(), true);
|
||
},
|
||
);
|
||
});
|
||
|
||
it('should not be able to import an NFT that does not belong to user', async function () {
|
||
await withFixtures(
|
||
{
|
||
dapp: true,
|
||
fixtures: new FixtureBuilder()
|
||
.withPermissionControllerConnectedToTestDapp()
|
||
.build(),
|
||
ganacheOptions,
|
||
smartContract,
|
||
title: this.test.title,
|
||
},
|
||
async ({ driver, _, contractRegistry }) => {
|
||
const contractAddress =
|
||
contractRegistry.getContractAddress(smartContract);
|
||
await driver.navigate();
|
||
await driver.fill('#password', 'correct horse battery staple');
|
||
await driver.press('#password', driver.Key.ENTER);
|
||
|
||
// After login, go to NFTs tab, open the import NFT form
|
||
await driver.clickElement('[data-testid="home__nfts-tab"]');
|
||
await driver.clickElement({ text: 'Import NFT', tag: 'button' });
|
||
|
||
// Enter an NFT that not belongs to user with a valid address and an invalid token id
|
||
await driver.fill('#address', contractAddress);
|
||
await driver.fill('#token-id', '2');
|
||
await driver.clickElement(
|
||
'[data-testid="import-nfts-modal-import-button"]',
|
||
);
|
||
|
||
// Check error message appears
|
||
const invalidNftNotification = await driver.findElement({
|
||
text: 'NFT can’t be added as the ownership details do not match. Make sure you have entered correct information.',
|
||
tag: 'p',
|
||
});
|
||
assert.equal(await invalidNftNotification.isDisplayed(), true);
|
||
},
|
||
);
|
||
});
|
||
});
|