jws-frontend/tests/01-Manage/02-Admin-PersonnelManagement/JWS_PM_004_EditPersonnel.spec.ts
2024-12-04 09:12:52 +07:00

283 lines
11 KiB
TypeScript

import { test, expect, Page } from '@playwright/test';
import { strictEqual } from 'assert';
import { exec } from 'child_process';
import { log } from 'console';
import { writeFileSync } from 'fs';
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('http://192.168.1.62:20101/');
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-personnel');
await page.click('id=sub-menu-personnel');
isLoginSuccessful = true;
console.log('ระบบทำการ Login');
} catch (error) {
console.error('เกิดข้อผิดพลาดในการทดสอบ', error);
isLoginSuccessful = false;
}
}
test('Login', async () => {
await login(page);
});
test('Edit Personnel - พนักงาน', async () => {
if (!isLoginSuccessful) {
await login(page);
}
try {
// เข้าสู่หน้าแก้ไขพนักงาน
await page.click("(//div[@role='tab'])[2]");
await page.waitForSelector('id=btn-kebab-action-employeem', {
state: 'visible',
});
await page.click('id=btn-kebab-action-employeem');
// ตรวจสอบการคลิกว่าได้มีการคลิกหรือการแสดงจริงหรือไม่
// const isElementVisible = await page.isVisible(
// 'id=btn-kebab-edit-employeem',
// );
// console.log('Element visibility:', isElementVisible);
await page.click('id=btn-kebab-edit-employeem');
// แก้ไขข้อมูล
await page.fill('id=drawer-info-personnel-input-first-name', 'อานน');
await page.fill('id=drawer-info-personnel-input-last-name', 'รักมาก');
await page.fill('id=drawer-info-personnel-input-first-name-en', 'Arnon');
await page.fill('id=drawer-info-personnel-input-last-name-en', 'Rakmak');
await page.click('id=btn-info-basic-save'); // คลิกปุ่มบันทึก
// ตรวจสอบหลังแก้ไขเสร็จ
await page.waitForSelector('id=btn-kebab-action-employeem', {
state: 'visible',
});
await page.click('id=btn-kebab-action-employeem');
await page.waitForSelector('id=btn-kebab-view-detail-employeem', {
state: 'visible',
});
await page.click('id=btn-kebab-view-detail-employeem');
// ตรวจสอบข้อมูลว่าทำการแก้ไขถูกหรือไม่
const detailEditFistName = await page.inputValue("//input[@value='อานน']");
const detailEditLastName = await page.inputValue(
"//input[@value='รักมาก']",
);
const detailEditFistNameEn = await page.inputValue(
"//input[@value='Arnon']",
);
const detailEditLastNameEn = await page.inputValue(
"//input[@value='Rakmak']",
);
await expect(detailEditFistName).toBe('อานน');
await expect(detailEditLastName).toBe('รักมาก');
await expect(detailEditFistNameEn).toBe('Arnon');
await expect(detailEditLastNameEn).toBe('Rakmak');
console.log('ตรวจสอบการแก้ไขข้อมูลพนักงานถูกต้อง');
} catch (error) {
console.log('เกิดข้อผิดพลาดในการทดสอบแก้ไขบุคลากร');
isLoginSuccessful = false;
throw error;
}
await page.waitForTimeout(4000);
await page.click('id=btn-info-close');
});
test('Edit Personnel - พนักงานส่งเอกสาร', async () => {
if (!isLoginSuccessful) {
await login(page);
}
try {
// เข้าสู่หน้าแก้ไขพนักงาน
await page.click("(//div[@role='tab'])[3]");
await page.click('id=btn-kebab-action-courierw');
await page.waitForSelector('id=btn-kebab-edit-courierw');
await page.click('id=btn-kebab-edit-courierw');
// แก้ไขข้อมูล
await page.fill('id=drawer-info-personnel-input-first-name', 'ลาดา');
await page.fill('id=drawer-info-personnel-input-last-name', 'มดา');
await page.fill('id=drawer-info-personnel-input-first-name-en', 'Lada');
await page.fill('id=drawer-info-personnel-input-last-name-en', 'Mada');
await page.click('id=btn-info-basic-save'); // คลิกปุ่มบันทึก
// ตรวจสอบหลังแก้ไขเสร็จ
await page.waitForSelector('id=btn-kebab-action-courierw', {
state: 'visible',
});
await page.click('id=btn-kebab-action-courierw');
await page.waitForSelector('id=btn-kebab-view-detail-courierw', {
state: 'visible',
});
await page.click('id=btn-kebab-view-detail-courierw');
// ตรวจสอบข้อมูลว่าทำการแก้ไขถูกหรือไม่
const detailEditFistName = await page.inputValue("//input[@value='ลาดา']");
const detailEditLastName = await page.inputValue("//input[@value='มดา']");
const detailEditFistNameEn = await page.inputValue(
"//input[@value='Lada']",
);
const detailEditLastNameEn = await page.inputValue(
"//input[@value='Mada']",
);
await expect(detailEditFistName).toBe('ลาดา');
await expect(detailEditLastName).toBe('มดา');
await expect(detailEditFistNameEn).toBe('Lada');
await expect(detailEditLastNameEn).toBe('Mada');
console.log('ตรวจสอบการแก้ไขข้อมูลพนักงานส่งเอกสารถูกต้อง');
} catch (error) {
console.log('เกิดข้อผิดพลาดในการทดสอบแก้ไขบุคลากร');
isLoginSuccessful = false;
throw error;
}
await page.waitForTimeout(4000);
await page.click('id=btn-info-close');
});
test('Edit Personnel - ตัวแทน', async () => {
if (!isLoginSuccessful) {
await login(page);
}
try {
// เข้าสู่หน้าแก้ไขพนักงาน
await page.click("(//div[@role='tab'])[4]");
await page.waitForTimeout(1000);
await page.click('id=btn-kebab-action-delegatem');
await page.waitForSelector('id=btn-kebab-edit-delegatem');
await page.click('id=btn-kebab-edit-delegatem');
// แก้ไขข้อมูล
await page.fill('id=drawer-info-personnel-input-first-name', 'ธนกร');
await page.fill('id=drawer-info-personnel-input-last-name', 'ลอยฟ้า');
await page.fill(
'id=drawer-info-personnel-input-first-name-en',
'Thanakorn',
);
await page.fill('id=drawer-info-personnel-input-last-name-en', 'Loifa');
await page.click('id=btn-info-basic-save'); // คลิกปุ่มบันทึก
// ตรวจสอบหลังแก้ไขเสร็จ
await page.waitForSelector('id=btn-kebab-action-delegatem', {
state: 'visible',
});
await page.click('id=btn-kebab-action-delegatem');
await page.waitForSelector('id=btn-kebab-view-detail-delegatem', {
state: 'visible',
});
await page.click('id=btn-kebab-view-detail-delegatem');
// ตรวจสอบข้อมูลว่าทำการแก้ไขถูกหรือไม่
const detailEditFistName = await page.inputValue("//input[@value='ธนกร']");
const detailEditLastName = await page.inputValue(
"//input[@value='ลอยฟ้า']",
);
const detailEditFistNameEn = await page.inputValue(
"//input[@value='Thanakorn']",
);
const detailEditLastNameEn = await page.inputValue(
"//input[@value='Loifa']",
);
await expect(detailEditFistName).toBe('ธนกร');
await expect(detailEditLastName).toBe('ลอยฟ้า');
await expect(detailEditFistNameEn).toBe('Thanakorn');
await expect(detailEditLastNameEn).toBe('Loifa');
console.log('ตรวจสอบการแก้ไขข้อมูลตัวแทนถูกต้อง');
} catch (error) {
console.log('เกิดข้อผิดพลาดในการทดสอบแก้ไขบุคลากร');
isLoginSuccessful = false;
throw error;
}
await page.waitForTimeout(4000);
await page.click('id=btn-info-close');
});
test('Edit Personnel - เอเจนซี่', async () => {
if (!isLoginSuccessful) {
await login(page);
}
try {
// เข้าสู่หน้าแก้ไขพนักงาน
await page.click("(//div[@role='tab'])[5]");
await page.waitForTimeout(2000);
await page.waitForSelector('id=btn-kebab-action-agencyw', {
state: 'visible',
});
await page.click('id=btn-kebab-action-agencyw');
await page.waitForSelector('id=btn-kebab-edit-agencyw');
await page.click('id=btn-kebab-edit-agencyw');
// แก้ไขข้อมูล
await page.fill('id=drawer-info-personnel-input-first-name', 'นิดา');
await page.fill('id=drawer-info-personnel-input-last-name', 'อามา');
await page.fill('id=drawer-info-personnel-input-first-name-en', 'Nida');
await page.fill('id=drawer-info-personnel-input-last-name-en', 'Arma');
await page.click('id=btn-info-basic-save'); // คลิกปุ่มบันทึก
// ตรวจสอบหลังแก้ไขเสร็จ
await page.waitForSelector('id=btn-kebab-action-agencyw', {
state: 'visible',
});
await page.click('id=btn-kebab-action-agencyw');
await page.waitForSelector('id=btn-kebab-view-detail-agencyw', {
state: 'visible',
});
await page.click('id=btn-kebab-view-detail-agencyw');
// ตรวจสอบข้อมูลว่าทำการแก้ไขถูกหรือไม่
const detailEditFistName = await page.inputValue("//input[@value='นิดา']");
const detailEditLastName = await page.inputValue("//input[@value='อามา']");
const detailEditFistNameEn = await page.inputValue(
"//input[@value='Nida']",
);
const detailEditLastNameEn = await page.inputValue(
"//input[@value='Arma']",
);
await expect(detailEditFistName).toBe('นิดา');
await expect(detailEditLastName).toBe('อามา');
await expect(detailEditFistNameEn).toBe('Nida');
await expect(detailEditLastNameEn).toBe('Arma');
console.log('ตรวจสอบการแก้ไขข้อมูลเอเจนซี่ถูกต้อง');
} catch (error) {
console.log('เกิดข้อผิดพลาดในการทดสอบแก้ไขบุคลากร');
isLoginSuccessful = false;
throw error;
}
await page.waitForTimeout(4000);
await page.click('id=btn-info-close');
});