2021-09-27 10:04:21 +00:00
|
|
|
/// <reference types="cypress"/>
|
|
|
|
/// <reference types="../../support"/>
|
|
|
|
|
2021-07-23 09:46:44 +00:00
|
|
|
import faker from "faker";
|
|
|
|
|
|
|
|
import {
|
|
|
|
createMenu as createMenuViaApi,
|
2022-06-27 16:49:35 +00:00
|
|
|
getMenu,
|
2021-09-27 10:04:21 +00:00
|
|
|
} from "../../support/api/requests/Menu";
|
|
|
|
import { deleteMenusStartsWith } from "../../support/api/utils/navigationUtils";
|
2021-07-23 09:46:44 +00:00
|
|
|
import {
|
|
|
|
createMenu,
|
|
|
|
createNewMenuItem,
|
2022-06-27 16:49:35 +00:00
|
|
|
MENU_ITEM_TYPES,
|
2021-09-27 10:04:21 +00:00
|
|
|
} from "../../support/pages/navigationPage";
|
2021-07-23 09:46:44 +00:00
|
|
|
|
2022-06-27 09:30:51 +00:00
|
|
|
describe("Tests for menu navigation", () => {
|
|
|
|
const startsWith = "Navigation";
|
|
|
|
const randomName = `${startsWith}${faker.datatype.number()}`;
|
|
|
|
let testCase = 1301;
|
2021-07-23 09:46:44 +00:00
|
|
|
|
2022-06-27 09:30:51 +00:00
|
|
|
let menu;
|
2021-07-23 09:46:44 +00:00
|
|
|
|
2022-06-27 09:30:51 +00:00
|
|
|
before(() => {
|
|
|
|
cy.clearSessionData().loginUserViaRequest();
|
|
|
|
deleteMenusStartsWith(startsWith);
|
|
|
|
createMenuViaApi(randomName).then(
|
2023-01-16 09:43:13 +00:00
|
|
|
({ menu: menuResp }) => {
|
|
|
|
menu = menuResp
|
|
|
|
cy.checkIfDataAreNotNull(menu)
|
|
|
|
},
|
2022-06-27 09:30:51 +00:00
|
|
|
);
|
|
|
|
});
|
2021-07-23 09:46:44 +00:00
|
|
|
|
2022-06-27 09:30:51 +00:00
|
|
|
beforeEach(() => {
|
|
|
|
cy.clearSessionData().loginUserViaRequest();
|
|
|
|
});
|
2021-07-23 09:46:44 +00:00
|
|
|
|
2022-06-27 09:30:51 +00:00
|
|
|
it(
|
|
|
|
"should create a menu. TC: SALEOR_1301",
|
|
|
|
{ tags: ["@menuNavigation", "@allEnv", "@stable"] },
|
|
|
|
() => {
|
2021-07-23 09:46:44 +00:00
|
|
|
const name = `${startsWith}${faker.datatype.number()}`;
|
|
|
|
|
|
|
|
createMenu(name)
|
|
|
|
.then(menuResp => {
|
|
|
|
getMenu(menuResp.id);
|
|
|
|
})
|
|
|
|
.then(menuResp => {
|
|
|
|
expect(menuResp.name).to.eq(name);
|
|
|
|
});
|
2022-06-27 16:49:35 +00:00
|
|
|
},
|
2022-06-27 09:30:51 +00:00
|
|
|
);
|
2021-07-23 09:46:44 +00:00
|
|
|
|
2022-06-27 09:30:51 +00:00
|
|
|
["category", "collection", "page"].forEach(itemType => {
|
|
|
|
testCase += 1;
|
|
|
|
it(
|
|
|
|
`should add new ${itemType} item to menu. TC: SALEOR_${testCase}`,
|
|
|
|
{ tags: ["@menuNavigation", "@allEnv", "@stable"] },
|
|
|
|
() => {
|
2021-07-23 09:46:44 +00:00
|
|
|
const itemName = `${startsWith}${faker.datatype.number()}`;
|
|
|
|
let selectedItem;
|
|
|
|
|
2022-11-08 10:19:52 +00:00
|
|
|
cy.addAliasToGraphRequest("SearchCategories")
|
|
|
|
.addAliasToGraphRequest("SearchPages")
|
|
|
|
.addAliasToGraphRequest("SearchCollections");
|
2021-07-23 09:46:44 +00:00
|
|
|
createNewMenuItem({
|
|
|
|
menuId: menu.id,
|
|
|
|
name: itemName,
|
2022-06-27 16:49:35 +00:00
|
|
|
menuItemType: MENU_ITEM_TYPES[itemType],
|
2021-07-23 09:46:44 +00:00
|
|
|
})
|
|
|
|
.then(selectedItemResp => {
|
|
|
|
selectedItem = selectedItemResp;
|
|
|
|
getMenu(menu.id);
|
|
|
|
})
|
|
|
|
.then(({ items }) => {
|
|
|
|
const item = items.find(element => element.name === itemName);
|
|
|
|
const itemOfType = item[itemType];
|
|
|
|
const name = itemType !== "page" ? "name" : "title";
|
|
|
|
expect(itemOfType[name]).to.eq(selectedItem);
|
|
|
|
});
|
2022-06-27 16:49:35 +00:00
|
|
|
},
|
2022-06-27 09:30:51 +00:00
|
|
|
);
|
2021-07-23 09:46:44 +00:00
|
|
|
});
|
|
|
|
});
|