Browse Source

qrcode: playwright tests (WIP)

pull/4142/head
Daniel Spaude 2 years ago
parent
commit
8218da8d43
No known key found for this signature in database
GPG Key ID: 654A3D1FA4F35FFE
  1. 1
      packages/nc-gui/components/smartsheet/column/QrCodeOptions.vue
  2. 103
      tests/playwright/tests/columnQrCode.spec.ts

1
packages/nc-gui/components/smartsheet/column/QrCodeOptions.vue

@ -56,7 +56,6 @@ setAdditionalValidations({
<a-col :span="24">
<a-form-item class="flex w-1/2 pb-2" :label="$t('labels.qrCodeValueColumn')" v-bind="validateInfos.fk_qr_value_column_id">
<a-select
class="nc-qrcode-value-col-id"
v-model:value="vModel.fk_qr_value_column_id"
:options="columnsAllowedAsQrValue"
placeholder="Select a column for the QR code value"

103
tests/playwright/tests/columnQrCode.spec.ts

@ -5,22 +5,6 @@ import { isPg, isSqlite } from '../setup/db';
import { expect, Locator } from '@playwright/test';
import { GridPage } from '../pages/Dashboard/Grid';
// Add qr code column referencing the City column
// and compare the base64 encoded codes/src attributes for the first 3 rows.
// Column data from City table (Sakila DB)
/**
* City LastUpdate Address List Country
* A Corua (La Corua) 2006-02-15 04:45:25 939 Probolinggo Loop Spain
* Abha 2006-02-15 04:45:25 733 Mandaluyong Place Saudi Arabia
* Abu Dhabi 2006-02-15 04:45:25 535 Ahmadnagar Manor United Arab Emirates
*/
const expectedQrCodeCellValues = [
'',
'',
'',
];
test.describe('Virtual Columns', () => {
let dashboard: DashboardPage;
let grid: GridPage;
@ -32,51 +16,66 @@ test.describe('Virtual Columns', () => {
grid = dashboard.grid;
});
async function qrCodeVerify(qrColumnTitle: string, expectedQrCodes: string[]) {
for (let i = 0; i < expectedQrCodes.length; i++) {
await dashboard.grid.cell.verifyQrCodeCell({
index: i,
columnHeader: qrColumnTitle,
expectedSrcValue: expectedQrCodes[i],
});
test.describe('QrCode Column', () => {
async function qrCodeColumnVerify(qrColumnTitle: string, expectedQrCodes: string[]) {
for (let i = 0; i < expectedQrCodes.length; i++) {
await dashboard.grid.cell.verifyQrCodeCell({
index: i,
columnHeader: qrColumnTitle,
expectedSrcValue: expectedQrCodes[i],
});
}
}
}
test('QrCode column creation and showing value in grid view', async () => {
// Add qr code column referencing the City column
// and compare the base64 encoded codes/src attributes for the first 3 rows.
// Column data from City table (Sakila DB)
/**
* City LastUpdate Address List Country
* A Corua (La Corua) 2006-02-15 04:45:25 939 Probolinggo Loop Spain
* Abha 2006-02-15 04:45:25 733 Mandaluyong Place Saudi Arabia
* Abu Dhabi 2006-02-15 04:45:25 535 Ahmadnagar Manor United Arab Emirates
*/
const expectedQrCodeCellValues = [
'',
'',
'',
];
test('QrCode', async () => {
// close 'Team & Auth' tab
await dashboard.closeTab({ title: 'Team & Auth' });
// close 'Team & Auth' tab
await dashboard.closeTab({ title: 'Team & Auth' });
await dashboard.treeView.openTable({ title: 'City' });
await dashboard.treeView.openTable({ title: 'City' });
// We expect that the QR code column is deleted
// when the column that is referenced by the QR code column gets deleted.
await grid.column.create({ title: 'column_name_a' });
await grid.column.verify({ title: 'column_name_a' });
// await grid.addNewRow({ index: 0, columnHeader: 'column_name_a', value: `Row 0` });
await dashboard.grid.column.create({
title: 'QrCode2',
type: 'QrCode',
qrCodeValueColumnTitle: 'column_name_a',
});
await grid.column.verify({ title: 'QrCode2', isVisible: true });
await grid.column.delete({ title: 'column_name_a' });
await grid.column.verify({ title: 'QrCode2', isVisible: true });
await dashboard.grid.column.create({
title: 'QrCode1',
type: 'QrCode',
qrCodeValueColumnTitle: 'City',
});
await qrCodeColumnVerify('QrCode1', expectedQrCodeCellValues);
await dashboard.grid.column.create({
title: 'QrCode1',
type: 'QrCode',
qrCodeValueColumnTitle: 'City',
await dashboard.closeTab({ title: 'City' });
});
await dashboard.grid.cell.verifyQrCodeCell({
index: 0,
columnHeader: 'QrCode1',
expectedSrcValue: expectedQrCodeCellValues[0],
});
test('QrCode column gets deleted when the reference value column is deleted', async () => {
// close 'Team & Auth' tab
await dashboard.closeTab({ title: 'Team & Auth' });
await dashboard.treeView.openTable({ title: 'City' });
await qrCodeVerify('QrCode1', expectedQrCodeCellValues);
await grid.column.create({ title: 'column_name_a' });
await grid.column.verify({ title: 'column_name_a' });
await dashboard.grid.column.create({
title: 'QrCode2',
type: 'QrCode',
qrCodeValueColumnTitle: 'column_name_a',
});
await grid.column.verify({ title: 'QrCode2', isVisible: true });
await grid.column.delete({ title: 'column_name_a' });
await grid.column.verify({ title: 'QrCode2', isVisible: false });
await dashboard.closeTab({ title: 'City' });
await dashboard.closeTab({ title: 'City' });
});
});
});

Loading…
Cancel
Save