mirror of
https://github.com/fluencelabs/fluence-js.git
synced 2025-04-30 12:02:14 +00:00
46 lines
1.4 KiB
TypeScript
46 lines
1.4 KiB
TypeScript
|
import puppeteer from 'puppeteer';
|
||
|
import { dirname, join } from 'path';
|
||
|
import { fileURLToPath } from 'url';
|
||
|
|
||
|
import { startCdn, startContentServer, stopServer } from '@test/test-utils';
|
||
|
|
||
|
const port = 3001;
|
||
|
const uri = `http://localhost:${port}/`;
|
||
|
const __dirname = dirname(fileURLToPath(import.meta.url));
|
||
|
const publicPath = join(__dirname, '../build/');
|
||
|
|
||
|
const test = async () => {
|
||
|
const cdn = await startCdn(8766);
|
||
|
const localServer = await startContentServer(port, publicPath);
|
||
|
|
||
|
console.log('starting puppeteer...');
|
||
|
const browser = await puppeteer.launch();
|
||
|
const page = await browser.newPage();
|
||
|
|
||
|
// uncomment to debug what's happening inside the browser
|
||
|
// page.on('console', (msg) => console.log('// from console: ', msg.text()));
|
||
|
|
||
|
console.log('going to the page in browser...');
|
||
|
await page.goto(uri);
|
||
|
|
||
|
console.log('clicking button...');
|
||
|
await page.click('#btn');
|
||
|
|
||
|
console.log('waiting for result to appear...');
|
||
|
const elem = await page.waitForSelector('#res');
|
||
|
|
||
|
console.log('getting the content of result div...');
|
||
|
const content = await elem?.evaluate((x) => x.textContent);
|
||
|
console.log('raw result: ', content);
|
||
|
|
||
|
await browser.close();
|
||
|
await stopServer(cdn);
|
||
|
await stopServer(localServer);
|
||
|
|
||
|
if (!content) {
|
||
|
throw new Error('smoke test failed!');
|
||
|
}
|
||
|
};
|
||
|
|
||
|
test().then(() => console.log('smoke tests succeed!'));
|