115 lines
5.4 KiB
TypeScript
115 lines
5.4 KiB
TypeScript
![]() |
import { test, expect, type Page } from '@playwright/test';
|
|||
|
import https from 'https';
|
|||
|
|
|||
|
|
|||
|
/* Global starting test config */
|
|||
|
|
|||
|
let page: Page;
|
|||
|
|
|||
|
function httpsGet(url: string): Promise<void> {
|
|||
|
return new Promise((resolve, reject) => {
|
|||
|
https.get(url, {
|
|||
|
rejectUnauthorized: false // Ignore SSL certificate errors
|
|||
|
}, (res) => {
|
|||
|
if (res.statusCode === 200) {
|
|||
|
resolve();
|
|||
|
} else {
|
|||
|
reject(new Error(`Request failed with status code ${res.statusCode}`));
|
|||
|
}
|
|||
|
}).on('error', (error) => {
|
|||
|
reject(error);
|
|||
|
});
|
|||
|
});
|
|||
|
}
|
|||
|
async function waitForServer(url: string, timeout: number = 150000) {
|
|||
|
const start = Date.now();
|
|||
|
while (Date.now() - start < timeout) {
|
|||
|
try {
|
|||
|
await httpsGet(url);
|
|||
|
return true;
|
|||
|
} catch (error) {
|
|||
|
// Ignore errors and try again
|
|||
|
console.log (`Error fetching ${url}: ${error.message}`);
|
|||
|
}
|
|||
|
await new Promise((resolve) => setTimeout(resolve, 1000));
|
|||
|
}
|
|||
|
throw new Error(`Server at ${url} did not start within ${timeout} ms`);
|
|||
|
}
|
|||
|
test.beforeAll(async ({ browser }) => {
|
|||
|
console.log('Waiting for the server to start...');
|
|||
|
await new Promise((resolve) => setTimeout(resolve, 5000));
|
|||
|
const baseURL = 'https://localhost:3000';
|
|||
|
await waitForServer(baseURL);
|
|||
|
page = await browser.newPage();
|
|||
|
test.setTimeout(150000);
|
|||
|
await page.goto(baseURL);
|
|||
|
await expect(page).toHaveTitle(/Дискурс/);
|
|||
|
await page.getByRole('link', { name: 'Войти' }).click();
|
|||
|
console.log('Localhost server started successfully!');
|
|||
|
await page.close();
|
|||
|
});
|
|||
|
test.afterAll(async () => {
|
|||
|
await page.close();
|
|||
|
});
|
|||
|
|
|||
|
|
|||
|
/* TESTS section */
|
|||
|
|
|||
|
/* Random Generator */
|
|||
|
function generateRandomString(length = 10) {
|
|||
|
let result = '';
|
|||
|
const characters = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';
|
|||
|
const charactersLength = characters.length;
|
|||
|
for (let i = 0; i < length; i++) {
|
|||
|
result += characters.charAt(Math.floor(Math.random() * charactersLength));
|
|||
|
}
|
|||
|
return result;
|
|||
|
}
|
|||
|
|
|||
|
test.beforeEach(async ({ page }) => {
|
|||
|
await page.goto(`/`);
|
|||
|
/* test.setTimeout(80000); */
|
|||
|
await page.getByRole('link', { name: 'Войти' }).click();
|
|||
|
await page.getByPlaceholder('Почта').click();
|
|||
|
await page.getByPlaceholder('Почта').fill('guests@discours.io');
|
|||
|
await page.getByPlaceholder('Пароль').click();
|
|||
|
await page.getByPlaceholder('Пароль').fill('Gue$tP@ss');
|
|||
|
await page.getByRole('button', { name: 'Войти' }).click();
|
|||
|
});
|
|||
|
|
|||
|
test.describe('Topic Actions', () => {
|
|||
|
test('Follow topic', async ({ page }) => {
|
|||
|
await page.getByRole('link', { name: 'темы', exact: true }).click();
|
|||
|
await page.getByRole('link', { name: 'Общество Статьи о политике, экономике и обществе, об актуальных событиях, людях, мнениях. Тексты про историю и современность, про то, что происходит в России и мире' }).click();
|
|||
|
await page.getByRole('button', { name: 'Подписаться на тему' }).click();
|
|||
|
await expect(page.getByRole('button', { name: 'Отписаться от темы' })).toBeVisible();
|
|||
|
});
|
|||
|
test('Unfollow topic', async ({ page }) => {
|
|||
|
await page.getByRole('link', { name: 'темы', exact: true }).click();
|
|||
|
await page.getByRole('link', { name: 'Общество Статьи о политике, экономике и обществе, об актуальных событиях, людях, мнениях. Тексты про историю и современность, про то, что происходит в России и мире' }).click();
|
|||
|
await page.getByRole('button', { name: 'Отписаться от темы' }).click();
|
|||
|
await expect(page.getByRole('button', { name: 'Подписаться на тему' })).toBeVisible();
|
|||
|
});
|
|||
|
test('Add comment to topic', async ({ page }) => {
|
|||
|
const randomString = generateRandomString();
|
|||
|
const currentDate = new Date();
|
|||
|
await page.getByRole('button', { name: 'Т.Р' }).click();
|
|||
|
await page.getByRole('link', { name: 'Профиль' }).click();
|
|||
|
await page.getByRole('link', { name: 'Тестируем функционал' }).first().click();
|
|||
|
await page.locator('.tiptap').click();
|
|||
|
await page.locator('.tiptap').fill('Проверка Комментариев: ' + randomString + ' ' + currentDate);
|
|||
|
await page.getByRole('button', { name: 'Отправить' }).click();
|
|||
|
await expect(page.getByText('Проверка Комментариев: ' + randomString + ' ' + currentDate)).toBeVisible();
|
|||
|
});
|
|||
|
test('Edit comment to topic', async ({ page }) => {
|
|||
|
await page.getByRole('button', { name: 'Т.Р' }).click();
|
|||
|
await page.getByRole('link', { name: 'Комментарии' }).click();
|
|||
|
await page.locator('[id^="comment_"]').filter({ hasText: 'Проверка Комментариев' }).first().hover();
|
|||
|
await page.getByRole('button', { name: 'Редактировать', exact: true }).first().click();
|
|||
|
const randomString = generateRandomString();
|
|||
|
const currentDate = new Date();
|
|||
|
await page.locator('.tiptap').fill('Редактируемый Комментарий: ' + randomString + ' ' + currentDate);
|
|||
|
await page.getByRole('button', { name: 'Сохранить' }).click();
|
|||
|
await expect(page.getByText('Редактируемый Комментарий: ' + randomString + ' ' + currentDate)).toBeVisible();
|
|||
|
});
|
|||
|
});
|