127 lines
4.5 KiB
TypeScript
127 lines
4.5 KiB
TypeScript
import { test, expect, Page } from '@playwright/test';
|
|
import { strictEqual } from 'assert';
|
|
import { Console, error, log } from 'console';
|
|
|
|
let page: Page;
|
|
let isLoginSuccessful = false;
|
|
|
|
test.beforeAll(async ({ browser }) => {
|
|
page = await browser.newPage();
|
|
});
|
|
|
|
test.afterAll(async () => {
|
|
if (page !== undefined) {
|
|
await page.close();
|
|
}
|
|
});
|
|
|
|
async function login(page) {
|
|
try {
|
|
// Login
|
|
await page.goto('/');
|
|
await expect(page).toHaveTitle(/^Sign in to /);
|
|
await page.fill("input[name='username']", 'admin');
|
|
await page.fill("input[name='password']", '1234');
|
|
await page.click('id=kc-login');
|
|
await page.waitForTimeout(2000);
|
|
// await page.click('id=acceptBtn');
|
|
|
|
// เข้าสู่เมนูสาขา
|
|
await page.click('id=menu.manage');
|
|
await page.waitForSelector('id=sub-menu-branch');
|
|
await page.click('id=sub-menu-branch');
|
|
await page.waitForTimeout(2000);
|
|
|
|
isLoginSuccessful = true;
|
|
console.log('ระบบทำการ Login');
|
|
} catch (error) {
|
|
console.error('เกิดข้อผิดพลาดในการ Login', error);
|
|
isLoginSuccessful = false;
|
|
}
|
|
}
|
|
|
|
test('Login', async () => {
|
|
await login(page);
|
|
});
|
|
|
|
test('ปิดการใช้งานสำนักงานใหญ่', async () => {
|
|
if (!isLoginSuccessful) {
|
|
await login(page);
|
|
}
|
|
|
|
try {
|
|
await page.click('id=btn-kebab-action-บริษัท คาโมมายด์ จำกัด');
|
|
|
|
await page.click('id=btn-kebab-status-บริษัท คาโมมายด์ จำกัด', {
|
|
force: true,
|
|
});
|
|
await page.click('id=btn-ok-dialog');
|
|
console.log('เปลี่ยนสถานะสำเร็จ');
|
|
await page.reload();
|
|
|
|
// รอ Update
|
|
await page.waitForTimeout(2000);
|
|
console.log('สถานะถูกเปลี่ยนแล้ว');
|
|
|
|
// ตรวจสอบสีของแถวหลังจากทำการเปลี่ยนสถานะ
|
|
const rowLocator = page.locator(
|
|
"//td[contains(.,'บริษัท คาโมมายด์ จำกัดCMM00000')]",
|
|
);
|
|
const backgroundColor = await rowLocator.evaluate(
|
|
(el) => window.getComputedStyle(el).backgroundColor,
|
|
);
|
|
|
|
// กำหนดสีหลัเปลี่ยนสถานะการใช้งาน
|
|
const expectedColor = 'rgb(249, 250, 252)';
|
|
|
|
// ตรวจสอบสีที่เปลี่ยนไป
|
|
expect(backgroundColor.trim()).toBe(expectedColor);
|
|
console.log('สีของแถวถูกเปลี่ยนเป็นสีเทาอ่อน');
|
|
} catch (error) {
|
|
console.error('เกิดข้อผิดพลาดในการทดสอบ');
|
|
isLoginSuccessful = false;
|
|
throw error;
|
|
}
|
|
await page.waitForTimeout(2000);
|
|
});
|
|
|
|
test('เปิดการใช้งานสำนักงานใหญ่', async () => {
|
|
if (!isLoginSuccessful) {
|
|
await login(page);
|
|
}
|
|
|
|
try {
|
|
await page.click('id=btn-kebab-action-บริษัท คาโมมายด์ จำกัด');
|
|
|
|
await page.click('id=btn-kebab-status-บริษัท คาโมมายด์ จำกัด', {
|
|
force: true,
|
|
});
|
|
await page.click('id=btn-ok-dialog');
|
|
console.log('เปลี่ยนสถานะสำเร็จ');
|
|
await page.reload();
|
|
|
|
// รอ Update
|
|
await page.waitForTimeout(2000);
|
|
console.log('สถานะถูกเปลี่ยนแล้ว');
|
|
|
|
// ตรวจสอบสีของแถวหลังจากทำการเปลี่ยนสถานะ
|
|
const rowLocator = page.locator(
|
|
"//td[contains(.,'บริษัท คาโมมายด์ จำกัดCMM00000')]",
|
|
);
|
|
const backgroundColor = await rowLocator.evaluate(
|
|
(el) => window.getComputedStyle(el).backgroundColor,
|
|
);
|
|
|
|
// กำหนดสีหลัเปลี่ยนสถานะการใช้งาน
|
|
const expectedColor = 'rgba(0, 0, 0, 0)';
|
|
|
|
// ตรวจสอบสีที่เปลี่ยนไป
|
|
expect(backgroundColor.trim()).toBe(expectedColor);
|
|
console.log('สีของแถวถูกเปลี่ยนเป็นของสถานะการใช้งาน');
|
|
} catch (error) {
|
|
console.error('เกิดข้อผิดพลาดในการทดสอบ');
|
|
isLoginSuccessful = false;
|
|
throw error;
|
|
}
|
|
await page.waitForTimeout(2000);
|
|
});
|