mirror of https://github.com/nocodb/nocodb
Raju Udava
2 years ago
committed by
Muhammed Mustafa
6 changed files with 199 additions and 13 deletions
@ -0,0 +1,118 @@
|
||||
import { test } from "@playwright/test"; |
||||
import { DashboardPage } from "../pages/Dashboard"; |
||||
import setup from "../setup"; |
||||
|
||||
test.describe("LTAR create & update", () => { |
||||
let dashboard: DashboardPage; |
||||
let context: any; |
||||
|
||||
test.beforeEach(async ({ page }) => { |
||||
context = await setup({ page }); |
||||
dashboard = new DashboardPage(page, context.project); |
||||
}); |
||||
|
||||
test("LTAR", async () => { |
||||
// close 'Team & Auth' tab
|
||||
await dashboard.closeTab({ title: "Team & Auth" }); |
||||
|
||||
await dashboard.treeView.createTable({ title: "Sheet1" }); |
||||
// subsequent table creation fails; hence delay
|
||||
await dashboard.rootPage.waitForTimeout(1000); |
||||
await dashboard.treeView.createTable({ title: "Sheet2" }); |
||||
|
||||
await dashboard.treeView.openTable({ title: "Sheet1" }); |
||||
await dashboard.grid.addNewRow({ index: 0, value: "1a" }); |
||||
await dashboard.grid.addNewRow({ index: 1, value: "1b" }); |
||||
await dashboard.grid.addNewRow({ index: 2, value: "1c" }); |
||||
|
||||
// Create LTAR-HM column
|
||||
await dashboard.grid.column.create({ |
||||
title: "Link1-2hm", |
||||
type: "LinkToAnotherRecord", |
||||
childTable: "Sheet2", |
||||
relationType: "Has Many", |
||||
}); |
||||
await dashboard.grid.column.create({ |
||||
title: "Link1-2mm", |
||||
type: "LinkToAnotherRecord", |
||||
childTable: "Sheet2", |
||||
relationType: "Many To many", |
||||
}); |
||||
await dashboard.closeTab({ title: "Sheet1" }); |
||||
|
||||
await dashboard.treeView.openTable({ title: "Sheet2" }); |
||||
await dashboard.grid.column.create({ |
||||
title: "Link2-1hm", |
||||
type: "LinkToAnotherRecord", |
||||
childTable: "Sheet1", |
||||
relationType: "Has Many", |
||||
}); |
||||
|
||||
// Sheet2 now has all 3 column categories : HM, BT, MM
|
||||
//
|
||||
|
||||
// Expanded form insert
|
||||
|
||||
await dashboard.grid.toolbar.clickAddNewRow(); |
||||
await dashboard.expandedForm.fillField({ |
||||
columnTitle: "Title", |
||||
value: "2a", |
||||
}); |
||||
await dashboard.expandedForm.fillField({ |
||||
columnTitle: "Sheet1", |
||||
value: "1a", |
||||
type: "belongsTo", |
||||
}); |
||||
await dashboard.expandedForm.fillField({ |
||||
columnTitle: "Sheet1 List", |
||||
value: "1a", |
||||
type: "manyToMany", |
||||
}); |
||||
await dashboard.expandedForm.fillField({ |
||||
columnTitle: "Link2-1hm", |
||||
value: "1a", |
||||
type: "hasMany", |
||||
}); |
||||
await dashboard.expandedForm.save(); |
||||
|
||||
// In cell insert
|
||||
await dashboard.grid.addNewRow({ index: 1, value: "2b" }); |
||||
await dashboard.grid.cell.inCellAdd({ index: 1, columnHeader: "Sheet1" }); |
||||
await dashboard.linkRecord.select("1b"); |
||||
await dashboard.grid.cell.inCellAdd({ |
||||
index: 1, |
||||
columnHeader: "Sheet1 List", |
||||
}); |
||||
await dashboard.linkRecord.select("1b"); |
||||
await dashboard.grid.cell.inCellAdd({ |
||||
index: 1, |
||||
columnHeader: "Link2-1hm", |
||||
}); |
||||
await dashboard.linkRecord.select("1b"); |
||||
|
||||
// Expand record insert
|
||||
await dashboard.grid.addNewRow({ index: 2, value: "2c-temp" }); |
||||
await dashboard.grid.openExpandedRow({ index: 2 }); |
||||
await dashboard.expandedForm.fillField({ |
||||
columnTitle: "Sheet1", |
||||
value: "1c", |
||||
type: "belongsTo", |
||||
}); |
||||
await dashboard.expandedForm.fillField({ |
||||
columnTitle: "Sheet1 List", |
||||
value: "1c", |
||||
type: "manyToMany", |
||||
}); |
||||
await dashboard.expandedForm.fillField({ |
||||
columnTitle: "Link2-1hm", |
||||
value: "1c", |
||||
type: "hasMany", |
||||
}); |
||||
await dashboard.expandedForm.fillField({ |
||||
columnTitle: "Title", |
||||
value: "2c", |
||||
type: "text", |
||||
}); |
||||
await dashboard.expandedForm.save(); |
||||
}); |
||||
}); |
Loading…
Reference in new issue