diff --git a/packages/nc-gui/components/smartsheet/column/QrCodeOptions.vue b/packages/nc-gui/components/smartsheet/column/QrCodeOptions.vue index 2ea6334837..19c6c276a8 100644 --- a/packages/nc-gui/components/smartsheet/column/QrCodeOptions.vue +++ b/packages/nc-gui/components/smartsheet/column/QrCodeOptions.vue @@ -56,7 +56,6 @@ setAdditionalValidations({ { 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' }); + }); }); });