331 lines
13 KiB
TypeScript
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);
|
|
});
|