mirror of https://github.com/nocodb/nocodb
flisowna
2 years ago
3 changed files with 133 additions and 28 deletions
@ -0,0 +1,80 @@ |
|||||||
|
import { expect, test } from '@playwright/test'; |
||||||
|
import { DashboardPage } from '../pages/Dashboard'; |
||||||
|
import setup from '../setup'; |
||||||
|
import { GridPage } from '../pages/Dashboard/Grid'; |
||||||
|
|
||||||
|
// type ExpectedBarcodeData = {
|
||||||
|
// referencedValue: string;
|
||||||
|
// base64EncodedSrc: string;
|
||||||
|
// };
|
||||||
|
|
||||||
|
const ONE_SVG_BARCODE_HTML = `<rect x="0" y="0" width="486" height="142" style="fill:#ffffff;"></rect><g transform="translate(10, 10)" style="fill:#000000;"><rect x="0" y="0" width="4" height="100"></rect><rect x="6" y="0" width="2" height="100"></rect><rect x="12" y="0" width="2" height="100"></rect><rect x="22" y="0" width="2" height="100"></rect><rect x="26" y="0" width="2" height="100"></rect><rect x="34" y="0" width="4" height="100"></rect><rect x="44" y="0" width="4" height="100"></rect><rect x="50" y="0" width="4" height="100"></rect><rect x="58" y="0" width="4" height="100"></rect><rect x="66" y="0" width="2" height="100"></rect><rect x="74" y="0" width="2" height="100"></rect><rect x="82" y="0" width="4" height="100"></rect><rect x="88" y="0" width="2" height="100"></rect><rect x="96" y="0" width="8" height="100"></rect><rect x="106" y="0" width="2" height="100"></rect><rect x="110" y="0" width="2" height="100"></rect><rect x="116" y="0" width="2" height="100"></rect><rect x="122" y="0" width="8" height="100"></rect><rect x="132" y="0" width="2" height="100"></rect><rect x="138" y="0" width="8" height="100"></rect><rect x="150" y="0" width="2" height="100"></rect><rect x="154" y="0" width="2" height="100"></rect><rect x="160" y="0" width="2" height="100"></rect><rect x="164" y="0" width="4" height="100"></rect><rect x="176" y="0" width="4" height="100"></rect><rect x="182" y="0" width="4" height="100"></rect><rect x="190" y="0" width="4" height="100"></rect><rect x="198" y="0" width="2" height="100"></rect><rect x="206" y="0" width="4" height="100"></rect><rect x="214" y="0" width="2" height="100"></rect><rect x="220" y="0" width="2" height="100"></rect><rect x="228" y="0" width="4" height="100"></rect><rect x="234" y="0" width="6" height="100"></rect><rect x="242" y="0" width="2" height="100"></rect><rect x="248" y="0" width="2" height="100"></rect><rect x="252" y="0" width="4" height="100"></rect><rect x="264" y="0" width="4" height="100"></rect><rect x="270" y="0" width="4" height="100"></rect><rect x="278" y="0" width="4" height="100"></rect><rect x="286" y="0" width="2" height="100"></rect><rect x="294" y="0" width="2" height="100"></rect><rect x="302" y="0" width="4" height="100"></rect><rect x="308" y="0" width="2" height="100"></rect><rect x="316" y="0" width="8" height="100"></rect><rect x="326" y="0" width="2" height="100"></rect><rect x="330" y="0" width="2" height="100"></rect><rect x="336" y="0" width="2" height="100"></rect><rect x="342" y="0" width="8" height="100"></rect><rect x="352" y="0" width="2" height="100"></rect><rect x="358" y="0" width="8" height="100"></rect><rect x="370" y="0" width="2" height="100"></rect><rect x="374" y="0" width="2" height="100"></rect><rect x="380" y="0" width="2" height="100"></rect><rect x="384" y="0" width="4" height="100"></rect><rect x="396" y="0" width="4" height="100"></rect><rect x="404" y="0" width="2" height="100"></rect><rect x="410" y="0" width="2" height="100"></rect><rect x="418" y="0" width="6" height="100"></rect><rect x="428" y="0" width="4" height="100"></rect><rect x="436" y="0" width="2" height="100"></rect><rect x="440" y="0" width="4" height="100"></rect><rect x="450" y="0" width="6" height="100"></rect><rect x="458" y="0" width="2" height="100"></rect><rect x="462" y="0" width="4" height="100"></rect><text style="font: 20px monospace" text-anchor="middle" x="233" y="122">A Corua (La Corua)</text></g>`; |
||||||
|
|
||||||
|
test.describe('Virtual Columns', () => { |
||||||
|
let dashboard: DashboardPage; |
||||||
|
let grid: GridPage; |
||||||
|
let context: any; |
||||||
|
|
||||||
|
test.beforeEach(async ({ page }) => { |
||||||
|
context = await setup({ page }); |
||||||
|
dashboard = new DashboardPage(page, context.project); |
||||||
|
grid = dashboard.grid; |
||||||
|
}); |
||||||
|
|
||||||
|
test.describe('Barcode Column', () => { |
||||||
|
// async function qrCodeColumnVerify(qrColumnTitle: string, expectedQrCodeData: ExpectedQrCodeData[]) {
|
||||||
|
// for (let i = 0; i < expectedQrCodeData.length; i++) {
|
||||||
|
// await grid.cell.verifyQrCodeCell({
|
||||||
|
// index: i,
|
||||||
|
// columnHeader: qrColumnTitle,
|
||||||
|
// expectedSrcValue: expectedQrCodeData[i].base64EncodedSrc,
|
||||||
|
// });
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
test('creation, showing, updating value and change barcode column title and reference column', 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: ExpectedQrCodeData[] = [
|
||||||
|
// {
|
||||||
|
// referencedValue: 'A Corua (La Corua)',
|
||||||
|
// base64EncodedSrc:
|
||||||
|
// '',
|
||||||
|
// },
|
||||||
|
// {
|
||||||
|
// referencedValue: 'Abha',
|
||||||
|
// base64EncodedSrc:
|
||||||
|
// '',
|
||||||
|
// },
|
||||||
|
// {
|
||||||
|
// referencedValue: 'Abu Dhabi',
|
||||||
|
// base64EncodedSrc:
|
||||||
|
// '',
|
||||||
|
// },
|
||||||
|
// ];
|
||||||
|
|
||||||
|
// close 'Team & Auth' tab
|
||||||
|
await dashboard.closeTab({ title: 'Team & Auth' }); |
||||||
|
|
||||||
|
await dashboard.treeView.openTable({ title: 'City' }); |
||||||
|
|
||||||
|
await grid.column.create({ |
||||||
|
title: 'Barcode1', |
||||||
|
type: 'Barcode', |
||||||
|
barcodeValueColumnTitle: 'City', |
||||||
|
}); |
||||||
|
const FOO = await grid.cell.get({ index: 0, columnHeader: 'Barcode1' }); |
||||||
|
const SVG = await FOO.locator('svg').innerHTML(); |
||||||
|
expect(SVG).toEqual(ONE_SVG_BARCODE_HTML); |
||||||
|
// const INNERHTML = await SVG.innerHTML();
|
||||||
|
// console.log('INNERHTML');
|
||||||
|
// console.log(INNERHTML);
|
||||||
|
}); |
||||||
|
}); |
||||||
|
}); |
Loading…
Reference in new issue