From b567d2230ea47608a0e9eab564864f7975c287cb Mon Sep 17 00:00:00 2001 From: kdaud Date: Sun, 25 Aug 2024 06:07:32 +0300 Subject: [PATCH] C2C-346: E2e tests for the flows Bahmni and OpenELIS --- .env | 4 +- e2e/tests/bahmni-odoo-flows.spec.ts | 10 +- e2e/tests/bahmni-openelis-flows.spec.ts | 227 ++++++++++++++++++++++++ e2e/tests/lab-orders.spec.ts | 2 +- e2e/tests/medications.spec.ts | 2 +- e2e/utils/configs/globalSetup.ts | 1 + e2e/utils/functions/bahmni.ts | 29 ++- e2e/utils/functions/openelis.ts | 55 ++++++ package.json | 2 +- playwright.config.ts | 8 +- 10 files changed, 320 insertions(+), 20 deletions(-) create mode 100644 e2e/tests/bahmni-openelis-flows.spec.ts create mode 100644 e2e/utils/functions/openelis.ts diff --git a/.env b/.env index 3d1b53c..9e2ac72 100644 --- a/.env +++ b/.env @@ -36,5 +36,5 @@ ODOO_USERNAME=admin ODOO_PASSWORD=admin # OpenELIS test user credentials -OpenELIS_USERNAME=admin -OpenELIS_PASSWORD=adminADMIN! +OPENELIS_USERNAME=admin +OPENELIS_PASSWORD=adminADMIN! diff --git a/e2e/tests/bahmni-odoo-flows.spec.ts b/e2e/tests/bahmni-odoo-flows.spec.ts index d7e547f..ca42774 100644 --- a/e2e/tests/bahmni-odoo-flows.spec.ts +++ b/e2e/tests/bahmni-odoo-flows.spec.ts @@ -17,7 +17,7 @@ test.beforeEach(async ({ page }) => { await expect(page.getByText(/appointment scheduling/i)).toBeVisible(); await expect(page.getByText(/patient documents/i)).toBeVisible(); await bahmni.registerPatient(); - await bahmni.goToHomePage(); + await bahmni.goToPatientDashboard(); }); test('Ordering a lab test for a Bahmni patient creates the corresponding Odoo customer with a filled quotation.', async ({ page }) => { @@ -83,7 +83,7 @@ test('Revising a synced Bahmni lab order edits the corresponding Odoo quotation await expect(labTest).toHaveText('Malaria'); // replay - await page.goto(`${BAHMNI_URL}`); + await bahmni.goToPatientDashboard(); await bahmni.goToLabSamples(); await bahmni.reviseLabOrder(); @@ -113,7 +113,7 @@ test('Discontinuing a synced Bahmni lab order edits the corresponding Odoo quota await expect(labTest).toHaveText('Malaria'); // replay - await page.goto(`${BAHMNI_URL}`); + await bahmni.goToPatientDashboard(); await bahmni.goToLabSamples(); await bahmni.discontinueLabOrder(); @@ -184,7 +184,7 @@ test('Revising a synced OpenMRS drug order edits the corresponding Odoo quotatio await expect(medicationDescrptionSelector).toContainText('Aspirine Co 81mg | 560.0 Ampoule(s) | 2.0 Application(s) - Q3H - 5 Semaine(s)'); // replay - await page.goto(`${BAHMNI_URL}`); + await bahmni.goToPatientDashboard(); await bahmni.goToMedications(); await bahmni.editMedicationDetails(); @@ -214,7 +214,7 @@ test('Discontinuing a synced Bahmni drug order for an Odoo customer with a singl await expect(medicationDescrptionSelector).toContainText('Aspirine Co 81mg | 560.0 Ampoule(s) | 2.0 Application(s) - Q3H - 5 Semaine(s)'); // replay - await page.goto(`${BAHMNI_URL}`); + await bahmni.goToPatientDashboard(); await bahmni.goToMedications(); await bahmni.discontinueMedication(); diff --git a/e2e/tests/bahmni-openelis-flows.spec.ts b/e2e/tests/bahmni-openelis-flows.spec.ts new file mode 100644 index 0000000..f6f5375 --- /dev/null +++ b/e2e/tests/bahmni-openelis-flows.spec.ts @@ -0,0 +1,227 @@ +import { test, expect } from '@playwright/test'; +import { Bahmni, patientName } from '../utils/functions/bahmni'; +import { OpenELIS } from '../utils/functions/openelis'; +import { BAHMNI_URL } from '../utils/configs/globalSetup'; + +let bahmni: Bahmni; +let openelis: OpenELIS; + +test.beforeEach(async ({ page }) => { + bahmni = new Bahmni(page); + openelis = new OpenELIS(page); + + await bahmni.login(); + await expect(page.getByText(/registration/i)).toBeVisible(); + await expect(page.getByText(/linical/i)).toBeVisible(); + await expect(page.getByText(/admin/i)).toBeVisible(); + await expect(page.getByText(/appointment scheduling/i)).toBeVisible(); + await expect(page.getByText(/patient documents/i)).toBeVisible(); + await bahmni.registerPatient(); + await bahmni.goToPatientDashboard(); +}); + +test('Ordering a lab test for a Bahmni patient creates the corresponding OpenElis client with an analysis request.', async ({ page }) => { + // setup + await bahmni.goToLabSamples(); + + // replay + await bahmni.createLabOrder(); + await page.locator('#dashboard-link span.patient-name').click(); + await expect(page.locator('#Lab-Orders').getByText('Malaria')) .toBeVisible(); + + // verify + await openelis.open(); + await expect(page).toHaveURL(/.*openelis/); + await openelis.searchClient(); + + const clientSelector = await page.locator("#todaySamplesToCollectListContainer-slick-grid div.slick-cell.l1.r1"); + await expect(clientSelector).toHaveText(`${patientName.givenName + ' ' + patientName.familyName}`); + + await page.locator('#todaySamplesToCollectListContainer-slick-grid div.slick-viewport div.slick-cell.l6.r6.cell-title a').click(); + await expect(page.locator('#tests_1')).toHaveValue('Malaria') +}); + + +test('Editing the details of a Bahmni patient with a synced lab order edits the corresponding OpenELIS client details.', async ({ page }) => { + // setup + await bahmni.goToLabSamples(); + await bahmni.createLabOrder(); + await page.locator('#dashboard-link span.patient-name').click(); + await expect(page.locator('#Lab-Orders').getByText('Malaria')) .toBeVisible(); + await openelis.open(); + await expect(page).toHaveURL(/.*openelis/); + await openelis.searchClient(); + const clientSelector = await page.locator("#todaySamplesToCollectListContainer-slick-grid div.slick-cell.l1.r1"); + await expect(clientSelector).toHaveText(`${patientName.givenName + ' ' + patientName.familyName}`); + + // replay + await page.goto(`${BAHMNI_URL}`); + await bahmni.updatePatientDetails(); + + // verify + await openelis.open(); + await openelis.searchClient(); + await expect(clientSelector).toHaveText(`${patientName.updatedGivenName}` + ' ' + `${patientName.familyName}`); +}); + + +test('Revising a synced Bahmni lab order edits the corresponding OpenELIS client analysis request.', async ({ page }) => { + // setup + await bahmni.goToLabSamples(); + await bahmni.createLabOrder(); + await page.locator('#dashboard-link span.patient-name').click(); + await expect(page.locator('#Lab-Orders').getByText('Malaria')) .toBeVisible(); + await openelis.open(); + await expect(page).toHaveURL(/.*openelis/); + await openelis.searchClient(); + const clientSelector = await page.locator("#todaySamplesToCollectListContainer-slick-grid div.slick-cell.l1.r1"); + await expect(clientSelector).toHaveText(`${patientName.givenName + ' ' + patientName.familyName}`); + await page.locator('#todaySamplesToCollectListContainer-slick-grid div.slick-viewport div.slick-cell.l6.r6.cell-title a').click(); + await expect(page.locator('#tests_1')).toHaveValue('Malaria') + + // replay + await bahmni.goToPatientDashboard(); + await bahmni.goToLabSamples(); + await bahmni.reviseLabOrder(); + await page.locator('#dashboard-link span.patient-name').click(); + await expect(page.locator('#Lab-Orders').getByText('Hematocrit')).toBeVisible(); + + // verify + await openelis.open(); + await openelis.searchClient(); + await expect(clientSelector).toHaveText(`${patientName.givenName + ' ' + patientName.familyName}`); + + await page.locator('#todaySamplesToCollectListContainer-slick-grid div.slick-viewport div.slick-cell.l6.r6.cell-title a').click(); + await expect(page.locator('#tests_1')).toHaveValue('Hematocrite'); +}); + +test('Voiding a synced OpenMRS lab order cancels the corresponding OpenElis analysis request.', async ({ page }) => { + // setup + await bahmni.goToLabSamples(); + await bahmni.createLabOrder(); + await page.locator('#dashboard-link span.patient-name').click(); + await expect(page.locator('#Lab-Orders').getByText('Malaria')) .toBeVisible(); + await openelis.open(); + await expect(page).toHaveURL(/.*openelis/); + await openelis.searchClient(); + const clientSelector = await page.locator("#todaySamplesToCollectListContainer-slick-grid div.slick-cell.l1.r1"); + await expect(clientSelector).toHaveText(`${patientName.givenName + ' ' + patientName.familyName}`); + await page.locator('#todaySamplesToCollectListContainer-slick-grid div.slick-viewport div.slick-cell.l6.r6.cell-title a').click(); + await expect(page.locator('#tests_1')).toHaveValue('Malaria') + + // replay + await bahmni.goToPatientDashboard(); + await bahmni.goToLabSamples(); + await bahmni.discontinueLabOrder(); + + // verify + await openelis.open(); + await openelis.searchClient(); + await expect(page.getByText(`${patientName.givenName + ' ' + patientName.familyName}`)).not.toBeVisible(); +}); + +test('Published coded lab results from OpenELIS are viewable in the Bahmni lab results viewer.', async ({ page }) => { + // setup + await bahmni.goToLabSamples(); + await bahmni.createLabOrder(); + await page.locator('#dashboard-link span.patient-name').click(); + await expect(page.locator('#Lab-Orders').getByText('Malaria')) .toBeVisible(); + + // replay + await openelis.open(); + await expect(page).toHaveURL(/.*openelis/); + await openelis.searchClient(); + + const clientSelector = await page.locator("#todaySamplesToCollectListContainer-slick-grid div.slick-cell.l1.r1"); + await expect(clientSelector).toHaveText(`${patientName.givenName + ' ' + patientName.familyName}`); + await openelis.collectSample(); + await page.locator('a#todaySamplesCollectedListContainerId').click(); + await page.locator('#todaySamplesCollectedListContainer-slick-grid div.ui-state-default.slick-headerrow-column.l2.r2 input[type=text]').type(`${patientName.familyName}`); + + await openelis.enterLabResults(); + await page.locator('a#todaySamplesCollectedListContainerId').click(); + await page.locator('#todaySamplesCollectedListContainer-slick-grid div.ui-state-default.slick-headerrow-column.l2.r2 input[type=text]').type(`${patientName.familyName}`); + await openelis.validateLabResults(); + await page.locator('#todaySamplesCollectedListContainer-slick-grid div.ui-state-default.slick-headerrow-column.l2.r2 input[type=text]').type(`${patientName.familyName}`); + const status = await page.locator('#todaySamplesCollectedListContainer-slick-grid div.slick-viewport div div:nth-child(1) div.slick-cell.l8.r8.cell-title'); + await expect(status).toHaveText('Yes'); + + // verify + await bahmni.goToPatientDashboard(); + await expect(page.locator('#Lab-Results').getByText('Malaria')).toBeVisible(); + await expect(page.locator('#Lab-Results span.value')).toHaveText('Negatif'); +}); + +test('Published numerical lab results from OpenELIS are viewable in the Bahmni lab results viewer.', async ({ page }) => { + // setup + await bahmni.goToLabSamples(); + await page.getByText('Blood', { exact: true }).click(); + await page.getByText('Lymphocites').click(); + await bahmni.saveOrder(); + await page.locator('#dashboard-link span.patient-name').click(); + await expect(page.locator('#Lab-Orders').getByText('Lymphocytes')) .toBeVisible(); + + // replay + await openelis.open(); + await expect(page).toHaveURL(/.*openelis/); + await openelis.searchClient(); + + const clientSelector = await page.locator("#todaySamplesToCollectListContainer-slick-grid div.slick-cell.l1.r1"); + await expect(clientSelector).toHaveText(`${patientName.givenName + ' ' + patientName.familyName}`); + await openelis.collectSample(); + await page.locator('a#todaySamplesCollectedListContainerId').click(); + await page.locator('#todaySamplesCollectedListContainer-slick-grid div.ui-state-default.slick-headerrow-column.l2.r2 input[type=text]').type(`${patientName.familyName}`); + + await openelis.enterNumericalResults(); + await page.locator('a#todaySamplesCollectedListContainerId').click(); + await page.locator('#todaySamplesCollectedListContainer-slick-grid div.ui-state-default.slick-headerrow-column.l2.r2 input[type=text]').type(`${patientName.familyName}`); + await openelis.validateLabResults(); + await page.locator('#todaySamplesCollectedListContainer-slick-grid div.ui-state-default.slick-headerrow-column.l2.r2 input[type=text]').type(`${patientName.familyName}`); + const status = await page.locator('#todaySamplesCollectedListContainer-slick-grid div.slick-viewport div div:nth-child(1) div.slick-cell.l8.r8.cell-title'); + await expect(status).toHaveText('Yes'); + + // verify + await bahmni.goToPatientDashboard(); + await expect(page.locator('#Lab-Results').getByText('Lymphocytes')).toBeVisible(); + await expect(page.locator('#Lab-Results span.value')).toHaveText('13.7'); +}); + +test('Published free text lab results from OpenELIS are viewable in the Bahmni lab results viewer.', async ({ page }) => { + // setup + await bahmni.goToLabSamples(); + await page.getByText('Urine', { exact: true }).click(); + await page.getByText('Urobilinogen').click(); + await bahmni.saveOrder(); + await page.locator('#dashboard-link span.patient-name').click(); + await expect(page.locator('#Lab-Orders').getByText('Urobilinogen')) .toBeVisible(); + + // replay + await openelis.open(); + await expect(page).toHaveURL(/.*openelis/); + await openelis.searchClient(); + + const clientSelector = await page.locator("#todaySamplesToCollectListContainer-slick-grid div.slick-cell.l1.r1"); + await expect(clientSelector).toHaveText(`${patientName.givenName + ' ' + patientName.familyName}`); + await openelis.collectSample(); + await page.locator('a#todaySamplesCollectedListContainerId').click(); + await page.locator('#todaySamplesCollectedListContainer-slick-grid div.ui-state-default.slick-headerrow-column.l2.r2 input[type=text]').type(`${patientName.familyName}`); + + await openelis.enterFreeTextResults(); + await page.locator('a#todaySamplesCollectedListContainerId').click(); + await page.locator('#todaySamplesCollectedListContainer-slick-grid div.ui-state-default.slick-headerrow-column.l2.r2 input[type=text]').type(`${patientName.familyName}`); + await openelis.validateLabResults(); + await page.locator('#todaySamplesCollectedListContainer-slick-grid div.ui-state-default.slick-headerrow-column.l2.r2 input[type=text]').type(`${patientName.familyName}`); + const status = await page.locator('#todaySamplesCollectedListContainer-slick-grid div.slick-viewport div div:nth-child(1) div.slick-cell.l8.r8.cell-title'); + await expect(status).toHaveText('Yes'); + + // verify + await bahmni.goToPatientDashboard(); + await expect(page.locator('#Lab-Results').getByText('Urobilinogen')).toBeVisible(); + await expect(page.locator('#Lab-Results span.value')).toHaveText('Abnormal level'); +}); + +test.afterEach(async ({ page }) => { + await bahmni.voidPatient(); + await page.close(); +}); + diff --git a/e2e/tests/lab-orders.spec.ts b/e2e/tests/lab-orders.spec.ts index 9de941e..4b8e762 100644 --- a/e2e/tests/lab-orders.spec.ts +++ b/e2e/tests/lab-orders.spec.ts @@ -17,9 +17,9 @@ test.beforeEach(async ({ page }) => { test('Create, revise and discontinue lab tests.', async ({ page }) => { // setup await bahmni.registerPatient(); + await bahmni.goToPatientDashboard(); // replay - await bahmni.goToHomePage(); await bahmni.goToLabSamples(); await page.getByText('Blood', { exact: true }).click(); await page.getByText('Malaria').click(); diff --git a/e2e/tests/medications.spec.ts b/e2e/tests/medications.spec.ts index 23bcca6..cf1f298 100644 --- a/e2e/tests/medications.spec.ts +++ b/e2e/tests/medications.spec.ts @@ -17,9 +17,9 @@ test.beforeEach(async ({ page }) => { test('Create, revise and discontinue a drug order.', async ({ page }) => { // setup await bahmni.registerPatient(); + await bahmni.goToPatientDashboard(); // replay - await bahmni.goToHomePage(); await bahmni.goToMedications(); await bahmni.createMedication(); diff --git a/e2e/utils/configs/globalSetup.ts b/e2e/utils/configs/globalSetup.ts index 181e0b0..e8770b0 100644 --- a/e2e/utils/configs/globalSetup.ts +++ b/e2e/utils/configs/globalSetup.ts @@ -13,6 +13,7 @@ dotenv.config(); export const BAHMNI_URL = `${process.env.TEST_ENVIRONMENT}` == 'uat' ? `${process.env.BAHMNI_URL_UAT}` : `${process.env.BAHMNI_URL_DEV}`; export const ODOO_URL = `${process.env.TEST_ENVIRONMENT}` == 'uat' ? `${process.env.ODOO_URL_UAT}` : `${process.env.ODOO_URL_DEV}`; +export const OPENELIS_URL = `${process.env.TEST_ENVIRONMENT}` == 'uat' ? `${process.env.OPENELIS_URL_UAT}` : `${process.env.OPENELIS_URL_DEV}`; async function globalSetup() { const requestContext = await request.newContext(); diff --git a/e2e/utils/functions/bahmni.ts b/e2e/utils/functions/bahmni.ts index 9b39f4e..a8e46bd 100644 --- a/e2e/utils/functions/bahmni.ts +++ b/e2e/utils/functions/bahmni.ts @@ -6,6 +6,19 @@ export var patientName = { familyName : '', updatedGivenName: '', } +/* +export const delay = (mills) => { + const end = Date.now() + mills; + while (Date.now() < end) {} +}; +*/ +export const delay = (mills) => { + let datetime1 = new Date().getTime(); + let datetime2 = datetime1 + mills; + while(datetime1 < datetime2) { + datetime1 = new Date().getTime(); + } +} export class Bahmni { constructor(readonly page: Page) {} @@ -50,8 +63,10 @@ export class Bahmni { await this.page.locator('#view-content td:nth-child(1) a').click(); await this.page.locator('#givenName').clear(); await this.page.locator('#givenName').fill(`${patientName.updatedGivenName}`); + await delay(2000); await this.page.getByRole('button', { name: 'Save' }).click(); patientName.givenName = `${patientName.updatedGivenName}`; + await delay(5000); }; async voidPatient() { @@ -65,8 +80,6 @@ export class Bahmni { } async goToLabSamples() { - await this.page.getByRole('link', { name: 'Clinical' }).click(); - await this.searchPatient(); await this.page.locator('#view-content :nth-child(1).btn--success').click(); await this.page.locator('#opd-tabs').getByText('Orders').click(); await expect(this.page.getByText('Lab Samples')).toBeVisible(); @@ -76,6 +89,7 @@ export class Bahmni { await this.page.getByText('Blood', { exact: true }).click(); await this.page.getByText('Malaria').click(); await this.saveOrder(); + await delay(8000); } async reviseLabOrder() { @@ -83,22 +97,23 @@ export class Bahmni { await this.page.locator('#selected-orders li').filter({ hasText: 'Malaria' }).locator('i').nth(1).click(); await this.page.getByText('Hematocrit').click(); await this.saveOrder(); + await delay(8000); } async discontinueLabOrder() { await this.page.getByText('Blood', { exact: true }).click(); await this.page.locator('#selected-orders li').filter({ hasText: 'Malaria' }).locator('i').nth(1).click(); await this.saveOrder(); + await delay(8000); } - async goToHomePage() { - await this.page.goto(`${BAHMNI_URL}/bahmni/home/`); - await expect(this.page).toHaveURL(/.*home/); + async goToPatientDashboard() { + await this.page.goto(`${BAHMNI_URL}/bahmni/home`); + await this.page.getByRole('link', { name: 'Clinical' }).click(); + await this.searchPatient(); } async goToMedications() { - await this.page.getByRole('link', { name: 'Clinical' }).click(); - await this.searchPatient(); await this.page.locator('#view-content :nth-child(1).btn--success').click(); await this.page.locator('#opd-tabs').getByText('Medications').click(); await expect(this.page.getByText('Order Drug')).toBeVisible(); diff --git a/e2e/utils/functions/openelis.ts b/e2e/utils/functions/openelis.ts new file mode 100644 index 0000000..e1dc295 --- /dev/null +++ b/e2e/utils/functions/openelis.ts @@ -0,0 +1,55 @@ +import { Page } from '@playwright/test'; +import { OPENELIS_URL } from '../configs/globalSetup'; +import { delay, patientName } from './bahmni'; + +export class OpenELIS { + constructor(readonly page: Page) {} + + async open() { + await this.page.goto(`${OPENELIS_URL}`); + await this.page.locator("input[name='loginName']").fill(`${process.env.OPENELIS_USERNAME}`); + await this.page.locator("input[name='password']").fill(`${process.env.OPENELIS_PASSWORD}`); + await this.page.locator('#submitButton').click(); + } + + async searchClient() { + await this.page.locator('#menu_labDashboard').click(); + await delay(5000); + await this.page.locator('input#refreshButton').click(); + await this.page.locator('input[type=text]').nth(1).type(`${patientName.familyName}`); + } + + async collectSample() { + await this.page.locator('#todaySamplesToCollectListContainer-slick-grid div.slick-viewport div.slick-cell.l6.r6.cell-title a').click(); + await this.page.locator('#orderDisplay tbody input.textButton').click(); + await this.page.locator('#saveButtonId').first().click(); + } + + async enterLabResults() { + await this.page.locator('#result').first().click(); + await this.page.locator('#results_1').selectOption('Negatif'); + await this.page.locator('#saveButtonId').first().click(); + } + + async enterNumericalResults() { + await this.page.locator('#result').first().click(); + await this.page.locator('#results_1').click(); + await this.page.locator('#results_1').fill('13.7'); + await this.page.locator('#cell_1').click(); + await this.page.locator('#saveButtonId').first().click(); + } + + async enterFreeTextResults() { + await this.page.locator('#result').first().click(); + await this.page.locator('#results_1').fill('Abnormal level'); + await this.page.locator('#abnormalId_1').click(); + await this.page.locator('#saveButtonId').first().click(); + } + + async validateLabResults() { + await this.page.locator('a#validate').first().click(); + await this.page.locator('#accepted_0').check(); + await this.page.locator('#saveButtonId').first().click(); + await delay(3000); + } +} diff --git a/package.json b/package.json index c52ced8..951ecbc 100644 --- a/package.json +++ b/package.json @@ -4,7 +4,7 @@ "license": "MPL-2.0", "description": "These are end-to-end automated tests covering Bahmni distro C2C workflows", "scripts": { - "e2e-tests-c2c": "npx playwright test" + "e2e-tests-c2c": "npx playwright test openelis" }, "keywords": [], "devDependencies": { diff --git a/playwright.config.ts b/playwright.config.ts index 23720b1..39ea76d 100644 --- a/playwright.config.ts +++ b/playwright.config.ts @@ -4,7 +4,7 @@ dotenv.config(); const config: PlaywrightTestConfig = { testDir: './e2e/tests', - timeout: 3 * 60 * 1000, + timeout: 4 * 60 * 1000, expect: { timeout: 40 * 1000, }, @@ -24,8 +24,10 @@ const config: PlaywrightTestConfig = { use: { ...devices['Desktop Chromium'], launchOptions: { - slowMo: 500 - } + slowMo: 600 + }, + video: 'retain-on-failure', + screenshot: 'only-on-failure' }, }, ],