saleor-dashboard/cypress/e2e/configuration/navigation.js
poulch d5ed6fb202
Feature flags (#2961)
* [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
2023-01-16 14:55:38 +01:00

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);
});
},
);
});
});