const { strict: assert } = require('assert'); const { convertToHexValue, withFixtures } = require('../helpers'); describe('Phishing Detection', function () { async function mockPhishingDetection(mockServer) { await mockServer .forGet( 'https://cdn.jsdelivr.net/gh/MetaMask/eth-phishing-detect@master/src/config.json', ) .thenCallback(() => { return { headers: { 'Access-Control-Allow-Origin': '*' }, statusCode: 200, json: { version: 2, tolerance: 2, fuzzylist: [], whitelist: [], blacklist: ['example.com'], }, }; }); } const ganacheOptions = { accounts: [ { secretKey: '0x7C9529A67102755B7E6102D6D950AC5D5863C98713805CEC576B945B15B71EAC', balance: convertToHexValue(25000000000000000000), }, ], }; it('should display the MetaMask Phishing Detection page', async function () { await withFixtures( { fixtures: 'imported-account', ganacheOptions, title: this.test.title, testSpecificMock: mockPhishingDetection, }, async ({ driver }) => { await driver.navigate(); await driver.fill('#password', 'correct horse battery staple'); await driver.press('#password', driver.Key.ENTER); await driver.navigate(); await driver.openNewPage('http://example.com'); await driver.waitForSelector({ text: 'continuing at your own risk' }); const header = await driver.findElement('h1'); assert.equal(await header.getText(), 'MetaMask Phishing Detection'); }, ); }); });