389 lines
19 KiB
TypeScript
389 lines
19 KiB
TypeScript
import { test, expect, Page } from '@playwright/test';
|
|
import { strictEqual } from 'assert';
|
|
import { formToJSON } from 'axios';
|
|
import { exec } from 'child_process';
|
|
import { ToastHeader } from 'react-bootstrap';
|
|
import { toHandlerKey } from 'vue';
|
|
|
|
let page: Page;
|
|
|
|
test.beforeAll(async ({ browser }) => {
|
|
page = await browser.newPage();
|
|
});
|
|
|
|
test.afterAll(async () => {
|
|
if (page !== undefined) {
|
|
await page.close();
|
|
}
|
|
});
|
|
|
|
test('Login', async () => {
|
|
// 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');
|
|
});
|
|
|
|
test('ทดสอบการสร้างนายจ้างบุคคลธรรมดาในกรณีที่ไม่กรอกช้อมูล', async () => {
|
|
await page.click('id=menu-icon-customer-management');
|
|
try {
|
|
await page.click('id=btn-add');
|
|
await page.click('id=add-customer-natural-person');
|
|
await page.click("//button[@type='submit']");
|
|
|
|
// กำหนดค่าเพื่อตรวจสอบหลังเกิดการ Validation
|
|
const citizenNoError = await page.locator(
|
|
"(//div[@class='q-field__messages col'])[1]",
|
|
);
|
|
const firstNameThError = await page.locator(
|
|
"(//div[@class='q-field__messages col'])[2]",
|
|
);
|
|
const lastNameThError = await page.locator(
|
|
"(//div[@class='q-field__messages col'])[3]",
|
|
);
|
|
const firstNameEngError = await page.locator(
|
|
"(//div[@class='q-field__messages col'])[4]",
|
|
);
|
|
const lastNameEngError = await page.locator(
|
|
"(//div[@class='q-field__messages col'])[5]",
|
|
);
|
|
const brithDateError = await page.locator(
|
|
"(//div[@class='q-field__messages col'])[6]",
|
|
);
|
|
|
|
// ตรวจสอบการเกิด Validation
|
|
expect(citizenNoError).toHaveText('จำเป็นต้องกรอกข้อมูลนี้');
|
|
expect(firstNameThError).toHaveText('จำเป็นต้องกรอกข้อมูลนี้');
|
|
expect(lastNameThError).toHaveText('จำเป็นต้องกรอกข้อมูลนี้');
|
|
expect(firstNameEngError).toHaveText('จำเป็นต้องกรอกข้อมูลนี้');
|
|
expect(lastNameEngError).toHaveText('จำเป็นต้องกรอกข้อมูลนี้');
|
|
expect(brithDateError).toHaveText('โปรดเลือกวันเดือนปีเกิด');
|
|
|
|
console.log('ตรวจสอบการแจ้งเตือนทั้งหมดถูกต้อง');
|
|
} catch (error) {
|
|
console.error('เกิดข้อผิดพลาดในการทดสอบ', error);
|
|
throw error;
|
|
}
|
|
await page.waitForTimeout(2000);
|
|
await page.click('id=btn-form-close');
|
|
});
|
|
|
|
test('ทดสอบการสร้างนายจ้างบุคคลธรรมดาในกรณีที่กรอกข้อมูลเฉพาะส่วนเกี่ยวกับ', async () => {
|
|
try {
|
|
await page.click('id=btn-add');
|
|
await page.click('id=add-customer-natural-person');
|
|
await page.fill('id=input-legal-person-no', '1222202282262');
|
|
await page.click('id=form-select-prefix-name');
|
|
await page.waitForSelector('id=form-select-prefix-name_0');
|
|
await page.click('id=form-select-prefix-name_0');
|
|
await page.fill("(//input[@id='form-input-first-name'])[1]", 'มานะ');
|
|
await page.fill("(//input[@id='form-input-last-name'])[1]", 'แมน');
|
|
await page.fill("(//input[@id='form-input-first-name'])[3]", 'Mana');
|
|
await page.fill("(//input[@id='form-input-last-name'])[2]", 'Man');
|
|
await page.click('id=form-input-birth-date');
|
|
await page.waitForSelector("//div[@id='2024-09-18']/div[1]");
|
|
await page.click("//div[@id='2024-09-18']/div[1]");
|
|
await page.click("//button[@type='submit']");
|
|
|
|
// รอการเกิด Dialog
|
|
const textPopupError = await page.locator(
|
|
"//span[normalize-space(text())='กรอกข้อมูลไม่ครบ']",
|
|
);
|
|
|
|
await expect(textPopupError).toHaveText('กรอกข้อมูลไม่ครบ');
|
|
console.log('ตรวจสอบการแจ้งเตือน Pop-up สำเร็จ');
|
|
} catch (error) {
|
|
console.error('เกิดข้อผิดพลาดในการทดสอบ', error);
|
|
throw error;
|
|
}
|
|
await page.waitForSelector('id=btn-ok-dialog');
|
|
await page.click('id=btn-ok-dialog');
|
|
|
|
await page.waitForTimeout(2000);
|
|
await page.click('id=btn-form-close');
|
|
});
|
|
|
|
test('ทดสอบการสร้างนายจ้างบุคคลธรรมดาในกรณีที่ไม่ได้กรอกข้อมูลส่วนข้อมูลธุรกิจ', async () => {
|
|
try {
|
|
await page.click('id=btn-add');
|
|
await page.click('id=add-customer-natural-person');
|
|
await page.click("(//div[@aria-selected='false'])[2]");
|
|
await page.click("//button[@type='submit']");
|
|
|
|
// กำหนดค่าเพื่อตรวจสอบการแจ้งเตือน
|
|
const businessTypeError = await page.locator(
|
|
"(//div[@class='q-field__messages col']//div)[1]",
|
|
);
|
|
const businessTypeEngError = await page.locator(
|
|
"(//div[@class='q-field__messages col']//div)[2]",
|
|
);
|
|
const jobPositionError = await page.locator(
|
|
"(//div[@class='q-field__messages col']//div)[3]",
|
|
);
|
|
const jobPositionEnError = await page.locator(
|
|
"(//div[@class='q-field__messages col']//div)[4]",
|
|
);
|
|
|
|
// ตรวจสอบการแจ้งเตือน
|
|
expect(businessTypeError).toHaveText('จำเป็นต้องกรอกข้อมูลนี้');
|
|
expect(businessTypeEngError).toHaveText('จำเป็นต้องกรอกข้อมูลนี้');
|
|
expect(jobPositionError).toHaveText('จำเป็นต้องกรอกข้อมูลนี้');
|
|
expect(jobPositionEnError).toHaveText('จำเป็นต้องกรอกข้อมูลนี้');
|
|
console.log('ตรวจสอบการแจ้งเตือนสำเร็จ');
|
|
} catch (error) {
|
|
console.error('เกิดข้อผิดพลาดในการทดสอบ', error);
|
|
}
|
|
await page.waitForTimeout(2000);
|
|
await page.click('id=btn-form-close');
|
|
});
|
|
|
|
test('ทดสอบการสร้างนายจ้างบุคคลธรรมดาในกรณีที่กรอกข้อมูลเฉพาะส่วนข้อมูลธุรกิจ', async () => {
|
|
try {
|
|
await page.click('id=btn-add');
|
|
await page.click('id=add-customer-natural-person');
|
|
await page.click("(//div[@aria-selected='false'])[2]");
|
|
await page.click('id=form-select-business-type');
|
|
await page.waitForSelector('id=form-select-business-type_1');
|
|
await page.click('id=form-select-business-type_1');
|
|
await page.click('id=form-select-job-position');
|
|
await page.waitForSelector('id=form-select-job-position_1');
|
|
await page.click('id=form-select-job-position_1');
|
|
await page.fill('id=form-input-job-description', 'รายละเอียด');
|
|
await page.fill("(//input[@id='form-input-pay-rate'])[1]", 'วันจ่ายเงิน');
|
|
await page.fill("(//input[@id='form-input-pay-rate'])[2]", 'Pay Day');
|
|
await page.fill("(//input[@id='form-input-pay-rate'])[3]", '2000');
|
|
await page.fill("//input[@aria-label='อัตราค่าจ้าง/วัน (Text)']", '2000');
|
|
await page.click("//button[@type='submit']");
|
|
|
|
// กำหนดค่าการแจ้งเตือน
|
|
const titleError = await page.locator(
|
|
"//span[normalize-space(text())='กรอกข้อมูลไม่ครบ']",
|
|
);
|
|
|
|
expect(titleError).toHaveText('กรอกข้อมูลไม่ครบ');
|
|
console.log('การแจ้งเตือนถูกต้อง');
|
|
} catch (error) {
|
|
console.error('เกิดข้อผิดพลาดในการทดสอบ', error);
|
|
}
|
|
await page.waitForSelector('id=btn-ok-dialog');
|
|
await page.click('id=btn-ok-dialog');
|
|
|
|
await page.waitForTimeout(2000);
|
|
await page.click('id=btn-form-close');
|
|
});
|
|
|
|
test('ทดสอบการสร้างนายจ้างบุคคลธรรมดาในกรณีที่ไม่กรอกข้อมูลส่วนที่อยู่นายจ้าง', async () => {
|
|
try {
|
|
await page.click('id=btn-add');
|
|
await page.click('id=add-customer-natural-person');
|
|
await page.click("(//div[@aria-selected='false'])[3]");
|
|
await page.click("//button[@type='submit']");
|
|
|
|
// กำหนดค่าการแจ้งเตือน
|
|
const addressIdentificationError = await page.locator(
|
|
"(//div[@class='q-field__messages col']//div)[1]",
|
|
);
|
|
const addressNoError = await page.locator(
|
|
"(//div[@class='q-field__messages col']//div)[2]",
|
|
);
|
|
const provinceError = await page.locator(
|
|
"(//div[@class='q-field__messages col']//div)[3]",
|
|
);
|
|
const districtError = await page.locator(
|
|
"(//div[@class='q-field__messages col']//div)[4]",
|
|
);
|
|
const subdistrictError = await page.locator(
|
|
"(//div[@class='q-field__messages col']//div)[5]",
|
|
);
|
|
const addressNoEngError = await page.locator(
|
|
"(//div[@class='q-field__messages col']//div)[6]",
|
|
);
|
|
|
|
// ตรวจสอบการแจ้งเตือน
|
|
expect(addressIdentificationError).toHaveText('จำเป็นต้องกรอกข้อมูลนี้');
|
|
expect(addressNoError).toHaveText('จำเป็นต้องกรอกข้อมูลนี้');
|
|
expect(provinceError).toHaveText('โปรดเลือกจังหวัด');
|
|
expect(districtError).toHaveText('โปรดเลือกอำเภอ');
|
|
expect(subdistrictError).toHaveText('โปรดเลือกตำบล');
|
|
expect(addressNoEngError).toHaveText('จำเป็นต้องกรอกข้อมูลนี้');
|
|
|
|
console.log('ตรวจสอบการแจ้งเตือนสำเร็จ');
|
|
} catch (error) {
|
|
console.error('เกิดข้อผิดพลาดในการทดสอบ', error);
|
|
throw error;
|
|
}
|
|
await page.waitForTimeout(2000);
|
|
await page.click('id=btn-form-close');
|
|
});
|
|
|
|
test('ทดสอบการสร้างนายจ้างบุคคลธรรมดาในกรณีที่กรอกข้อมูลเฉพาะส่วนที่อยู่นายจ้าง', async () => {
|
|
try {
|
|
await page.click('id=btn-add');
|
|
await page.click('id=add-customer-natural-person');
|
|
await page.click("(//div[@aria-selected='false'])[3]");
|
|
await page.fill("(//input[@id='form-input-address'])[1]", '22282202202');
|
|
await page.fill('id=form-input-address-no', '800');
|
|
await page.click('id=form-select-province');
|
|
await page.waitForSelector('id=form-select-province_4');
|
|
await page.click('id=form-select-province_4');
|
|
await page.click('id=form-select-district');
|
|
await page.waitForSelector('id=form-select-district_8');
|
|
await page.click('id=form-select-district_8');
|
|
await page.click('id=form-select-sub-district');
|
|
await page.waitForSelector('id=form-select-sub-district_7');
|
|
await page.click('id=form-select-sub-district_7');
|
|
await page.fill('id=form-input-address-en', '800');
|
|
await page.click("//button[@type='submit']");
|
|
|
|
// กำหนดค่าการแจ้งเตือน
|
|
const popupError = await page.locator(
|
|
"//span[normalize-space(text())='กรอกข้อมูลไม่ครบ']",
|
|
);
|
|
|
|
// ตรวจสอบการแจ้งเตือน
|
|
expect(popupError).toHaveText('กรอกข้อมูลไม่ครบ');
|
|
console.log('ตรวจสอบการแจ้งเตือนถูกต้อง');
|
|
} catch (error) {
|
|
console.error('เกิดข้อผิดพลาดในการทดสอบ', error);
|
|
throw error;
|
|
}
|
|
await page.waitForSelector('id=btn-ok-dialog');
|
|
await page.click('id=btn-ok-dialog');
|
|
|
|
await page.waitForTimeout(2000);
|
|
await page.click('id=btn-form-close');
|
|
});
|
|
|
|
test('ทดสอบการสร้างนายจ้างบุคคลธรรมดาในกรณีที่ไม่กรอกข้อมูลส่วนข้อมูลติดต่อ', async () => {
|
|
try {
|
|
await page.click('id=btn-add');
|
|
await page.click('id=add-customer-natural-person');
|
|
await page.click("(//div[@aria-selected='false'])[4]");
|
|
await page.click("//button[@type='submit']");
|
|
// กำหนดค่าการแจ้งเตือน
|
|
const popupError = await page.locator(
|
|
"//span[normalize-space(text())='กรอกข้อมูลไม่ครบ']",
|
|
);
|
|
|
|
// ตรวจสอบการแจ้งเตือน
|
|
expect(popupError).toHaveText('กรอกข้อมูลไม่ครบ');
|
|
console.log('ตรวจสอบการแจ้งเตือนถูกต้อง');
|
|
} catch (error) {
|
|
console.error('เกิดข้อผิดพลาดในการทดสอบ', error);
|
|
throw error;
|
|
}
|
|
await page.waitForSelector('id=btn-ok-dialog');
|
|
await page.click('id=btn-ok-dialog');
|
|
|
|
await page.waitForTimeout(2000);
|
|
await page.click('id=btn-form-close');
|
|
});
|
|
|
|
test('ทดสอบการสร้างนายจ้างบุคคลธรรมดาในกรณีที่กรอกข้อมูลเฉพาะส่วนข้อมูลติดต่อ', async () => {
|
|
try {
|
|
await page.click('id=btn-add');
|
|
await page.click('id=add-customer-natural-person');
|
|
await page.click("(//div[@aria-selected='false'])[4]");
|
|
await page.fill('id=form-input-contact-name', 'คุณอาท');
|
|
await page.fill('id=form-input-mail', 'art@mail.com');
|
|
await page.fill("(//input[@id='form-input-telephone'])[1]", '0882622426');
|
|
await page.fill("(//input[@id='form-input-telephone'])[2]", '022222002');
|
|
await page.click("//button[@type='submit']");
|
|
// กำหนดค่าการแจ้งเตือน
|
|
const popupError = await page.locator(
|
|
"//span[normalize-space(text())='กรอกข้อมูลไม่ครบ']",
|
|
);
|
|
|
|
// ตรวจสอบการแจ้งเตือน
|
|
expect(popupError).toHaveText('กรอกข้อมูลไม่ครบ');
|
|
console.log('ตรวจสอบการแจ้งเตือนถูกต้อง');
|
|
} catch (error) {
|
|
console.error('เกิดข้อผิดพลาดในการทดสอบ', error);
|
|
throw error;
|
|
}
|
|
await page.waitForSelector('id=btn-ok-dialog');
|
|
await page.click('id=btn-ok-dialog');
|
|
|
|
await page.waitForTimeout(2000);
|
|
await page.click('id=btn-form-close');
|
|
});
|
|
|
|
test('ทดสอบการสร้างนายจ้างบุคคลธรรมดาในกรณีที่กรอกรูปแบบอีเมลส่วนข้อมูลติดต่อไม่ถูกต้อง', async () => {
|
|
try {
|
|
await page.click('id=btn-add');
|
|
await page.click('id=add-customer-natural-person');
|
|
await page.click("(//div[@aria-selected='false'])[4]");
|
|
await page.fill('id=form-input-mail', 'art');
|
|
await page.click("//button[@type='submit']");
|
|
// กำหนดค่าการแจ้งเตือน
|
|
const emailFomatError = await page.locator(
|
|
"//div[normalize-space(text())='ข้อมูลไม่ถูกต้อง']",
|
|
);
|
|
|
|
// ตรวจสอบการแจ้งเตือน
|
|
expect(emailFomatError).toHaveText('ข้อมูลไม่ถูกต้อง');
|
|
console.log('ตรวจสอบการแจ้งเตือนรูปแบบอีเมลไม่ถูกต้อง : Success ');
|
|
} catch (error) {
|
|
console.error('เกิดข้อผิดพลาดในการทดสอบ', error);
|
|
throw error;
|
|
}
|
|
await page.waitForTimeout(2000);
|
|
await page.click('id=btn-form-close');
|
|
});
|
|
|
|
test('ทดสอบการสร้างนายจ้างบุคคลธรรมดาในกรณีที่ไม่อัปโหลดข้อมูลส่วนเอกสาร', async () => {
|
|
try {
|
|
await page.click('id=btn-add');
|
|
await page.click('id=add-customer-natural-person');
|
|
await page.click("(//div[@aria-selected='false'])[5]");
|
|
await page.click("//button[@type='submit']");
|
|
|
|
// กำหนดค่าแจ้งเตือน
|
|
const popupError = await page.locator(
|
|
"//span[normalize-space(text())='กรอกข้อมูลไม่ครบ']",
|
|
);
|
|
|
|
// ตรวจสอบการแจ้งเตือน
|
|
expect(popupError).toHaveText('กรอกข้อมูลไม่ครบ');
|
|
console.log('ตรวจสอบการแจ้งเตือนถูกต้อง');
|
|
} catch (error) {
|
|
console.error('เกิดข้อผิดพลาดในการทดสอบ', error);
|
|
throw error;
|
|
}
|
|
await page.waitForSelector('id=btn-ok-dialog');
|
|
await page.click('id=btn-ok-dialog');
|
|
|
|
await page.waitForTimeout(2000);
|
|
await page.click('id=btn-form-close');
|
|
});
|
|
|
|
// test('ทดสอบการสร้างนายจ้างบุคคลธรรมดาในกรณีที่อัปโหลดเอกสารเฉพาะส่วนเอกสาร', async () => {
|
|
// await page.click('id=menu-icon-customer-management');
|
|
// try {
|
|
// await page.click('id=btn-add');
|
|
// await page.click('id=add-customer-natural-person');
|
|
// await page.click("(//div[@aria-selected='false'])[5]");
|
|
// await page.click("//button[@type='submit']");
|
|
|
|
// // กำหนดค่าแจ้งเตือน
|
|
// const popupError = await page.locator(
|
|
// "//span[normalize-space(text())='กรอกข้อมูลไม่ครบ']",
|
|
// );
|
|
|
|
// // ตรวจสอบการแจ้งเตือน
|
|
// expect(popupError).toHaveText('กรอกข้อมูลไม่ครบ');
|
|
// console.log('ตรวจสอบการแจ้งเตือนถูกต้อง');
|
|
// } catch (error) {
|
|
// console.error('เกิดข้อผิดพลาดในการทดสอบ', error);
|
|
// throw error;
|
|
// }
|
|
// await page.waitForSelector('id=btn-ok-dialog');
|
|
// await page.click('id=btn-ok-dialog');
|
|
|
|
// await page.waitForTimeout(2000);
|
|
// await page.click('id=btn-form-close');
|
|
// });
|