mirror of https://github.com/nocodb/nocodb
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
81 lines
2.8 KiB
81 lines
2.8 KiB
import { expect, Locator } from '@playwright/test'; |
|
import BasePage from '../../Base'; |
|
import { DashboardPage } from '..'; |
|
import { getTextExcludeIconText } from '../../../tests/utils/general'; |
|
|
|
export class ImportTemplatePage extends BasePage { |
|
readonly dashboard: DashboardPage; |
|
readonly importButton: Locator; |
|
|
|
constructor(dashboard: DashboardPage) { |
|
super(dashboard.rootPage); |
|
this.dashboard = dashboard; |
|
this.importButton = dashboard.get().locator('.nc-btn-import'); |
|
} |
|
|
|
get() { |
|
return this.dashboard.get().locator(`.nc-modal-quick-import`); |
|
} |
|
|
|
async getImportTableList() { |
|
await this.get().locator(`.ant-collapse-header`).nth(0).waitFor(); |
|
const tr = this.get().locator(`.ant-collapse-header`); |
|
const rowCount = await tr.count(); |
|
const tableList: string[] = []; |
|
for (let i = 0; i < rowCount; i++) { |
|
const tableName = await this.get() |
|
.locator(`.ant-collapse-header`) |
|
.nth(i) |
|
.locator('input[type="text"]') |
|
.inputValue(); |
|
tableList.push(tableName); |
|
} |
|
return tableList; |
|
} |
|
|
|
async getImportColumnList() { |
|
// return an array |
|
const columnList: { type: string; name: string }[] = []; |
|
const tr = this.get().locator(`tr.ant-table-row-level-0:visible`); |
|
const rowCount = await tr.count(); |
|
for (let i = 0; i < rowCount; i++) { |
|
// replace \n and \t from innerText |
|
const columnType = (await getTextExcludeIconText(tr.nth(i))).replace(/\n|\t/g, ''); |
|
const columnName = await tr.nth(i).locator(`input[type="text"]`).inputValue(); |
|
columnList.push({ type: columnType, name: columnName }); |
|
} |
|
return columnList; |
|
} |
|
|
|
// todo: Add polling logic to assertions |
|
async import({ file, result }: { file: string; result: any }) { |
|
const importFile = this.get().locator(`input[type="file"]`); |
|
await importFile.setInputFiles(file); |
|
await this.importButton.click(); |
|
|
|
const tblList = await this.getImportTableList(); |
|
for (let i = 0; i < result.length; i++) { |
|
expect(tblList[i]).toBe(result[i].name); |
|
const columnList = await this.getImportColumnList(); |
|
expect(columnList).toEqual(result[i].columns); |
|
if (i < result.length - 1) { |
|
await this.expandTableList({ index: i + 1 }); |
|
} |
|
} |
|
|
|
await this.get().locator('button:has-text("Back"):visible').waitFor(); |
|
await this.waitForResponse({ |
|
requestUrlPathToMatch: '/api/v1/db/data/bulk/', |
|
httpMethodsToMatch: ['POST'], |
|
uiAction: () => this.get().locator('button:has-text("Import"):visible').click(), |
|
}); |
|
await this.dashboard.waitForTabRender({ |
|
title: tblList[0], |
|
}); |
|
} |
|
|
|
private async expandTableList(param: { index: number }) { |
|
await this.get().locator(`.ant-collapse-header`).nth(param.index).click(); |
|
await this.rootPage.waitForTimeout(1000); |
|
} |
|
}
|
|
|