jws-frontend/tests/01-Manage/03-Admin-ManageCustomer/JWS_MC_016_CreateEmployee.spec.ts
2025-01-13 11:47:01 +07:00

331 lines
13 KiB
TypeScript

import { test, expect, Page } from '@playwright/test';
import { strictEqual } from 'assert';
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-customer');
await page.click('id=sub-menu-customer');
await page.waitForSelector('id=tab-employee');
await page.click('id=tab-employee');
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-add');
await page.waitForTimeout(2000);
// ส่วนข้อมูลพื้นฐาน
await page.click('id=form-employee-select-employer-branch');
await page.waitForSelector('id=form-employee-select-employer-branch_1');
await page.click('id=form-employee-select-employer-branch_1');
await page.fill('id=form-employee-input-nrc-no', '2822022820220');
// ส่วนข้้อมูลส่วนตัว
await page.click('id=form-employee-select-prefix-name');
await page.waitForSelector('id=form-employee-select-prefix-name_0');
await page.click('id=form-employee-select-prefix-name_0');
await page.fill(
"(//input[@id='form-employee-input-first-name'])[1]",
'กิตติศักดิ์',
);
await page.fill('id=form-employee-input-last-name', 'วิจิตรานนท์');
await page.fill('id=form-employee-input-first-name-en', 'Kittisak');
await page.fill('id=form-employee-input-last-name-en', 'Wijitranon');
// วันเดิิอนปีเกิด
await page.click('id=form-employee-input-birth-date');
await page.waitForSelector(
"(//button[@class='dp__btn dp__month_year_select'])[2]",
);
await page.click("(//button[@class='dp__btn dp__month_year_select'])[2]");
await page.click("//div[text()='1996']");
await page.click("(//button[@class='dp__btn dp__month_year_select'])[1]");
await page.click("//div[text()='พ.ค.']");
await page.click("//div[@id='1996-05-02']/div[1]");
// สัญชาติ
await page.click('id=form-employee-select-nationality');
await page.waitForSelector('id=form-employee-select-nationality_2');
await page.click('id=form-employee-select-nationality_2');
await page.click('id=btn-info-basic-save');
await page.waitForTimeout(2000);
// -------------------- Tab ข้อมูลหนังสือเดินทาง ------------------------------
await page.waitForSelector(
'id=dialog-tab-customerEmployee.fileType.passport',
{
state: 'visible',
},
);
await page.click('id=dialog-tab-customerEmployee.fileType.passport', {
force: true,
});
await page.fill(
"(//input[@id='drawer-info-employee-input-passport-no'])[2]",
'MM202228',
);
await page.click(
"(//input[@id='drawer-info-employee-select-passport-country'])[2]",
);
await page.waitForSelector(
'id=drawer-info-employee-select-passport-country_1',
);
await page.click('id=drawer-info-employee-select-passport-country_1');
// วันหมดอายุหนังสือเดือนทาง
await page.waitForTimeout(1000);
await page.click(
"(//input[@id='drawer-info-employee-date-picker-passport-expire'])[2]",
);
await page.click("(//button[@class='dp__btn dp__month_year_select'])[2]");
await page.click("//div[text()='2030']");
await page.click("(//button[@class='dp__btn dp__month_year_select'])[1]");
await page.click("//div[@data-test='ส.ค.']");
await page.click("//div[@id='2030-08-10']/div[1]");
await page.waitForSelector("(//button[@type='submit'])[2]");
await page.click("(//button[@type='submit'])[2]");
await page.waitForTimeout(2000);
// -------------------- Tab ข้อมูล Visa ------------------------------------
await page.waitForSelector(
'id=dialog-tab-customerEmployee.form.group.visa',
{
state: 'visible',
},
);
await page.click('id=dialog-tab-customerEmployee.form.group.visa', {
force: true,
});
// ใช้ได้ถึงวันที่
await page.click(
"(//input[@id='drawer-info-employee-date-picker-visa-expire'])[2]",
);
await page.click("(//button[@class='dp__btn dp__month_year_select'])[2]");
await page.click("//div[text()='2030']");
await page.click("(//button[@class='dp__btn dp__month_year_select'])[1]");
await page.click("//div[text()='ธ.ค.']");
await page.click("//div[@id='2030-12-04']/div[1]");
await page.click("(//button[@type='submit'])[2]");
await page.waitForTimeout(2000);
await page.click('id=btn-form-close');
await page.waitForTimeout(2000);
const employeeCheck = await page.locator(
"//tr[contains(.,'Kittisak Wijitranon') and contains (.,'บริษัท เอเชียเทค ซิสเต็มส์ จำกัด')]",
);
await expect(employeeCheck).toContainText('Kittisak Wijitranon');
await expect(employeeCheck).toContainText(
'บริษัท เอเชียเทค ซิสเต็มส์ จำกัด',
);
console.log('ระบบทำการตรวจสอบการจ้างลูกจ้างถูกต้อง');
} catch (error) {
console.error('เกิดข้อผิดพลาดในการทดสอบ', error);
isLoginSuccessful = false;
throw error;
}
await page.waitForTimeout(2000);
});
test('ทดสอบการสร้างลูกจ้างนรูปแบบใช้ที่อยู่แบบกำหนดเอง', async () => {
if (!isLoginSuccessful) {
await login(page);
}
try {
await page.reload();
await page.waitForSelector('id=tab-employee');
await page.click('id=tab-employee');
await page.waitForTimeout(1000);
await page.click('id=btn-add');
await page.waitForTimeout(2000);
// ส่วนข้อมูลพื้นฐาน
await page.click('id=form-employee-select-employer-branch');
await page.waitForSelector('id=form-employee-select-employer-branch_0');
await page.click('id=form-employee-select-employer-branch_0');
await page.fill('id=form-employee-input-nrc-no', '2822022820222');
// ส่วนข้้อมูลส่วนตัว
await page.click('id=form-employee-select-prefix-name');
await page.waitForSelector('id=form-employee-select-prefix-name_1');
await page.click('id=form-employee-select-prefix-name_1');
await page.fill(
"(//input[@id='form-employee-input-first-name'])[1]",
'วรัญญา',
);
await page.fill('id=form-employee-input-last-name', 'สุขเกษม');
await page.fill('id=form-employee-input-first-name-en', 'Waranya');
await page.fill('id=form-employee-input-last-name-en', 'Sukkasem');
// วันเดิิอนปีเกิด
await page.click('id=form-employee-input-birth-date');
await page.waitForSelector(
"(//button[@class='dp__btn dp__month_year_select'])[2]",
);
await page.click("(//button[@class='dp__btn dp__month_year_select'])[2]");
await page.click("//div[text()='1994']");
await page.click("(//button[@class='dp__btn dp__month_year_select'])[1]");
await page.click("//div[text()='เม.ย.']");
await page.click("//div[@id='1994-04-02']/div[1]");
// สัญชาติ
await page.click('id=form-employee-select-nationality');
await page.waitForSelector('id=form-employee-select-nationality_4');
await page.click('id=form-employee-select-nationality_4');
// ส่วนที่อยู่
await page.click('id=form-employee-custom');
await page.fill(
'id=form-employee-input-address-no',
'89/15 หมู่บ้านเพชรทวี',
);
await page.fill(
"(//input[@id='form-employee-input-soi'])[1]",
'สุขุมวิท 55 ',
);
await page.fill(
"(//input[@id='form-employee-input-street'])[1]",
'สุขุมวิท',
);
await page.click('id=form-employee-select-district');
(await page.waitForSelector('id=form-employee-select-district_13'))
.scrollIntoViewIfNeeded;
await page.click('id=form-employee-select-district_13');
await page.click('id=form-employee-select-sub-district');
await page.waitForSelector('id=form-employee-select-sub-district_1');
await page.click('id=form-employee-select-sub-district_1');
await page.fill(
'id=form-employee-input-address-en',
'89/15 Phetthawee Village',
);
await page.fill(
"(//input[@id='form-employee-input-soi'])[2]",
'Sukhumvit 55',
);
await page.fill(
"(//input[@id='form-employee-input-street'])[2]",
'Sukhumvit',
);
await page.waitForTimeout(2000);
await page.click("//button[@type='submit']");
await page.waitForTimeout(2000);
// -------------------- Tab ข้อมูลหนังสือเดินทาง ------------------------------
await page.waitForSelector(
'id=dialog-tab-customerEmployee.fileType.passport',
{
state: 'visible',
},
);
await page.click('id=dialog-tab-customerEmployee.fileType.passport', {
force: true,
});
await page.fill(
"(//input[@id='drawer-info-employee-input-passport-no'])[2]",
'VN220228',
);
await page.click(
"(//input[@id='drawer-info-employee-select-passport-country'])[2]",
);
await page.waitForSelector(
'id=drawer-info-employee-select-passport-country_4',
);
await page.click('id=drawer-info-employee-select-passport-country_4');
// วันหมดอายุหนังสือเดือนทาง
await page.waitForTimeout(1000);
await page.click(
"(//input[@id='drawer-info-employee-date-picker-passport-expire'])[2]",
);
await page.click("(//button[@class='dp__btn dp__month_year_select'])[2]");
await page.click("//div[text()='2032']");
await page.click("(//button[@class='dp__btn dp__month_year_select'])[1]");
await page.click("//div[@data-test='ส.ค.']");
await page.click("//div[@id='2032-08-10']/div[1]");
await page.waitForSelector("(//button[@type='submit'])[2]");
await page.click("(//button[@type='submit'])[2]");
await page.waitForTimeout(2000);
// -------------------- Tab ข้อมูล Visa ------------------------------------
await page.waitForSelector(
'id=dialog-tab-customerEmployee.form.group.visa',
{
state: 'visible',
},
);
await page.click('id=dialog-tab-customerEmployee.form.group.visa', {
force: true,
});
// ใช้ได้ถึงวันที่
await page.click(
"(//input[@id='drawer-info-employee-date-picker-visa-expire'])[2]",
);
await page.click("(//button[@class='dp__btn dp__month_year_select'])[2]");
await page.click("//div[text()='2032']");
await page.click("(//button[@class='dp__btn dp__month_year_select'])[1]");
await page.click("//div[text()='ธ.ค.']");
await page.click("//div[@id='2032-12-04']/div[1]");
await page.click("(//button[@type='submit'])[2]");
await page.waitForTimeout(2000);
await page.click('id=btn-form-close');
await page.waitForTimeout(2000);
const employeeCheck = await page.locator(
"//tr[contains(.,'Waranya Sukkasem') and contains (.,'1524428220420-00')]",
);
await expect(employeeCheck).toContainText('Waranya Sukkasem');
await expect(employeeCheck).toContainText('1524428220420-00');
console.log('ระบบทำการตรวจสอบการจ้างลูกจ้างถูกต้อง');
} catch (error) {
console.error('เกิดข้อผิดพลาดในการทดสอบ', error);
isLoginSuccessful = false;
throw error;
}
await page.waitForTimeout(2000);
});