Web Dev Solutions

Catalin Mititiuc

const { ProvideResponseParameters } = require('selenium-webdriver/bidi/provideResponseParameters'); const { Builder, By, until } = require('selenium-webdriver'), chrome = require('selenium-webdriver/chrome.js'), getNetworkInstance = require('selenium-webdriver/bidi/network.js'), { AddInterceptParameters } = require('selenium-webdriver/bidi/addInterceptParameters'), { InterceptPhase } = require('selenium-webdriver/bidi/interceptPhase'), { expect, it } = require('@jest/globals'), chromeOptions = new chrome.Options(), { mkdir, writeFile, symlink, unlink } = require('node:fs/promises'), path = require('path'), { tmpdir } = require('os'), puppeteer = require('puppeteer'); const { HttpResponse } = require('selenium-webdriver/devtools/networkinterceptor'); const fs = require('node:fs/promises'); const DIR = path.resolve(tmpdir(), 'test-dir'); chromeOptions.addArguments('--headless', '--disable-gpu', '--no-sandbox'); chromeOptions.enableBidi(); let driver; // beforeAll(async () => { // await symlink('../../../test/map1.svg', 'public/assets/images/test_map.svg'); // }); beforeEach(async () => { driver = new Builder().forBrowser('chrome').setChromeOptions(chromeOptions).build(); // console.log('manage', await driver.manage()); }); it('loads the page', async () => { expect(await driver.getTitle()).toEqual('Infantry Combat Solo Basic'); // console.log('window', window); // takeScreenshot(driver); // var start = new Date().getTime(); // await driver.executeAsyncScript( // 'window.setTimeout(arguments[arguments.length - 1], 500);'). // then(function() { // console.log( // 'Elapsed time: ' + (new Date().getTime() - start) + ' ms'); // }); // await driver.executeScript(`return __dirname`).then(function (e) { // console.log('e', e); // }); // console.log('client', await driver.executeScript(`return document.querySelect('object');`)); }); it.only('selects an off-board soldier', async () => { const connection = await driver.createCDPConnection('page') const url = 'http://localhost:3005/assets/images/scenario-side_show.svg'; const httpResponse = new HttpResponse(url); httpResponse.body = await fs.readFile('./test/integration/fixtures/scenario-test.svg', 'utf8'); httpResponse.addHeaders('Content-Type', 'image/svg+xml'); await driver.onIntercept(connection, httpResponse, async function () { console.log('intercepted'); }); await driver.get('http://localhost:3005'); await driver.wait(until.elementLocated(By.css('#dice')), 1000); await driver.switchTo().frame(await driver.findElement(By.css('object'))); const selector = '.counter[data-allegiance="attacker"][data-number="1"]', svg = await driver.findElement(By.css('svg')), counter = await driver.findElement(By.css(selector), svg); await counter.click(); expect(await counter.getAttribute('class')).toEqual(expect.stringContaining('selected')); await driver.switchTo().defaultContent(); expect(await driver.findElement(By.css('.soldier-record')).getAttribute('class')).toEqual(expect.stringContaining('selected')); await driver.switchTo().frame(await driver.findElement(By.css('object'))); await counter.click(); expect(await counter.getAttribute('class')).toEqual(expect.not.stringContaining('selected')); await driver.switchTo().defaultContent(); expect(await driver.findElement(By.css('.soldier-record')).getAttribute('class')).toEqual(expect.not.stringContaining('selected')); }); afterEach(async () => { await driver.quit(); }); // afterAll(async () => { // await unlink('public/assets/images/test_map.svg'); // }); async function takeScreenshot(driver) { const dir = './test/screenshots'; const fileName = path.relative(process.cwd(), __filename) + ' "' + expect.getState().currentTestName + `" ${new Date().toISOString()}.png`; const image = await driver.takeScreenshot(); await mkdir(dir, { recursive: true }); await writeFile(`${dir}/${fileName.replaceAll('/', '-')}`, image, 'base64'); }