283 lines
11 KiB
TypeScript
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('/');
|
|
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');
|
|
});
|