keycloak-scim/cypress/integration/partial_import_test.spec.ts

96 lines
3.4 KiB
TypeScript
Raw Normal View History

import CreateRealmPage from "../support/pages/admin_console/CreateRealmPage";
import SidebarPage from "../support/pages/admin_console/SidebarPage";
import LoginPage from "../support/pages/LoginPage";
import PartialImportModal from "../support/pages/admin_console/configure/realm_settings/PartialImportModal";
import RealmSettings from "../support/pages/admin_console/configure/realm_settings/RealmSettings";
import { keycloakBefore } from "../support/util/keycloak_before";
import AdminClient from "../support/util/AdminClient";
describe("Partial import test", () => {
const TEST_REALM = "partial-import-test-realm";
const loginPage = new LoginPage();
const sidebarPage = new SidebarPage();
const createRealmPage = new CreateRealmPage();
const modal = new PartialImportModal();
const realmSettings = new RealmSettings();
beforeEach(() => {
keycloakBefore();
loginPage.logIn();
// doing this from the UI has the added bonus of putting you in the test realm
sidebarPage.goToCreateRealm();
createRealmPage.fillRealmName(TEST_REALM).createRealm();
sidebarPage.goToRealmSettings();
realmSettings.clickActionMenu();
});
afterEach(async () => {
const client = new AdminClient();
await client.deleteRealm(TEST_REALM);
});
it("Opens and closes partial import dialog", () => {
modal.open();
modal.importButton().should("be.disabled");
modal.cancelButton().click();
modal.importButton().should("not.exist");
});
it("Import button only enabled if JSON has something to import", () => {
modal.open();
cy.get("#partial-import-file").type("{}");
modal.importButton().should("be.disabled");
});
it("Displays user options after multi-realm import", () => {
modal.open();
modal.typeResourceFile("multi-realm.json");
// Import button should be disabled if no checkboxes selected
modal.importButton().should("be.disabled");
modal.usersCheckbox().click();
modal.importButton().should("be.enabled");
modal.groupsCheckbox().click();
modal.importButton().should("be.enabled");
modal.groupsCheckbox().click();
modal.usersCheckbox().click();
modal.importButton().should("be.disabled");
// verify resource counts
modal.userCount().contains("1 users");
modal.groupCount().contains("1 groups");
modal.clientCount().contains("1 clients");
modal.idpCount().contains("1 identity providers");
modal.realmRolesCount().contains("2 realm roles");
modal.clientRolesCount().contains("1 client roles");
// import button should disable when switching realms
modal.usersCheckbox().click();
modal.importButton().should("be.enabled");
modal.selectRealm("realm2");
modal.importButton().should("be.disabled");
modal.clientCount().contains("2 clients");
});
it("Displays user options after realmless import", () => {
modal.open();
modal.typeResourceFile("client-only.json");
modal.realmSelector().should("not.exist");
modal.clientCount().contains("1 clients");
modal.userCount().should("not.exist");
modal.groupCount().should("not.exist");
modal.idpCount().should("not.exist");
modal.realmRolesCount().should("not.exist");
modal.clientRolesCount().should("not.exist");
});
// Unfortunately, the PatternFly FileUpload component does not create an id for the clear button. So we can't easily test that function right now.
});