* Install playwright Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Add foundations for writing tests under Playwright Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * .gitignore juggling Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Add tsconfig and fix eslint rules Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Add docker & synapse plugins Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Add login.spec.ts Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Wire up fixture which sets up ElementAppPage & bakes config.json Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Remove launch test, it has served its purpose Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Remove test which has been ported to Playwright Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Fix test not cleaning up after itself Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Move registerUser to the Homeserver interface Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Remove unused fixture param Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Remove redundant launch test Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> * Add newline --------- Signed-off-by: Michael Telatynski <7t3chguy@gmail.com> Co-authored-by: R Midhun Suresh <hi@midhun.dev>
103 lines
3.8 KiB
TypeScript
103 lines
3.8 KiB
TypeScript
/*
|
|
Copyright 2022 The Matrix.org Foundation C.I.C.
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
you may not use this file except in compliance with the License.
|
|
You may obtain a copy of the License at
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
*/
|
|
|
|
/// <reference types="cypress" />
|
|
|
|
import { HomeserverInstance } from "../../plugins/utils/homeserver";
|
|
import { doTokenRegistration } from "./utils";
|
|
|
|
describe("Login", () => {
|
|
let homeserver: HomeserverInstance;
|
|
|
|
afterEach(() => {
|
|
cy.stopHomeserver(homeserver);
|
|
});
|
|
|
|
// tests for old-style SSO login, in which we exchange tokens with Synapse, and Synapse talks to an auth server
|
|
describe("SSO login", () => {
|
|
beforeEach(() => {
|
|
cy.task("startOAuthServer")
|
|
.then((oAuthServerPort: number) => {
|
|
return cy.startHomeserver({ template: "default", oAuthServerPort });
|
|
})
|
|
.then((data) => {
|
|
homeserver = data;
|
|
});
|
|
});
|
|
|
|
afterEach(() => {
|
|
cy.task("stopOAuthServer");
|
|
});
|
|
|
|
it("logs in with SSO and lands on the home screen", () => {
|
|
// If this test fails with a screen showing "Timeout connecting to remote server", it is most likely due to
|
|
// your firewall settings: Synapse is unable to reach the OIDC server.
|
|
//
|
|
// If you are using ufw, try something like:
|
|
// sudo ufw allow in on docker0
|
|
//
|
|
doTokenRegistration(homeserver.baseUrl);
|
|
|
|
// Eventually, we should end up at the home screen.
|
|
cy.url().should("contain", "/#/home", { timeout: 30000 });
|
|
cy.findByRole("heading", { name: "Welcome Alice" });
|
|
});
|
|
});
|
|
|
|
describe("logout", () => {
|
|
beforeEach(() => {
|
|
cy.startHomeserver("consent").then((data) => {
|
|
homeserver = data;
|
|
cy.initTestUser(homeserver, "Erin");
|
|
});
|
|
});
|
|
|
|
it("should go to login page on logout", () => {
|
|
cy.findByRole("button", { name: "User menu" }).click();
|
|
|
|
// give a change for the outstanding requests queue to settle before logging out
|
|
cy.wait(2000);
|
|
|
|
cy.get(".mx_UserMenu_contextMenu").within(() => {
|
|
cy.findByRole("menuitem", { name: "Sign out" }).click();
|
|
});
|
|
|
|
cy.url().should("contain", "/#/login");
|
|
});
|
|
|
|
it("should respect logout_redirect_url", () => {
|
|
cy.tweakConfig({
|
|
// We redirect to decoder-ring because it's a predictable page that isn't Element itself.
|
|
// We could use example.org, matrix.org, or something else, however this puts dependency of external
|
|
// infrastructure on our tests. In the same vein, we don't really want to figure out how to ship a
|
|
// `test-landing.html` page when running with an uncontrolled Element (via `yarn start`).
|
|
// Using the decoder-ring is just as fine, and we can search for strategic names.
|
|
logout_redirect_url: "/decoder-ring/",
|
|
});
|
|
|
|
cy.findByRole("button", { name: "User menu" }).click();
|
|
|
|
// give a change for the outstanding requests queue to settle before logging out
|
|
cy.wait(2000);
|
|
|
|
cy.get(".mx_UserMenu_contextMenu").within(() => {
|
|
cy.findByRole("menuitem", { name: "Sign out" }).click();
|
|
});
|
|
|
|
cy.url().should("contains", "decoder-ring");
|
|
});
|
|
});
|
|
});
|