Browse Source

qrcode: add more playwright tests

pr-4468-qr-code-extraction
Daniel Spaude 2 years ago
parent
commit
873aa85a84
No known key found for this signature in database
GPG Key ID: 654A3D1FA4F35FFE
  1. 19
      tests/playwright/pages/Dashboard/Grid/Column/index.ts
  2. 44
      tests/playwright/tests/columnQrCode.spec.ts

19
tests/playwright/pages/Dashboard/Grid/Column/index.ts

@ -151,19 +151,6 @@ export class ColumnPageObject extends BasePage {
} }
async changeReferencedColumnForQrCode({ titleOfReferencedColumn }: { titleOfReferencedColumn: string }) { async changeReferencedColumnForQrCode({ titleOfReferencedColumn }: { titleOfReferencedColumn: string }) {
// await this.get().locator('.ant-select-selector > .ant-select-selection-item:nth-child(2').click();
// await this.get().locator('.ant-select-single').nth(1).click();
// await this.get().locator('.ant-select-single').nth(1).click();
// await this.rootPage
// .locator(`.ant-select-item`, {
// hasText: qrCodeValueColumnTitle,
// })
// .click();
await this.get().locator('.nc-qr-code-value-column-select .ant-select-single').click(); await this.get().locator('.nc-qr-code-value-column-select .ant-select-single').click();
await this.rootPage await this.rootPage
.locator(`.ant-select-item`, { .locator(`.ant-select-item`, {
@ -172,12 +159,6 @@ export class ColumnPageObject extends BasePage {
.click(); .click();
await this.save(); await this.save();
// await this.get().locator('.ant-select-selection-search-input[aria-expanded="true"]').waitFor();
// await this.get().locator('.ant-select-selection-search-input[aria-expanded="true"]').fill(type);
// // Select column type
// await this.rootPage.locator(`text=${type}`).nth(1).click();
} }
async delete({ title }: { title: string }) { async delete({ title }: { title: string }) {

44
tests/playwright/tests/columnQrCode.spec.ts

@ -29,7 +29,7 @@ test.describe('Virtual Columns', () => {
}); });
} }
} }
test('creation, showing, updating value and change qr col title and reference column', async () => { test('creation, showing, updating value and change qr column title and reference column', async () => {
// Add qr code column referencing the City column // Add qr code column referencing the City column
// and compare the base64 encoded codes/src attributes for the first 3 rows. // and compare the base64 encoded codes/src attributes for the first 3 rows.
// Column data from City table (Sakila DB) // Column data from City table (Sakila DB)
@ -68,7 +68,6 @@ test.describe('Virtual Columns', () => {
qrCodeValueColumnTitle: 'City', qrCodeValueColumnTitle: 'City',
}); });
await qrCodeColumnVerify('QrCode1', expectedQrCodeCellValues); await qrCodeColumnVerify('QrCode1', expectedQrCodeCellValues);
// Clicking on qr code in first row and expect it shows a // Clicking on qr code in first row and expect it shows a
@ -78,15 +77,16 @@ test.describe('Virtual Columns', () => {
await qrGridOverlay.verifyQrValueLabel(expectedQrCodeCellValues[0].referencedValue); await qrGridOverlay.verifyQrValueLabel(expectedQrCodeCellValues[0].referencedValue);
await qrGridOverlay.clickCloseButton(); await qrGridOverlay.clickCloseButton();
// Change the value in the referenced column, first row // Change the value in the referenced column, first row
// and expect respective QR changes accordingly // and expect respective QR changes accordingly
await grid.cell.fillText({ columnHeader: 'City', index: 0, text: 'Hamburg' }) await grid.cell.fillText({ columnHeader: 'City', index: 0, text: 'Hamburg' });
const expectedQrCodeCellValuesAfterCityNameChange = [ const expectedQrCodeCellValuesAfterCityNameChange = [
{ {
referencedValue: 'Hamburg', referencedValue: 'Hamburg',
base64EncodedSrc: '' base64EncodedSrc:
'',
}, },
...expectedQrCodeCellValues.slice(1) ...expectedQrCodeCellValues.slice(1),
]; ];
await qrCodeColumnVerify('QrCode1', expectedQrCodeCellValuesAfterCityNameChange); await qrCodeColumnVerify('QrCode1', expectedQrCodeCellValuesAfterCityNameChange);
@ -104,23 +104,22 @@ test.describe('Virtual Columns', () => {
// Change to another referenced column // Change to another referenced column
await grid.column.create({ title: 'New City Column' }); await grid.column.create({ title: 'New City Column' });
await grid.cell.fillText({ columnHeader: 'New City Column', index: 0, text: 'Hamburg' }) await grid.cell.fillText({ columnHeader: 'New City Column', index: 0, text: 'Hamburg' });
await grid.column.openEdit({ title: 'QrCode1 Renamed' }); await grid.column.openEdit({ title: 'QrCode1 Renamed' });
await grid.column.changeReferencedColumnForQrCode({ titleOfReferencedColumn: 'New City Column'}); await grid.column.changeReferencedColumnForQrCode({ titleOfReferencedColumn: 'New City Column' });
await qrCodeColumnVerify('QrCode1 Renamed', [{ await qrCodeColumnVerify('QrCode1 Renamed', [
referencedValue: 'Hamburg', {
base64EncodedSrc: '' referencedValue: 'Hamburg',
}]); base64EncodedSrc:
'',
},
]);
await dashboard.closeTab({ title: 'City' }); await dashboard.closeTab({ title: 'City' });
}); });
test('deletion when the reference value column is deleted', async () => { test('deletion of the QR column: directly and indirectly when the reference value column is deleted', async () => {
// close 'Team & Auth' tab // close 'Team & Auth' tab
await dashboard.closeTab({ title: 'Team & Auth' }); await dashboard.closeTab({ title: 'Team & Auth' });
@ -128,6 +127,15 @@ test.describe('Virtual Columns', () => {
await grid.column.create({ title: 'column_name_a' }); await grid.column.create({ title: 'column_name_a' });
await grid.column.verify({ title: 'column_name_a' }); await grid.column.verify({ title: 'column_name_a' });
await grid.column.create({
title: 'QrCode2',
type: 'QrCode',
qrCodeValueColumnTitle: 'column_name_a',
});
await grid.column.verify({ title: 'QrCode2', isVisible: true });
await grid.column.delete({ title: 'QrCode2' });
await grid.column.verify({ title: 'QrCode2', isVisible: false });
await grid.column.create({ await grid.column.create({
title: 'QrCode2', title: 'QrCode2',
type: 'QrCode', type: 'QrCode',

Loading…
Cancel
Save