* A first, maybe working cypress test Plus cypress plugins to manage synapses in docker containers * Fix yaml * This file is important * try & find where it's put the artifact * Download artifact to a directory * pics or it didn't happen * Add conditional, otherwise no artifacts on failure... * Try increasing timeout also actually give the test a name * Try in chrome * Get docker logs to see why it's failing also document the chrome setting * Try changing mode on homeserver.yaml * debug * More debugging * more file permissions debugging * ARGH * more debug * sigh * Eugh, that's not how arguments work * Add the option to really allow open registration and remove debug logging / comment fixes * failure to yaml * Upload docker logs as artifacts and temporarily remove contional to test * Put the conditional back * Upgrade types in end to end tests to be compatible with fs-extra types * Try reducing timeout a bit also make password more... sensible * Hex is not octal * Remove file mode Seems to be unnecessary since the signing key is perfectly fine * Give the log files extensions * Rename workflow file now it also does tests * Add cypress scripts * copyright headers * Use ? operator Co-authored-by: Travis Ralston <travisr@matrix.org> * Use develop synapse image * Tidy up any remaining synapses after each spec run Also: * Move the synapseStart / synapseStop functions out to the top level so they can be reused * Add a tsconfig file * Give the containers names * Don't upload video on test pass We don't upload it anyway so tell cypress not to so it can not bother encoding them * Enable linting on cypress files and fix existing lint errors * Type check cypress files and make it pass the type checks, specifically: * Upgrade sinon fake timers to a version that has the right types * Set module resolution * Type check cypress files separately * Rename workflow file again Probably better to just call it an element web build * Don't plus + characters in container name * Fix yaml * Stream logs to file * Add note to end to end tester to sya what's been ported * Put docker rm in finally block Co-authored-by: Travis Ralston <travisr@matrix.org>
96 lines
4.4 KiB
TypeScript
96 lines
4.4 KiB
TypeScript
/*
|
|
Copyright 2018 New Vector Ltd
|
|
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.
|
|
*/
|
|
|
|
import { range } from './util';
|
|
import { signup } from './usecases/signup';
|
|
import { toastScenarios } from './scenarios/toast';
|
|
import { roomDirectoryScenarios } from './scenarios/directory';
|
|
import { lazyLoadingScenarios } from './scenarios/lazy-loading';
|
|
import { e2eEncryptionScenarios } from './scenarios/e2e-encryption';
|
|
import { ElementSession } from "./session";
|
|
import { RestSessionCreator } from "./rest/creator";
|
|
import { RestMultiSession } from "./rest/multi";
|
|
import { spacesScenarios } from './scenarios/spaces';
|
|
import { RestSession } from "./rest/session";
|
|
import { stickerScenarios } from './scenarios/sticker';
|
|
import { userViewScenarios } from "./scenarios/user-view";
|
|
import { ssoCustomisationScenarios } from "./scenarios/sso-customisations";
|
|
import { updateScenarios } from "./scenarios/update";
|
|
import { threadsScenarios } from "./scenarios/threads";
|
|
import { enableThreads } from "./usecases/threads";
|
|
|
|
export async function scenario(createSession: (s: string) => Promise<ElementSession>,
|
|
restCreator: RestSessionCreator): Promise<void> {
|
|
let firstUser = true;
|
|
async function createUser(username) {
|
|
const session = await createSession(username);
|
|
if (firstUser) {
|
|
// only show browser version for first browser opened
|
|
console.log(`running tests on ${await session.browser.version()} ...`);
|
|
firstUser = false;
|
|
}
|
|
// ported to cyprus (registration test)
|
|
await signup(session, session.username, 'testsarefun!!!', session.hsUrl);
|
|
return session;
|
|
}
|
|
|
|
const alice = await createUser("alice");
|
|
const bob = await createUser("bob");
|
|
|
|
// Enable threads for Alice & Bob before going any further as it requires refreshing the app
|
|
// which otherwise loses all performance ticks.
|
|
console.log("Enabling threads: ");
|
|
await enableThreads(alice);
|
|
await enableThreads(bob);
|
|
|
|
await toastScenarios(alice, bob);
|
|
await userViewScenarios(alice, bob);
|
|
await roomDirectoryScenarios(alice, bob);
|
|
await e2eEncryptionScenarios(alice, bob);
|
|
console.log("create REST users:");
|
|
const charlies = await createRestUsers(restCreator);
|
|
await lazyLoadingScenarios(alice, bob, charlies);
|
|
await threadsScenarios(alice, bob);
|
|
// do spaces scenarios last as the rest of the alice/bob tests may get confused by spaces
|
|
await spacesScenarios(alice, bob);
|
|
|
|
// we spawn another session for stickers, partially because it involves injecting
|
|
// a custom sticker picker widget for the account, although mostly because for these
|
|
// tests to scale, they probably need to be split up more, which means running each
|
|
// scenario with it's own session (and will make it easier to find relevant logs),
|
|
// so lets move in this direction (although at some point we'll also need to start
|
|
// closing them as we go rather than leaving them all open until the end).
|
|
const stickerSession = await createSession("sally");
|
|
await stickerScenarios("sally", "ilikestickers", stickerSession, restCreator);
|
|
|
|
// we spawn yet another session for SSO stuff because it involves authentication and
|
|
// logout, which can/does affect other tests dramatically. See notes above regarding
|
|
// stickers for the performance loss of doing this.
|
|
const ssoSession = await createUser("enterprise_erin");
|
|
await ssoCustomisationScenarios(ssoSession);
|
|
|
|
// Create a new window to test app auto-updating
|
|
const updateSession = await createSession("update");
|
|
await updateScenarios(updateSession);
|
|
}
|
|
|
|
async function createRestUsers(restCreator: RestSessionCreator): Promise<RestMultiSession> {
|
|
const usernames = range(1, 10).map((i) => `charly-${i}`);
|
|
const charlies = await restCreator.createSessionRange(usernames, "testtest", "charly-1..10");
|
|
await charlies.setDisplayName((s: RestSession) => `Charly #${s.userName().split('-')[1]}`);
|
|
return charlies;
|
|
}
|