web: test LDAP wizard sequence

This commit is contained in:
Ken Sternberg 2023-09-25 15:46:19 -07:00
parent 6457702f00
commit 7e6a9fd3d2
4 changed files with 42 additions and 10 deletions

View file

@ -8,7 +8,7 @@ help: ## Show this help
ROOT := $(shell git rev-parse --show-toplevel 2> /dev/null) ROOT := $(shell git rev-parse --show-toplevel 2> /dev/null)
WDIO = npm run wdio WDIO = npm run wdio
SPEC = $(WDIO) -- --spec ./test/specs SPEC = $(WDIO) -- --logLevel warn --spec ./test/specs
LOCAL_BLUEPRINTS=$(ROOT)/blueprints/local LOCAL_BLUEPRINTS=$(ROOT)/blueprints/local
@ -35,3 +35,7 @@ test-good-login: node_modules admin-user ## Test that we can log into the serve
test-bad-login: node_modules admin-user ## Test that bad usernames and passwords create appropriate error messages test-bad-login: node_modules admin-user ## Test that bad usernames and passwords create appropriate error messages
$(SPEC)/bad-logins.ts $(SPEC)/bad-logins.ts
test-application-wizard-ldap: node_modules admin-user
$(SPEC)/new-wizard-ldap-application.ts

View file

@ -17,7 +17,7 @@ class ApplicationWizardView extends AdminPage {
app = ApplicationForm; app = ApplicationForm;
get wizardTitle() { get wizardTitle() {
return $(">>>ak-application-wizard-commit-application h1.pf-c-title"); return $(">>>ak-wizard-frame .pf-c-wizard__header h1.pf-c-title");
} }
get providerList() { get providerList() {

View file

@ -1,12 +1,11 @@
import { login } from "../utils/login.js"; import { login } from "../utils/login.js";
import { randomId } from "../utils/index.js"; import { randomId } from "../utils/index.js";
import ApplicationsListPage from "../pageobjects/applications-list.page.js"; import ApplicationsListPage from "../pageobjects/applications-list.page.js";
import ApplicationsWizardView from "../pageobjects/applications-wizard.page.js"; import ApplicationWizardView from "../pageobjects/application-wizard.page.js";
import ApplicationForm from "../pageobjects/application-form.view.js";
import { expect } from "@wdio/globals"; import { expect } from "@wdio/globals";
describe("Log into Authentik", () => { describe("Configure LDAP Application with Wizard", () => {
it("should login with valid credentials and reach the UserLibrary", () => { it("Should configure a simple LDAP Application", async () => {
const newPrefix = randomId(); const newPrefix = randomId();
await login(); await login();
@ -14,9 +13,23 @@ describe("Log into Authentik", () => {
expect(await ApplicationsListPage.pageHeader).toHaveText("Applications"); expect(await ApplicationsListPage.pageHeader).toHaveText("Applications");
await ApplicationsListPage.startWizardButton.click(); await ApplicationsListPage.startWizardButton.click();
await ApplicationsWizardView.wizardTitle.toBeVisible(); await ApplicationWizardView.wizardTitle.waitForDisplayed();
expect(await ApplicationsWizardView.wizardTitle).toHaveText("Create Application"); expect(await ApplicationWizardView.wizardTitle).toHaveText("New Application");
await ApplicationForm.name.setValue(`New LDAP Application - ${newPrefix}`); await ApplicationWizardView.app.name.setValue(`New LDAP Application - ${newPrefix}`);
await ApplicationWizardView.nextButton.click();
await ApplicationWizardView.pause()
await ApplicationWizardView.providerList.waitForDisplayed();
await ApplicationWizardView.providerList.$('>>>input[value=ldapprovider]').click();
await ApplicationWizardView.nextButton.click();
await ApplicationWizardView.pause()
await ApplicationWizardView.ldap.setBindFlow('default-authentication-flow');
await ApplicationWizardView.nextButton.click();
await ApplicationWizardView.pause()
await ApplicationWizardView.commitMessage.waitForDisplayed();
expect(await ApplicationWizardView.commitMessage).toHaveText("Your application has been saved");
})
}); });

View file

@ -0,0 +1,15 @@
export function randomId() {
let dt = new Date().getTime();
return "xxxxxxxx".replace(/x/g, (c) => {
const r = (dt + Math.random() * 16) % 16 | 0;
dt = Math.floor(dt / 16);
return (c == "x" ? r : (r & 0x3) | 0x8).toString(16);
});
}
export function convertToSlug(text: string) {
return text
.toLowerCase()
.replace(/ /g, "-")
.replace(/[^\w-]+/g, "");
}