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.
331 lines
10 KiB
331 lines
10 KiB
import { mainPage, settingsPage } from "../../support/page_objects/mainPage"; |
|
import { roles } from "../../support/page_objects/projectConstants"; |
|
|
|
// Left hand navigation bar, validation for |
|
// 1. Audit menu |
|
// 2. Advance settings menu |
|
// 3. Preview mode menu |
|
// |
|
export function _advSettings(roleType, mode) { |
|
cy.log(roleType, mode); |
|
|
|
if (mode === "baseShare") { |
|
// open modal |
|
cy.get(".nc-project-menu").should("exist").click(); |
|
cy.getActiveMenu(".nc-dropdown-project-menu") |
|
.find(`[data-menu-id="language"]`) |
|
.should("exist"); |
|
|
|
// click again to close modal |
|
cy.get(".nc-project-menu").should("exist").click(); |
|
return; |
|
} |
|
|
|
let validationString = |
|
true == roles[roleType].validations.advSettings ? "exist" : "not.exist"; |
|
|
|
// cy.get(".nc-team-settings").should(validationString); |
|
cy.get(".nc-project-menu").should("exist").click(); |
|
cy.getActiveMenu(".nc-dropdown-project-menu") |
|
.find(`[data-menu-id="preview-as"]`) |
|
.should(validationString); |
|
cy.getActiveMenu(".nc-dropdown-project-menu") |
|
.find(`[data-menu-id="teamAndSettings"]:visible`) |
|
.should(validationString); |
|
|
|
if (true === roles[roleType].validations.advSettings) { |
|
cy.getActiveMenu(".nc-dropdown-project-menu") |
|
.find(`[data-menu-id="teamAndSettings"]:visible`) |
|
.should(validationString) |
|
.click(); |
|
|
|
cy.get(`[data-menu-id="teamAndAuth"]`).should("exist"); |
|
if (roleType === "owner") |
|
cy.get(`[data-menu-id="appStore"]`).should("exist"); |
|
cy.get(`[data-menu-id="projMetaData"]`).should("exist"); |
|
cy.get(`[data-menu-id="audit"]`).should("exist"); |
|
|
|
settingsPage.closeMenu(); |
|
} else { |
|
cy.get(".nc-project-menu").should("exist").click(); |
|
} |
|
|
|
// float menu in preview mode |
|
if ("preview" === mode) { |
|
cy.get(".nc-floating-preview-btn").should("exist"); |
|
cy.get(".nc-floating-preview-btn") |
|
.find(`[type="radio"][value="${roles[roleType].name}"]`) |
|
.should("be.checked"); |
|
} |
|
|
|
// cy.get("body").click("bottomRight"); |
|
} |
|
|
|
export function _editSchema(roleType, mode) { |
|
let columnName = "City"; |
|
let validationString = |
|
true === roles[roleType].validations.editSchema ? "exist" : "not.exist"; |
|
|
|
cy.openTableTab(columnName, 25); |
|
|
|
// create table |
|
cy.get(`.nc-add-new-table`).should(validationString); |
|
|
|
// delete table option |
|
cy.get(`.nc-project-tree-tbl-City`).should("exist").rightclick(); |
|
cy.get(".ant-dropdown-content:visible").should(validationString); |
|
|
|
if (validationString === "exist") { |
|
cy.getActiveMenu(".nc-dropdown-tree-view-context-menu") |
|
.find('[role="menuitem"]') |
|
.contains("Delete") |
|
.should("exist"); |
|
cy.getActiveMenu(".nc-dropdown-tree-view-context-menu") |
|
.find('[role="menuitem"]') |
|
.contains("Rename") |
|
.should("exist"); |
|
|
|
// click on a cell to close table context menu |
|
mainPage.getCell(columnName, 3).click(); |
|
} |
|
|
|
// add new column option |
|
// |
|
cy.get(".nc-column-add").should(validationString); |
|
|
|
// update column (edit/ delete menu) |
|
cy.get(".nc-ui-dt-dropdown").should(validationString); |
|
|
|
if (validationString === "exist") { |
|
cy.get(".nc-import-menu").should("exist").click(); |
|
cy.getActiveMenu(".nc-dropdown-import-menu").should("exist"); |
|
cy.getActiveMenu(".nc-dropdown-import-menu") |
|
.find(".ant-dropdown-menu-item") |
|
.contains("Airtable"); |
|
cy.getActiveMenu(".nc-dropdown-import-menu") |
|
.find(".ant-dropdown-menu-item") |
|
.contains("CSV file"); |
|
cy.getActiveMenu(".nc-dropdown-import-menu") |
|
.find(".ant-dropdown-menu-item") |
|
.contains("JSON file"); |
|
cy.getActiveMenu(".nc-dropdown-import-menu") |
|
.find(".ant-dropdown-menu-item") |
|
.contains("Microsoft Excel"); |
|
} |
|
} |
|
|
|
export function _editData(roleType, mode) { |
|
let columnName = "City"; |
|
let validationString = |
|
true === roles[roleType].validations.editData ? "exist" : "not.exist"; |
|
|
|
cy.openTableTab(columnName, 25); |
|
|
|
// add row button |
|
cy.get(".nc-add-new-row-btn:visible").should(validationString); |
|
|
|
// add button at bottom of page |
|
mainPage.getCell(columnName, 25).scrollIntoView(); |
|
cy.get(".nc-grid-add-new-cell:visible").should(validationString); |
|
|
|
// update row option (right click) |
|
// |
|
mainPage.getCell("City", 5).rightclick(); |
|
cy.wait(100); |
|
cy.get(".ant-dropdown-content:visible").should(validationString); |
|
|
|
if (validationString === "exist") { |
|
// right click options will exist (only for 'exist' case) |
|
// |
|
cy.getActiveMenu(".nc-dropdown-grid-context-menu") |
|
.contains("Insert New Row") |
|
.should(validationString); |
|
cy.getActiveMenu(".nc-dropdown-grid-context-menu") |
|
.contains("Clear cell") |
|
.should(validationString); |
|
cy.getActiveMenu(".nc-dropdown-grid-context-menu") |
|
.contains("Delete Row") |
|
.should(validationString); |
|
cy.getActiveMenu(".nc-dropdown-grid-context-menu") |
|
.contains("Delete Selected Rows") |
|
.should(validationString); |
|
|
|
// cy.get("body").type("{esc}"); |
|
mainPage.getCell("City", 13).click(); |
|
|
|
// update cell contents option using row expander should be enabled |
|
// |
|
mainPage |
|
.getRow(1) |
|
.find(".nc-row-no") |
|
.should("exist") |
|
.eq(0) |
|
.trigger("mouseover", { force: true }); |
|
cy.get(".nc-row-expand").should("exist").eq(10).click({ force: true }); |
|
cy.getActiveDrawer(".nc-drawer-expanded-form") |
|
.find("button") |
|
.contains("Save row") |
|
.should("exist"); |
|
cy.getActiveDrawer(".nc-drawer-expanded-form") |
|
.find("button") |
|
.contains("Cancel") |
|
.should("exist") |
|
.click(); |
|
} else { |
|
// update cell contents option using row expander should be disabled |
|
// |
|
cy.get(".nc-row-expand").should("exist").eq(10).click({ force: true }); |
|
cy.getActiveDrawer(".nc-drawer-expanded-form") |
|
.find("button:disabled") |
|
.contains("Save row") |
|
.should("exist"); |
|
cy.getActiveDrawer(".nc-drawer-expanded-form") |
|
.find("button") |
|
.contains("Cancel") |
|
.should("exist") |
|
.click(); |
|
} |
|
|
|
// double click cell entries to edit |
|
// |
|
mainPage.getCell("City", 5).dblclick().find("input").should(validationString); |
|
} |
|
|
|
// read &/ update comment |
|
// Viewer: only allowed to read |
|
// Everyone else: read &/ update |
|
// |
|
export function _editComment(roleType, mode) { |
|
let columnName = "City"; |
|
let validationString = |
|
true === roles[roleType].validations.editComment |
|
? "Comment added successfully" |
|
: "Not allowed"; |
|
|
|
cy.openTableTab(columnName, 25); |
|
|
|
// click on comment icon & type comment |
|
// |
|
cy.get(".nc-row-expand").should("exist").eq(10).click({ force: true }); |
|
|
|
// Expected response: |
|
// Viewer: Not able to see comment option |
|
// Everyone else: Comment added/read successfully |
|
// |
|
|
|
if ("viewer" === roleType) { |
|
cy.getActiveDrawer(".nc-drawer-expanded-form") |
|
.should("exist") |
|
.find(".nc-toggle-comments") |
|
.should("not.exist"); |
|
} else { |
|
cy.getActiveDrawer(".nc-drawer-expanded-form") |
|
.should("exist") |
|
.find(".nc-toggle-comments") |
|
.should("exist") |
|
.click(); |
|
|
|
cy.getActiveDrawer(".nc-drawer-expanded-form") |
|
.find(".nc-comment-box") |
|
.should("exist") |
|
.type("Comment-1{enter}"); |
|
// cy.toastWait('Comment added successfully') |
|
cy.getActiveDrawer(".nc-drawer-expanded-form") |
|
.find(".nc-toggle-comments") |
|
.click(); |
|
} |
|
|
|
cy.getActiveDrawer(".nc-drawer-expanded-form") |
|
.find("button") |
|
.contains("Cancel") |
|
.should("exist") |
|
.click(); |
|
} |
|
|
|
// right navigation menu bar |
|
// Editor/Viewer/Commenter : can only view 'existing' views |
|
// Rest: can create/edit |
|
export function _viewMenu(roleType, mode) { |
|
let columnName = "City"; |
|
|
|
// Lock, Download, Upload |
|
let menuWithSubmenuCount = 3; |
|
|
|
// share view list, webhook, api snippet, erd |
|
let menuWithoutSubmenuCount = 4; |
|
|
|
cy.openTableTab(columnName, 25); |
|
|
|
let validationString = |
|
true === roles[roleType].validations.shareView ? "exist" : "not.exist"; |
|
|
|
if (roleType === "editor") { |
|
// Download / Upload CSV |
|
menuWithSubmenuCount = 2; |
|
// Get API Snippet and ERD |
|
menuWithoutSubmenuCount = 2; |
|
// ERD |
|
if (mode === "baseShare") menuWithoutSubmenuCount = 1; |
|
} else if (roleType === "commenter" || roleType === "viewer") { |
|
// Download CSV & Download excel |
|
menuWithSubmenuCount = 0; |
|
// Get API Snippet and ERD |
|
menuWithoutSubmenuCount = 2; |
|
} |
|
|
|
// view list field (default GRID view) |
|
cy.get(`.nc-view-item`).should("exist"); |
|
|
|
// view create option, exists only for owner/ creator |
|
cy.get(`.nc-create-grid-view`).should(validationString); |
|
cy.get(`.nc-create-gallery-view`).should(validationString); |
|
cy.get(`.nc-create-form-view`).should(validationString); |
|
|
|
// share view permissions are role specific |
|
|
|
// actions menu (more), only download csv should be visible for non-previlaged users |
|
cy.get(".nc-actions-menu-btn").click(); |
|
cy.getActiveMenu(".nc-dropdown-actions-menu") |
|
.find(".ant-dropdown-menu-submenu:visible") |
|
.should("have.length", menuWithSubmenuCount); |
|
cy.getActiveMenu(".nc-dropdown-actions-menu") |
|
.find(".ant-dropdown-menu-item:visible") |
|
.should("have.length", menuWithoutSubmenuCount); |
|
// click again to close menu |
|
cy.get(".nc-actions-menu-btn").click(); |
|
} |
|
|
|
export function _topRightMenu(roleType, mode) { |
|
// kludge; download csv menu persists until clicked |
|
let columnName = "City"; |
|
// cy.closeTableTab(columnName); |
|
// cy.openTableTab(columnName, 25); |
|
|
|
let validationString = |
|
true == roles[roleType].validations.shareView ? "exist" : "not.exist"; |
|
|
|
cy.get(`.nc-share-base`).should(validationString); |
|
cy.get(".nc-menu-translate").should("exist"); |
|
cy.get(".nc-menu-accounts").should("exist"); |
|
} |
|
|
|
// Access control list |
|
// |
|
export function disableTableAccess(tbl, role) { |
|
const cls = `.nc-acl-${tbl}-${role}-chkbox`; |
|
cy.get(cls).find("input").should("be.checked").click({ force: true }); |
|
cy.get(cls).find("input").should("not.be.checked"); |
|
} |
|
|
|
export function enableTableAccess(tbl, role) { |
|
const cls = `.nc-acl-${tbl}-${role}-chkbox`; |
|
cy.get(cls).find("input").should("not.be.checked").click({ force: true }); |
|
cy.get(cls).find("input").should("be.checked"); |
|
} |
|
|
|
export function _accessControl(roleType, previewMode) { |
|
let validationString = roleType === "creator" ? "exist" : "not.exist"; |
|
|
|
cy.get(`.nc-project-tree-tbl-Language`).should(validationString); |
|
cy.get(`.nc-project-tree-tbl-CustomerList`).should(validationString); |
|
}
|
|
|