jws-frontend/tests/03-Admin-ManageCustomer/JWS_MC_002_CreateNaturalperosonfail.spec.ts
2024-09-26 11:05:54 +07:00

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');
// });