* stop e2e tests exploding if a circular datastructure is logged it's valid for the webapp to log datastructures to the console which happen to be circular but the e2e test running explodes badly with a runtime exception and bombs out before logging anything or providing a sensible stacktrace. you can trap the exception though and get a sensible error however. * don't barf on circular refs in return vals either and log timestamps * log timestamps * speed up roomDir & E2EE tests by 3x use timeouts correctly, so the first set of scenarios take 42s to run rather than 2m21s * speed up space test by 20s
82 lines
3.2 KiB
TypeScript
82 lines
3.2 KiB
TypeScript
/*
|
|
Copyright 2021 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 { ElementSession } from "../session";
|
|
|
|
export async function openSpaceCreateMenu(session: ElementSession): Promise<void> {
|
|
const spaceCreateButton = await session.query('.mx_SpaceButton_new');
|
|
await spaceCreateButton.click();
|
|
}
|
|
|
|
export async function createSpace(session: ElementSession, name: string, isPublic = false): Promise<void> {
|
|
session.log.step(`creates space "${name}"`);
|
|
|
|
await openSpaceCreateMenu(session);
|
|
const className = isPublic ? ".mx_SpaceCreateMenuType_public" : ".mx_SpaceCreateMenuType_private";
|
|
const visibilityButton = await session.query(className);
|
|
await visibilityButton.click();
|
|
|
|
const nameInput = await session.query('input[name="spaceName"]');
|
|
await session.replaceInputText(nameInput, name);
|
|
|
|
await session.delay(100);
|
|
|
|
const createButton = await session.query('.mx_SpaceCreateMenu_wrapper .mx_AccessibleButton_kind_primary');
|
|
await createButton.click();
|
|
|
|
if (!isPublic) {
|
|
const justMeButton = await session.query('.mx_SpaceRoomView_privateScope_justMeButton');
|
|
await justMeButton.click();
|
|
const continueButton = await session.query('.mx_AddExistingToSpace_footer .mx_AccessibleButton_kind_primary');
|
|
await continueButton.click();
|
|
} else {
|
|
for (let i = 0; i < 2; i++) {
|
|
const continueButton = await session.query('.mx_SpaceRoomView_buttons .mx_AccessibleButton_kind_primary');
|
|
await continueButton.click();
|
|
}
|
|
}
|
|
|
|
session.log.done();
|
|
}
|
|
|
|
export async function inviteSpace(session: ElementSession, spaceName: string, userId: string): Promise<void> {
|
|
session.log.step(`invites "${userId}" to space "${spaceName}"`);
|
|
|
|
const spaceButton = await session.query(`.mx_SpaceButton[aria-label="${spaceName}"]`);
|
|
await spaceButton.click({
|
|
button: 'right',
|
|
});
|
|
|
|
const inviteButton = await session.query('.mx_SpacePanel_contextMenu_inviteButton[aria-label="Invite"]');
|
|
await inviteButton.click();
|
|
|
|
try {
|
|
// You only get this interstitial if it's a public space, so give up after 200ms
|
|
// if it hasn't appeared
|
|
const button = await session.query('.mx_SpacePublicShare_inviteButton', 200);
|
|
await button.click();
|
|
} catch (e) {
|
|
// ignore
|
|
}
|
|
|
|
const inviteTextArea = await session.query(".mx_InviteDialog_editor input");
|
|
await inviteTextArea.type(userId);
|
|
const selectUserItem = await session.query(".mx_InviteDialog_roomTile");
|
|
await selectUserItem.click();
|
|
const confirmButton = await session.query(".mx_InviteDialog_goButton");
|
|
await confirmButton.click();
|
|
session.log.done();
|
|
}
|