
* [Feature Flags] Abstraction over flags provider (#2928) * Remove useFlag hook * [Feature Flags] GraphQL build multiple schemas (#2937) * Build script * Refactor build types script * Remove old codegen.yml * Clean feature flags in script * Refactor schema path * Restore useAuthProvider * Update configuration file * encapsulate details for feature flags provider * Add proper env to flagsmith provider * Remove flagsmith mocks * Vite config define global variables * Render flagmisth provider only when is used * Keep name service agnostic * Test with mocked flagsmith * Use global FLAGS varaible for env flags * Fix type issue with FLAGS * Fix build issue * Remove duplicate translations * Fix typo * Prepare for QA tests * Remove test feature flag
83 lines
2.3 KiB
JavaScript
83 lines
2.3 KiB
JavaScript
/// <reference types="cypress"/>
|
|
/// <reference types="../../support"/>
|
|
|
|
import faker from "faker";
|
|
|
|
import {
|
|
createMenu as createMenuViaApi,
|
|
getMenu,
|
|
} from "../../support/api/requests/Menu";
|
|
import { deleteMenusStartsWith } from "../../support/api/utils/navigationUtils";
|
|
import {
|
|
createMenu,
|
|
createNewMenuItem,
|
|
MENU_ITEM_TYPES,
|
|
} from "../../support/pages/navigationPage";
|
|
|
|
describe("Tests for menu navigation", () => {
|
|
const startsWith = "Navigation";
|
|
const randomName = `${startsWith}${faker.datatype.number()}`;
|
|
let testCase = 1301;
|
|
|
|
let menu;
|
|
|
|
before(() => {
|
|
cy.clearSessionData().loginUserViaRequest();
|
|
deleteMenusStartsWith(startsWith);
|
|
createMenuViaApi(randomName).then(({ menu: menuResp }) => {
|
|
menu = menuResp;
|
|
cy.checkIfDataAreNotNull(menu);
|
|
});
|
|
});
|
|
|
|
beforeEach(() => {
|
|
cy.clearSessionData().loginUserViaRequest();
|
|
});
|
|
|
|
it(
|
|
"should create a menu. TC: SALEOR_1301",
|
|
{ tags: ["@menuNavigation", "@allEnv", "@stable"] },
|
|
() => {
|
|
const name = `${startsWith}${faker.datatype.number()}`;
|
|
|
|
createMenu(name)
|
|
.then(menuResp => {
|
|
getMenu(menuResp.id);
|
|
})
|
|
.then(menuResp => {
|
|
expect(menuResp.name).to.eq(name);
|
|
});
|
|
},
|
|
);
|
|
|
|
["category", "collection", "page"].forEach(itemType => {
|
|
testCase += 1;
|
|
it(
|
|
`should add new ${itemType} item to menu. TC: SALEOR_${testCase}`,
|
|
{ tags: ["@menuNavigation", "@allEnv", "@stable"] },
|
|
() => {
|
|
const itemName = `${startsWith}${faker.datatype.number()}`;
|
|
let selectedItem;
|
|
|
|
cy.addAliasToGraphRequest("SearchCategories")
|
|
.addAliasToGraphRequest("SearchPages")
|
|
.addAliasToGraphRequest("SearchCollections");
|
|
createNewMenuItem({
|
|
menuId: menu.id,
|
|
name: itemName,
|
|
menuItemType: MENU_ITEM_TYPES[itemType],
|
|
})
|
|
.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);
|
|
});
|
|
},
|
|
);
|
|
});
|
|
});
|