diff --git a/e2e/tests/odoo-openmrs-flows.spec.ts b/e2e/tests/odoo-openmrs-flows.spec.ts index 9507dd4..bf661fa 100644 --- a/e2e/tests/odoo-openmrs-flows.spec.ts +++ b/e2e/tests/odoo-openmrs-flows.spec.ts @@ -40,6 +40,8 @@ test('Editing the details of an OpenMRS patient with a synced lab order edits th await odoo.searchCustomer(); await expect(page.locator('tr.o_data_row:nth-child(1) td:nth-child(4)')).toContainText(`${patientName.firstName + ' ' + patientName.givenName}`); await expect(page.locator('tr.o_data_row:nth-child(1) td:nth-child(8) span')).toHaveText('Quotation'); + await page.getByRole('cell', { name: `${patientName.firstName + ' ' + patientName.givenName}` }).click(); + await expect(page.locator('.o_group>table:nth-child(1) :nth-child(2) td:nth-child(2)>span')).toHaveText('08/16/2002'); // replay await page.goto(`${O3_URL}`); @@ -52,6 +54,9 @@ test('Editing the details of an OpenMRS patient with a synced lab order edits th await odoo.searchCustomer(); await expect(page.locator('tr.o_data_row:nth-child(1) td:nth-child(4)')).toHaveText(`${patientName.updatedFirstName}` + ' ' + `${patientName.givenName}`); await expect(page.locator('tr.o_data_row:nth-child(1) td:nth-child(8) span')).toHaveText('Quotation'); + await page.getByRole('cell', { name: `${patientName.firstName + ' ' + patientName.givenName}` }).click(); + await expect(page.locator('.o_group>table:nth-child(1) :nth-child(2) td:nth-child(2)>span')).not.toHaveText('08/16/2002'); + await expect(page.locator('.o_group>table:nth-child(1) :nth-child(2) td:nth-child(2)>span')).toHaveText('08/18/2003'); }); test('Ordering a drug for an OpenMRS patient creates the corresponding Odoo customer with a filled quotation.', async ({ page }) => { @@ -81,6 +86,8 @@ test('Editing the details of an OpenMRS patient with a synced drug order edits t await odoo.searchCustomer(); await expect(page.locator('tr.o_data_row:nth-child(1) td:nth-child(4)')).toContainText(`${patientName.firstName + ' ' + patientName.givenName}`); await expect(page.locator('tr.o_data_row:nth-child(1) td:nth-child(8) span')).toHaveText('Quotation'); + await page.getByRole('cell', { name: `${patientName.firstName + ' ' + patientName.givenName}` }).click(); + await expect(page.locator('.o_group>table:nth-child(1) :nth-child(2) td:nth-child(2)>span')).toHaveText('08/16/2002'); // replay await page.goto(`${O3_URL}`); @@ -93,6 +100,9 @@ test('Editing the details of an OpenMRS patient with a synced drug order edits t await odoo.searchCustomer(); await expect(page.locator('table tbody td.o_data_cell:nth-child(4)')).toHaveText(`${patientName.updatedFirstName}` + ' ' + `${patientName.givenName }`); await expect(page.locator('tr.o_data_row:nth-child(1) td:nth-child(8) span')).toHaveText('Quotation'); + await page.getByRole('cell', { name: `${patientName.firstName + ' ' + patientName.givenName}` }).click(); + await expect(page.locator('.o_group>table:nth-child(1) :nth-child(2) td:nth-child(2)>span')).not.toHaveText('08/16/2002'); + await expect(page.locator('.o_group>table:nth-child(1) :nth-child(2) td:nth-child(2)>span')).toHaveText('08/18/2003'); }); test('Revising details of a synced OpenMRS drug order modifies the corresponding Odoo quotation line.', async ({ page }) => { diff --git a/e2e/utils/functions/openmrs.ts b/e2e/utils/functions/openmrs.ts index fb5ff93..dc5de04 100644 --- a/e2e/utils/functions/openmrs.ts +++ b/e2e/utils/functions/openmrs.ts @@ -70,10 +70,9 @@ export class OpenMRS { await this.page.getByLabel('Family Name').clear(); await this.page.getByLabel('Family Name').fill(`${patientName.givenName}`); await this.page.locator('label').filter({ hasText: /^Male$/ }).locator('span').first().click(); - await this.page.locator('div').filter({ hasText: /^Date of Birth Known\?YesNo$/ }).getByRole('tab', { name: 'No' }).click(); - await expect(this.page.getByLabel('Estimated age in years')).toBeVisible(); - await this.page.getByLabel('Estimated age in years').clear(); - await this.page.getByLabel('Estimated age in years').fill(`${Math.floor(Math.random() * 99)}`); + await this.page.locator('div[aria-label="day, "]').fill('16'); + await this.page.locator('div[aria-label="month, "]').fill('08'); + await this.page.locator('div[aria-label="year, "]').fill('2002'); await expect(this.page.getByText('Register Patient')).toBeVisible(); await this.page.getByRole('button', { name: 'Register Patient' }).click(); await expect(this.page.getByText('New Patient Created')).toBeVisible(); @@ -351,6 +350,9 @@ export class OpenMRS { await this.page.getByLabel('First Name').type(`${patientName.updatedFirstName}`); await delay(2000); await this.page.locator('label').filter({ hasText: 'Female' }).locator('span').first().click(); + await this.page.locator('div[aria-label="day, "]').fill('18'); + await this.page.locator('div[aria-label="month, "]').fill('08'); + await this.page.locator('div[aria-label="year, "]').fill('2003'); await this.page.getByRole('button', { name: 'Update Patient' }).click(); await expect(this.page.getByText('Patient Details Updated')).toBeVisible(); patientName.firstName = `${patientName.updatedFirstName}`; diff --git a/package.json b/package.json index 7c98608..6551a8c 100644 --- a/package.json +++ b/package.json @@ -14,7 +14,7 @@ "!playwright-report/" ], "scripts": { - "ozone-pro": "npx playwright test", + "ozone-pro": "npx playwright test odoo-openmrs", "ozone-foss": "npx playwright test odoo-openmrs erpnext-openmrs openmrs-senaite", "openmrs-distro-his": "npx playwright test odoo-openmrs openmrs-senaite" },