Browse Source

qrcode: playwright tests (WIP)

pull/4142/head
Daniel Spaude 2 years ago
parent
commit
73db942ab7
No known key found for this signature in database
GPG Key ID: 654A3D1FA4F35FFE
  1. 1
      packages/nc-gui/components/smartsheet/column/QrCodeOptions.vue
  2. 11
      tests/playwright/pages/Dashboard/Grid/Column/index.ts
  3. 24
      tests/playwright/pages/Dashboard/common/Cell/index.ts
  4. 124
      tests/playwright/tests/columnQrCode.spec.ts

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

@ -56,6 +56,7 @@ 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"

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

@ -21,6 +21,7 @@ export class ColumnPageObject extends BasePage {
title,
type = 'SingleLineText',
formula = '',
qrCodeValueColumnTitle = '',
childTable = '',
childColumn = '',
relationType = '',
@ -30,6 +31,7 @@ export class ColumnPageObject extends BasePage {
title: string;
type?: string;
formula?: string;
qrCodeValueColumnTitle?: string;
childTable?: string;
childColumn?: string;
relationType?: string;
@ -70,6 +72,15 @@ export class ColumnPageObject extends BasePage {
case 'Formula':
await this.get().locator('.nc-formula-input').fill(formula);
break;
case 'QrCode':
await this.get().locator('.ant-select-single').nth(1).click();
// await this.get().locator('.ant-select-item').fill(qrCodeValueColumnTitle);
await this.rootPage
.locator(`.ant-select-item`, {
hasText: qrCodeValueColumnTitle,
})
.click();
break;
case 'Lookup':
await this.get().locator('.ant-select-single').nth(1).click();
await this.rootPage

24
tests/playwright/pages/Dashboard/common/Cell/index.ts

@ -82,6 +82,30 @@ export class CellPageObject extends BasePage {
}
}
async verifyQrCodeCell({
index,
columnHeader,
expectedSrcValue,
}: {
index: number;
columnHeader: string;
expectedSrcValue: string;
}) {
const _verify = async text => {
await expect
.poll(async () => {
const innerTexts = await this.get({
index,
columnHeader,
}).allInnerTexts();
return typeof innerTexts === 'string' ? [innerTexts] : innerTexts;
})
.toContain(text);
};
await _verify(expectedSrcValue);
}
// todo: Improve param names (i.e value => values)
// verifyVirtualCell
// : virtual relational cell- HM, BT, MM

124
tests/playwright/tests/columnQrCode.spec.ts

@ -0,0 +1,124 @@
import { test } from '@playwright/test';
import { DashboardPage } from '../pages/Dashboard';
import setup, { NcContext } from '../setup';
import { isPg, isSqlite } from '../setup/db';
// Add formula to be verified here & store expected results for 5 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
* Acua 2006-02-15 04:45:25 1789 Saint-Denis Parkway Mexico
* Adana 2006-02-15 04:45:25 663 Baha Blanca Parkway Turkey
*/
// const formulaDataByDbType = (context: NcContext) => [
// {
// formula: '1 + 1',
// result: ['2', '2', '2', '2', '2'],
// },
// {
// formula: 'ADD({CityId}, {CountryId}) + AVG({CityId}, {CountryId}) + LEN({City})',
// result: ['150', '130', '165', '100', '158'],
// },
// {
// formula: `WEEKDAY("2022-07-19")`,
// result: ['1', '1', '1', '1', '1'],
// },
// {
// formula: `WEEKDAY("2022-07-19", "sunday")`,
// result: ['2', '2', '2', '2', '2'],
// },
// {
// formula: `CONCAT(UPPER({City}), LOWER({City}), TRIM(' trimmed '))`,
// result: [
// 'A CORUA (LA CORUA)a corua (la corua)trimmed',
// 'ABHAabhatrimmed',
// 'ABU DHABIabu dhabitrimmed',
// 'ACUAacuatrimmed',
// 'ADANAadanatrimmed',
// ],
// },
// {
// formula: `CEILING(1.4) + FLOOR(1.6) + ROUND(2.5) + MOD({CityId}, 3) + MIN({CityId}, {CountryId}) + MAX({CityId}, {CountryId})`,
// result: ['95', '92', '110', '71', '110'],
// },
// {
// formula: `LOG({CityId}) + EXP({CityId}) + POWER({CityId}, 3) + SQRT({CountryId})`,
// result: isPg(context)
// ? ['13.04566088154786', '24.74547123273205', '57.61253379902822', '126.94617671688704', '283.9609869087087']
// : ['13.04566088154786', '25.137588417628013', '58.23402483297667', '127.73041108667896', '284.8714548168068'],
// },
// {
// formula: `NOW()`,
// result: ['1', '1', '1', '1', '1'],
// },
// ];
const expectedQrCodeCellValues = [
'',
'',
'',
];
test.describe('Virtual Columns', () => {
let dashboard: DashboardPage;
let context: any;
test.beforeEach(async ({ page }) => {
context = await setup({ page });
dashboard = new DashboardPage(page, context.project);
});
async function formulaResultVerify({
qrColumnTitle,
expectedQrCodes,
}: {
qrColumnTitle: string;
expectedQrCodes: string[];
}) {
for (let i = 0; i < expectedQrCodes.length; i++) {
await dashboard.grid.cell.verify({
index: i,
columnHeader: qrColumnTitle,
value: expectedQrCodes[i],
});
}
}
test('QrCode', async () => {
// close 'Team & Auth' tab
// const formulaData = formulaDataByDbType(context);
await dashboard.closeTab({ title: 'Team & Auth' });
await dashboard.treeView.openTable({ title: 'City' });
// Create qr code column
await dashboard.grid.column.create({
title: 'QrCode1',
type: 'QrCode',
qrCodeValueColumnTitle: 'City',
});
// verify different formula's
// for (let i = 1; i < formulaData.length; i++) {
// // Sqlite does not support log function
// if (isSqlite(context) && formulaData[i].formula.includes('LOG(')) continue;
// await dashboard.grid.column.openEdit({
// title: 'NC_MATH_0',
// type: 'Formula',
// formula: formulaData[i].formula,
// });
// await dashboard.grid.column.save({ isUpdated: true });
// if (formulaData[i].formula !== `NOW()`) {
// await formulaResultVerify({
// title: 'NC_MATH_0',
// result: formulaData[i].result,
// });
// }
// }
await dashboard.closeTab({ title: 'City' });
});
});
Loading…
Cancel
Save