import { test, expect, Page, errors } from '@playwright/test'; import { strictEqual } from 'assert'; import { log } from 'console'; import exp from 'constants'; import { errorMonitor } from 'stream'; 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-branch'); await page.click('id=sub-menu-branch'); // ถ้าขั้นตอนสำเร็จ isLoginSuccessful = true; } catch (error) { console.error('เกิดข้อผิดพลาดในการ Login', error); isLoginSuccessful = false; } } test('Login', async () => { await login(page); }); test('Create Branch Management - ไม่มีการกรอกข้อมูล', async () => { if (!isLoginSuccessful) { await login(page); } try { // เข้าสู่เมนูสาขา await page.click('id=menu.manage'); await page.waitForSelector('id=sub-menu-branch'); await page.click('id=sub-menu-branch'); await page.click('id=hq-add-btn'); await page.click('id=btn-info-basic-save'); const exceptError = [ { locator: "(//div[@class='q-field__messages col']//div)[1]", message: 'จำเป็นต้องกรอกข้อมูลนี้', }, { locator: "(//div[@class='q-field__messages col']//div)[2]", message: 'จำเป็นต้องกรอกข้อมูลนี้', }, { locator: "(//div[@class='q-field__messages col']//div)[3]", message: 'จำเป็นต้องกรอกข้อมูลนี้', }, { locator: "(//div[@class='q-field__messages col']//div)[4]", message: 'จำเป็นต้องกรอกข้อมูลนี้', }, { locator: "(//div[@class='q-field__messages col']//div)[5]", message: 'จำเป็นต้องกรอกข้อมูลนี้', }, { locator: "(//div[@class='q-field__messages col']//div)[6]", message: 'จำเป็นต้องกรอกข้อมูลนี้', }, { locator: "(//div[@class='q-field__messages col']//div)[7]", message: 'โปรดเลือกจังหวัด', }, { locator: "(//div[@class='q-field__messages col']//div)[8]", message: 'โปรดเลือกเขต/อำเภอ', }, { locator: "(//div[@class='q-field__messages col']//div)[9]", message: 'โปรดเลือกแขวง/ตำบล', }, { locator: "(//div[@class='q-field__messages col']//div)[10]", message: 'จำเป็นต้องกรอกข้อมูลนี้', }, ]; for (const error of exceptError) { const locator = page.locator(error.locator); await expect(locator).toHaveText(error.message); } console.log('ระบบตรวจสอบการแจ้งเตือนแล้ว'); } catch (error) { console.error('เกิดข้อผิดพลาดในการ Login', error); isLoginSuccessful = false; throw error; } await page.waitForTimeout(4000); await page.click('id=btn-form-close'); console.log('การตรวจสอบ Validation ถูกต้อง'); }); test('Create Branch Managenment - กรณีที่กรอกชื่อย่อที่ไม่ใช่ภาษาอังกฤษ', async () => { if (!isLoginSuccessful) { await login(page); } try { await page.reload(); await page.click('id=hq-add-btn'); await page.fill("(//input[@id='input-abbreviation'])[2]", 'ภาษาไทย'); const invalidDataabbreviationError = page.locator( // ตรวจสอบการแสดง Validation แจ้งเตือนชื่อย่อในกรณีที่ไม่ใช้ภาษาอังกฤษ "(//div[contains(@class,'q-field__bottom row')])[1]", ); await expect(invalidDataabbreviationError).toHaveText( 'ข้อมูลไม่ถูกต้อง โปรดใช้เฉพาะ _ ตัวอักษรภาษาอังกฤษและตัวเลขเท่านั้น', { timeout: 2000, }, ); console.log( 'ตรวจสอบการแสดง Vidation แจ้งเตือนในกรณีที่ไม่ใช่ภาษาอังกฤษถูกต้อง', ); } catch (error) { console.error('เกิดข้อผิดพลาดในการทดสอบ', error); isLoginSuccessful = false; throw error; } await page.waitForTimeout(4000); await page.click('id=btn-form-close'); }); test('Create Branch Management - กรอกเลขนิติบุคคลในกรณีที่กรอกไม่ครบจำนวน 13 หลัก', async () => { if (!isLoginSuccessful) { await login(page); } try { await page.reload(); await page.click('id=hq-add-btn'); await page.fill("(//input[@id='input-tax-no'])[2]", '123'); const taxNoError = page.locator( // ตรวจสอบการแสดง Validation แจ้งเตือนชื่อย่อในกรณีที่ไม่ใช้ภาษาอังกฤษ "(//div[@class='q-field__messages col']//div)[2]", ); await expect(taxNoError).toHaveText( 'ข้อมูลไม่ถูกต้อง กรุณากรอกให้ครบ 13 หลัก', { timeout: 2000, }, ); console.log( 'ตรวจสอบการแสดง Vidation แจ้งเตือนในกรณีที่กรอกทะเบียนนิติบุคคลเลขที่ไม่ครบ 13 หลัก', ); } catch (error) { console.error('เกิดข้อผิดพลาดในการทดสอบ', error); isLoginSuccessful = false; throw error; } await page.waitForTimeout(4000); await page.click('id=btn-form-close'); }); test('Create Branch Management - กรอกอีเมลในกรณีที่ไม่ตรงรูปแบบอีเมล', async () => { if (!isLoginSuccessful) { await login(page); } try { await page.reload(); await page.click('id=hq-add-btn'); await page.fill("(//input[@id='input-email'])[2]", '123'); const emailError = page.locator( // ตรวจสอบการแสดง Validation แจ้งเตือนในกรณีที่กรอกอีเมลไม่ถูกรูปแบบ "(//div[@class='q-field__messages col']//div)[2]", ); await expect(emailError).toHaveText('ข้อมูลไม่ถูกต้อง', { timeout: 2000, }); console.log( 'ตรวจสอบการแสดง Vidation แจ้งเตือนในกรณีที่กรอกอีเมลไม่ถูกรูปแบบ', ); } catch (error) { console.error('เกิดข้อผิดพลาดในการทดสอบ', error); isLoginSuccessful = false; throw error; } await page.waitForTimeout(4000); await page.click('id=btn-form-close'); });