fix lint
This commit is contained in:
parent
3e971e4880
commit
2d848bba29
25 changed files with 84 additions and 100 deletions
|
@ -21,10 +21,9 @@ module.exports = class LogBuffer {
|
||||||
const result = eventMapper(arg);
|
const result = eventMapper(arg);
|
||||||
if (reduceAsync) {
|
if (reduceAsync) {
|
||||||
result.then((r) => this.buffer += r);
|
result.then((r) => this.buffer += r);
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
this.buffer += result;
|
this.buffer += result;
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
};
|
||||||
|
|
|
@ -59,4 +59,4 @@ module.exports = class Logger {
|
||||||
this.muted = false;
|
this.muted = false;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
}
|
};
|
||||||
|
|
|
@ -57,13 +57,13 @@ module.exports = class RestSessionCreator {
|
||||||
`-u ${username}`,
|
`-u ${username}`,
|
||||||
`-p ${password}`,
|
`-p ${password}`,
|
||||||
'--no-admin',
|
'--no-admin',
|
||||||
this.hsUrl
|
this.hsUrl,
|
||||||
];
|
];
|
||||||
const registerCmd = `./register_new_matrix_user ${registerArgs.join(' ')}`;
|
const registerCmd = `./register_new_matrix_user ${registerArgs.join(' ')}`;
|
||||||
const allCmds = [
|
const allCmds = [
|
||||||
`cd ${this.synapseSubdir}`,
|
`cd ${this.synapseSubdir}`,
|
||||||
". ./activate",
|
". ./activate",
|
||||||
registerCmd
|
registerCmd,
|
||||||
].join(' && ');
|
].join(' && ');
|
||||||
|
|
||||||
await execAsync(allCmds, {cwd: this.cwd, encoding: 'utf-8'});
|
await execAsync(allCmds, {cwd: this.cwd, encoding: 'utf-8'});
|
||||||
|
@ -74,9 +74,9 @@ module.exports = class RestSessionCreator {
|
||||||
"type": "m.login.password",
|
"type": "m.login.password",
|
||||||
"identifier": {
|
"identifier": {
|
||||||
"type": "m.id.user",
|
"type": "m.id.user",
|
||||||
"user": username
|
"user": username,
|
||||||
},
|
},
|
||||||
"password": password
|
"password": password,
|
||||||
};
|
};
|
||||||
const url = `${this.hsUrl}/_matrix/client/r0/login`;
|
const url = `${this.hsUrl}/_matrix/client/r0/login`;
|
||||||
const responseBody = await request.post({url, json: true, body: requestBody});
|
const responseBody = await request.post({url, json: true, body: requestBody});
|
||||||
|
@ -88,4 +88,4 @@ module.exports = class RestSessionCreator {
|
||||||
hsUrl: this.hsUrl,
|
hsUrl: this.hsUrl,
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
}
|
};
|
||||||
|
|
|
@ -14,9 +14,6 @@ See the License for the specific language governing permissions and
|
||||||
limitations under the License.
|
limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
const request = require('request-promise-native');
|
|
||||||
const RestRoom = require('./room');
|
|
||||||
const {approveConsent} = require('./consent');
|
|
||||||
const Logger = require('../logger');
|
const Logger = require('../logger');
|
||||||
|
|
||||||
module.exports = class RestMultiSession {
|
module.exports = class RestMultiSession {
|
||||||
|
@ -31,7 +28,7 @@ module.exports = class RestMultiSession {
|
||||||
|
|
||||||
pop(userName) {
|
pop(userName) {
|
||||||
const idx = this.sessions.findIndex((s) => s.userName() === userName);
|
const idx = this.sessions.findIndex((s) => s.userName() === userName);
|
||||||
if(idx === -1) {
|
if (idx === -1) {
|
||||||
throw new Error(`user ${userName} not found`);
|
throw new Error(`user ${userName} not found`);
|
||||||
}
|
}
|
||||||
const session = this.sessions.splice(idx, 1)[0];
|
const session = this.sessions.splice(idx, 1)[0];
|
||||||
|
@ -39,7 +36,7 @@ module.exports = class RestMultiSession {
|
||||||
}
|
}
|
||||||
|
|
||||||
async setDisplayName(fn) {
|
async setDisplayName(fn) {
|
||||||
this.log.step("set their display name")
|
this.log.step("set their display name");
|
||||||
await Promise.all(this.sessions.map(async (s) => {
|
await Promise.all(this.sessions.map(async (s) => {
|
||||||
s.log.mute();
|
s.log.mute();
|
||||||
await s.setDisplayName(fn(s));
|
await s.setDisplayName(fn(s));
|
||||||
|
@ -49,7 +46,7 @@ module.exports = class RestMultiSession {
|
||||||
}
|
}
|
||||||
|
|
||||||
async join(roomIdOrAlias) {
|
async join(roomIdOrAlias) {
|
||||||
this.log.step(`join ${roomIdOrAlias}`)
|
this.log.step(`join ${roomIdOrAlias}`);
|
||||||
const rooms = await Promise.all(this.sessions.map(async (s) => {
|
const rooms = await Promise.all(this.sessions.map(async (s) => {
|
||||||
s.log.mute();
|
s.log.mute();
|
||||||
const room = await s.join(roomIdOrAlias);
|
const room = await s.join(roomIdOrAlias);
|
||||||
|
@ -64,7 +61,7 @@ module.exports = class RestMultiSession {
|
||||||
const rooms = this.sessions.map(s => s.room(roomIdOrAlias));
|
const rooms = this.sessions.map(s => s.room(roomIdOrAlias));
|
||||||
return new RestMultiRoom(rooms, roomIdOrAlias, this.log);
|
return new RestMultiRoom(rooms, roomIdOrAlias, this.log);
|
||||||
}
|
}
|
||||||
}
|
};
|
||||||
|
|
||||||
class RestMultiRoom {
|
class RestMultiRoom {
|
||||||
constructor(rooms, roomIdOrAlias, log) {
|
constructor(rooms, roomIdOrAlias, log) {
|
||||||
|
@ -74,7 +71,7 @@ class RestMultiRoom {
|
||||||
}
|
}
|
||||||
|
|
||||||
async talk(message) {
|
async talk(message) {
|
||||||
this.log.step(`say "${message}" in ${this.roomIdOrAlias}`)
|
this.log.step(`say "${message}" in ${this.roomIdOrAlias}`);
|
||||||
await Promise.all(this.rooms.map(async (r) => {
|
await Promise.all(this.rooms.map(async (r) => {
|
||||||
r.log.mute();
|
r.log.mute();
|
||||||
await r.talk(message);
|
await r.talk(message);
|
||||||
|
@ -84,7 +81,7 @@ class RestMultiRoom {
|
||||||
}
|
}
|
||||||
|
|
||||||
async leave() {
|
async leave() {
|
||||||
this.log.step(`leave ${this.roomIdOrAlias}`)
|
this.log.step(`leave ${this.roomIdOrAlias}`);
|
||||||
await Promise.all(this.rooms.map(async (r) => {
|
await Promise.all(this.rooms.map(async (r) => {
|
||||||
r.log.mute();
|
r.log.mute();
|
||||||
await r.leave();
|
await r.leave();
|
||||||
|
|
|
@ -25,18 +25,18 @@ module.exports = class RestRoom {
|
||||||
}
|
}
|
||||||
|
|
||||||
async talk(message) {
|
async talk(message) {
|
||||||
this.log.step(`says "${message}" in ${this._roomId}`)
|
this.log.step(`says "${message}" in ${this._roomId}`);
|
||||||
const txId = uuidv4();
|
const txId = uuidv4();
|
||||||
await this.session._put(`/rooms/${this._roomId}/send/m.room.message/${txId}`, {
|
await this.session._put(`/rooms/${this._roomId}/send/m.room.message/${txId}`, {
|
||||||
"msgtype": "m.text",
|
"msgtype": "m.text",
|
||||||
"body": message
|
"body": message,
|
||||||
});
|
});
|
||||||
this.log.done();
|
this.log.done();
|
||||||
return txId;
|
return txId;
|
||||||
}
|
}
|
||||||
|
|
||||||
async leave() {
|
async leave() {
|
||||||
this.log.step(`leaves ${this._roomId}`)
|
this.log.step(`leaves ${this._roomId}`);
|
||||||
await this.session._post(`/rooms/${this._roomId}/leave`);
|
await this.session._post(`/rooms/${this._roomId}/leave`);
|
||||||
this.log.done();
|
this.log.done();
|
||||||
}
|
}
|
||||||
|
@ -44,4 +44,4 @@ module.exports = class RestRoom {
|
||||||
roomId() {
|
roomId() {
|
||||||
return this._roomId;
|
return this._roomId;
|
||||||
}
|
}
|
||||||
}
|
};
|
||||||
|
|
|
@ -43,17 +43,17 @@ module.exports = class RestSession {
|
||||||
this.log.step(`sets their display name to ${displayName}`);
|
this.log.step(`sets their display name to ${displayName}`);
|
||||||
this._displayName = displayName;
|
this._displayName = displayName;
|
||||||
await this._put(`/profile/${this._credentials.userId}/displayname`, {
|
await this._put(`/profile/${this._credentials.userId}/displayname`, {
|
||||||
displayname: displayName
|
displayname: displayName,
|
||||||
});
|
});
|
||||||
this.log.done();
|
this.log.done();
|
||||||
}
|
}
|
||||||
|
|
||||||
async join(roomIdOrAlias) {
|
async join(roomIdOrAlias) {
|
||||||
this.log.step(`joins ${roomIdOrAlias}`);
|
this.log.step(`joins ${roomIdOrAlias}`);
|
||||||
const {room_id} = await this._post(`/join/${encodeURIComponent(roomIdOrAlias)}`);
|
const roomId = await this._post(`/join/${encodeURIComponent(roomIdOrAlias)}`).room_id;
|
||||||
this.log.done();
|
this.log.done();
|
||||||
const room = new RestRoom(this, room_id, this.log);
|
const room = new RestRoom(this, roomId, this.log);
|
||||||
this._rooms[room_id] = room;
|
this._rooms[roomId] = room;
|
||||||
this._rooms[roomIdOrAlias] = room;
|
this._rooms[roomIdOrAlias] = room;
|
||||||
return room;
|
return room;
|
||||||
}
|
}
|
||||||
|
@ -86,9 +86,9 @@ module.exports = class RestSession {
|
||||||
body.topic = options.topic;
|
body.topic = options.topic;
|
||||||
}
|
}
|
||||||
|
|
||||||
const {room_id} = await this._post(`/createRoom`, body);
|
const roomId = await this._post(`/createRoom`, body).room_id;
|
||||||
this.log.done();
|
this.log.done();
|
||||||
return new RestRoom(this, room_id, this.log);
|
return new RestRoom(this, roomId, this.log);
|
||||||
}
|
}
|
||||||
|
|
||||||
_post(csApiPath, body) {
|
_post(csApiPath, body) {
|
||||||
|
@ -105,23 +105,22 @@ module.exports = class RestSession {
|
||||||
url: `${this._credentials.hsUrl}/_matrix/client/r0${csApiPath}`,
|
url: `${this._credentials.hsUrl}/_matrix/client/r0${csApiPath}`,
|
||||||
method,
|
method,
|
||||||
headers: {
|
headers: {
|
||||||
"Authorization": `Bearer ${this._credentials.accessToken}`
|
"Authorization": `Bearer ${this._credentials.accessToken}`,
|
||||||
},
|
},
|
||||||
json: true,
|
json: true,
|
||||||
body
|
body,
|
||||||
});
|
});
|
||||||
return responseBody;
|
return responseBody;
|
||||||
|
} catch (err) {
|
||||||
} catch(err) {
|
|
||||||
const responseBody = err.response.body;
|
const responseBody = err.response.body;
|
||||||
if (responseBody.errcode === 'M_CONSENT_NOT_GIVEN') {
|
if (responseBody.errcode === 'M_CONSENT_NOT_GIVEN') {
|
||||||
await approveConsent(responseBody.consent_uri);
|
await approveConsent(responseBody.consent_uri);
|
||||||
return this._request(method, csApiPath, body);
|
return this._request(method, csApiPath, body);
|
||||||
} else if(responseBody && responseBody.error) {
|
} else if (responseBody && responseBody.error) {
|
||||||
throw new Error(`${method} ${csApiPath}: ${responseBody.error}`);
|
throw new Error(`${method} ${csApiPath}: ${responseBody.error}`);
|
||||||
} else {
|
} else {
|
||||||
throw new Error(`${method} ${csApiPath}: ${err.response.statusCode}`);
|
throw new Error(`${method} ${csApiPath}: ${err.response.statusCode}`);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
};
|
||||||
|
|
|
@ -42,7 +42,7 @@ module.exports = async function scenario(createSession, restCreator) {
|
||||||
console.log("create REST users:");
|
console.log("create REST users:");
|
||||||
const charlies = await createRestUsers(restCreator);
|
const charlies = await createRestUsers(restCreator);
|
||||||
await lazyLoadingScenarios(alice, bob, charlies);
|
await lazyLoadingScenarios(alice, bob, charlies);
|
||||||
}
|
};
|
||||||
|
|
||||||
async function createRestUsers(restCreator) {
|
async function createRestUsers(restCreator) {
|
||||||
const usernames = range(1, 10).map((i) => `charly-${i}`);
|
const usernames = range(1, 10).map((i) => `charly-${i}`);
|
||||||
|
|
|
@ -30,7 +30,7 @@ module.exports = async function roomDirectoryScenarios(alice, bob) {
|
||||||
const bobMessage = "hi Alice!";
|
const bobMessage = "hi Alice!";
|
||||||
await sendMessage(bob, bobMessage);
|
await sendMessage(bob, bobMessage);
|
||||||
await receiveMessage(alice, {sender: "bob", body: bobMessage});
|
await receiveMessage(alice, {sender: "bob", body: bobMessage});
|
||||||
const aliceMessage = "hi Bob, welcome!"
|
const aliceMessage = "hi Bob, welcome!";
|
||||||
await sendMessage(alice, aliceMessage);
|
await sendMessage(alice, aliceMessage);
|
||||||
await receiveMessage(bob, {sender: "alice", body: aliceMessage});
|
await receiveMessage(bob, {sender: "alice", body: aliceMessage});
|
||||||
}
|
};
|
||||||
|
|
|
@ -14,10 +14,6 @@ See the License for the specific language governing permissions and
|
||||||
limitations under the License.
|
limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
const {delay} = require('../util');
|
|
||||||
const {acceptDialogMaybe} = require('../usecases/dialog');
|
|
||||||
const join = require('../usecases/join');
|
|
||||||
const sendMessage = require('../usecases/send-message');
|
const sendMessage = require('../usecases/send-message');
|
||||||
const acceptInvite = require('../usecases/accept-invite');
|
const acceptInvite = require('../usecases/accept-invite');
|
||||||
const invite = require('../usecases/invite');
|
const invite = require('../usecases/invite');
|
||||||
|
@ -43,10 +39,10 @@ module.exports = async function e2eEncryptionScenarios(alice, bob) {
|
||||||
const [bobSas, aliceSas] = await Promise.all([bobSasPromise, aliceSasPromise]);
|
const [bobSas, aliceSas] = await Promise.all([bobSasPromise, aliceSasPromise]);
|
||||||
assert.deepEqual(bobSas, aliceSas);
|
assert.deepEqual(bobSas, aliceSas);
|
||||||
bob.log.done(`done (match for ${bobSas.join(", ")})`);
|
bob.log.done(`done (match for ${bobSas.join(", ")})`);
|
||||||
const aliceMessage = "Guess what I just heard?!"
|
const aliceMessage = "Guess what I just heard?!";
|
||||||
await sendMessage(alice, aliceMessage);
|
await sendMessage(alice, aliceMessage);
|
||||||
await receiveMessage(bob, {sender: "alice", body: aliceMessage, encrypted: true});
|
await receiveMessage(bob, {sender: "alice", body: aliceMessage, encrypted: true});
|
||||||
const bobMessage = "You've got to tell me!";
|
const bobMessage = "You've got to tell me!";
|
||||||
await sendMessage(bob, bobMessage);
|
await sendMessage(bob, bobMessage);
|
||||||
await receiveMessage(alice, {sender: "bob", body: bobMessage, encrypted: true});
|
await receiveMessage(alice, {sender: "bob", body: bobMessage, encrypted: true});
|
||||||
}
|
};
|
||||||
|
|
|
@ -20,12 +20,11 @@ const join = require('../usecases/join');
|
||||||
const sendMessage = require('../usecases/send-message');
|
const sendMessage = require('../usecases/send-message');
|
||||||
const {
|
const {
|
||||||
checkTimelineContains,
|
checkTimelineContains,
|
||||||
scrollToTimelineTop
|
scrollToTimelineTop,
|
||||||
} = require('../usecases/timeline');
|
} = require('../usecases/timeline');
|
||||||
const {createRoom} = require('../usecases/create-room');
|
const {createRoom} = require('../usecases/create-room');
|
||||||
const {getMembersInMemberlist} = require('../usecases/memberlist');
|
const {getMembersInMemberlist} = require('../usecases/memberlist');
|
||||||
const changeRoomSettings = require('../usecases/room-settings');
|
const changeRoomSettings = require('../usecases/room-settings');
|
||||||
const {enableLazyLoading} = require('../usecases/settings');
|
|
||||||
const assert = require('assert');
|
const assert = require('assert');
|
||||||
|
|
||||||
module.exports = async function lazyLoadingScenarios(alice, bob, charlies) {
|
module.exports = async function lazyLoadingScenarios(alice, bob, charlies) {
|
||||||
|
@ -43,7 +42,7 @@ module.exports = async function lazyLoadingScenarios(alice, bob, charlies) {
|
||||||
await delay(1000);
|
await delay(1000);
|
||||||
await checkMemberListLacksCharlies(alice, charlies);
|
await checkMemberListLacksCharlies(alice, charlies);
|
||||||
await checkMemberListLacksCharlies(bob, charlies);
|
await checkMemberListLacksCharlies(bob, charlies);
|
||||||
}
|
};
|
||||||
|
|
||||||
const room = "Lazy Loading Test";
|
const room = "Lazy Loading Test";
|
||||||
const alias = "#lltest:localhost";
|
const alias = "#lltest:localhost";
|
||||||
|
@ -60,7 +59,7 @@ async function setupRoomWithBobAliceAndCharlies(alice, bob, charlies) {
|
||||||
await charlyMembers.talk(charlyMsg1);
|
await charlyMembers.talk(charlyMsg1);
|
||||||
await charlyMembers.talk(charlyMsg2);
|
await charlyMembers.talk(charlyMsg2);
|
||||||
bob.log.step("sends 20 messages").mute();
|
bob.log.step("sends 20 messages").mute();
|
||||||
for(let i = 20; i >= 1; --i) {
|
for (let i = 20; i >= 1; --i) {
|
||||||
await sendMessage(bob, `I will only say this ${i} time(s)!`);
|
await sendMessage(bob, `I will only say this ${i} time(s)!`);
|
||||||
}
|
}
|
||||||
bob.log.unmute().done();
|
bob.log.unmute().done();
|
||||||
|
@ -112,7 +111,7 @@ async function joinCharliesWhileAliceIsOffline(alice, charly6to10) {
|
||||||
const members6to10 = await charly6to10.join(alias);
|
const members6to10 = await charly6to10.join(alias);
|
||||||
const member6 = members6to10.rooms[0];
|
const member6 = members6to10.rooms[0];
|
||||||
member6.log.step("sends 20 messages").mute();
|
member6.log.step("sends 20 messages").mute();
|
||||||
for(let i = 20; i >= 1; --i) {
|
for (let i = 20; i >= 1; --i) {
|
||||||
await member6.talk("where is charly?");
|
await member6.talk("where is charly?");
|
||||||
}
|
}
|
||||||
member6.log.unmute().done();
|
member6.log.unmute().done();
|
||||||
|
|
|
@ -42,7 +42,7 @@ module.exports = class RiotSession {
|
||||||
const page = await browser.newPage();
|
const page = await browser.newPage();
|
||||||
await page.setViewport({
|
await page.setViewport({
|
||||||
width: 1280,
|
width: 1280,
|
||||||
height: 800
|
height: 800,
|
||||||
});
|
});
|
||||||
if (throttleCpuFactor !== 1) {
|
if (throttleCpuFactor !== 1) {
|
||||||
const client = await page.target().createCDPSession();
|
const client = await page.target().createCDPSession();
|
||||||
|
@ -55,8 +55,8 @@ module.exports = class RiotSession {
|
||||||
async tryGetInnertext(selector) {
|
async tryGetInnertext(selector) {
|
||||||
const field = await this.page.$(selector);
|
const field = await this.page.$(selector);
|
||||||
if (field != null) {
|
if (field != null) {
|
||||||
const text_handle = await field.getProperty('innerText');
|
const textHandle = await field.getProperty('innerText');
|
||||||
return await text_handle.jsonValue();
|
return await textHandle.jsonValue();
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
@ -70,7 +70,7 @@ module.exports = class RiotSession {
|
||||||
return this.getElementProperty(field, 'innerText');
|
return this.getElementProperty(field, 'innerText');
|
||||||
}
|
}
|
||||||
|
|
||||||
getOuterHTML(element_handle) {
|
getOuterHTML(field) {
|
||||||
return this.getElementProperty(field, 'outerHTML');
|
return this.getElementProperty(field, 'outerHTML');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -97,12 +97,12 @@ module.exports = class RiotSession {
|
||||||
return {
|
return {
|
||||||
logs() {
|
logs() {
|
||||||
return buffer;
|
return buffer;
|
||||||
}
|
},
|
||||||
}
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
async printElements(label, elements) {
|
async printElements(label, elements) {
|
||||||
console.log(label, await Promise.all(elements.map(getOuterHTML)));
|
console.log(label, await Promise.all(elements.map(this.getOuterHTML)));
|
||||||
}
|
}
|
||||||
|
|
||||||
async replaceInputText(input, text) {
|
async replaceInputText(input, text) {
|
||||||
|
@ -210,7 +210,7 @@ module.exports = class RiotSession {
|
||||||
async poll(callback, interval = 100) {
|
async poll(callback, interval = 100) {
|
||||||
const timeout = DEFAULT_TIMEOUT;
|
const timeout = DEFAULT_TIMEOUT;
|
||||||
let waited = 0;
|
let waited = 0;
|
||||||
while(waited < timeout) {
|
while (waited < timeout) {
|
||||||
await this.delay(interval);
|
await this.delay(interval);
|
||||||
waited += interval;
|
waited += interval;
|
||||||
if (await callback()) {
|
if (await callback()) {
|
||||||
|
@ -219,4 +219,4 @@ module.exports = class RiotSession {
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
};
|
||||||
|
|
|
@ -14,9 +14,6 @@ See the License for the specific language governing permissions and
|
||||||
limitations under the License.
|
limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
const assert = require('assert');
|
|
||||||
const {acceptDialogMaybe} = require('./dialog');
|
|
||||||
|
|
||||||
module.exports = async function acceptInvite(session, name) {
|
module.exports = async function acceptInvite(session, name) {
|
||||||
session.log.step(`accepts "${name}" invite`);
|
session.log.step(`accepts "${name}" invite`);
|
||||||
//TODO: brittle selector
|
//TODO: brittle selector
|
||||||
|
@ -35,4 +32,4 @@ module.exports = async function acceptInvite(session, name) {
|
||||||
await acceptInvitationLink.click();
|
await acceptInvitationLink.click();
|
||||||
|
|
||||||
session.log.done();
|
session.log.done();
|
||||||
}
|
};
|
||||||
|
|
|
@ -14,8 +14,6 @@ See the License for the specific language governing permissions and
|
||||||
limitations under the License.
|
limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
const assert = require('assert');
|
|
||||||
|
|
||||||
async function openRoomDirectory(session) {
|
async function openRoomDirectory(session) {
|
||||||
const roomDirectoryButton = await session.query('.mx_LeftPanel_explore .mx_AccessibleButton');
|
const roomDirectoryButton = await session.query('.mx_LeftPanel_explore .mx_AccessibleButton');
|
||||||
await roomDirectoryButton.click();
|
await roomDirectoryButton.click();
|
||||||
|
|
|
@ -33,7 +33,7 @@ async function acceptDialogMaybe(session, expectedTitle) {
|
||||||
let primaryButton = null;
|
let primaryButton = null;
|
||||||
try {
|
try {
|
||||||
primaryButton = await session.query(".mx_Dialog .mx_Dialog_primary");
|
primaryButton = await session.query(".mx_Dialog .mx_Dialog_primary");
|
||||||
} catch(err) {
|
} catch (err) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if (expectedTitle) {
|
if (expectedTitle) {
|
||||||
|
|
|
@ -14,8 +14,6 @@ See the License for the specific language governing permissions and
|
||||||
limitations under the License.
|
limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
const assert = require('assert');
|
|
||||||
|
|
||||||
module.exports = async function invite(session, userId) {
|
module.exports = async function invite(session, userId) {
|
||||||
session.log.step(`invites "${userId}" to room`);
|
session.log.step(`invites "${userId}" to room`);
|
||||||
await session.delay(1000);
|
await session.delay(1000);
|
||||||
|
@ -27,4 +25,4 @@ module.exports = async function invite(session, userId) {
|
||||||
const confirmButton = await session.query(".mx_Dialog_primary");
|
const confirmButton = await session.query(".mx_Dialog_primary");
|
||||||
await confirmButton.click();
|
await confirmButton.click();
|
||||||
session.log.done();
|
session.log.done();
|
||||||
}
|
};
|
||||||
|
|
|
@ -14,7 +14,6 @@ See the License for the specific language governing permissions and
|
||||||
limitations under the License.
|
limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
const assert = require('assert');
|
|
||||||
const {openRoomDirectory} = require('./create-room');
|
const {openRoomDirectory} = require('./create-room');
|
||||||
|
|
||||||
module.exports = async function join(session, roomName) {
|
module.exports = async function join(session, roomName) {
|
||||||
|
@ -27,4 +26,4 @@ module.exports = async function join(session, roomName) {
|
||||||
await joinFirstLink.click();
|
await joinFirstLink.click();
|
||||||
await session.query('.mx_MessageComposer');
|
await session.query('.mx_MessageComposer');
|
||||||
session.log.done();
|
session.log.done();
|
||||||
}
|
};
|
||||||
|
|
|
@ -22,7 +22,7 @@ async function openMemberInfo(session, name) {
|
||||||
return m.displayName === name;
|
return m.displayName === name;
|
||||||
}).map((m) => m.label)[0];
|
}).map((m) => m.label)[0];
|
||||||
await matchingLabel.click();
|
await matchingLabel.click();
|
||||||
};
|
}
|
||||||
|
|
||||||
module.exports.openMemberInfo = openMemberInfo;
|
module.exports.openMemberInfo = openMemberInfo;
|
||||||
|
|
||||||
|
@ -39,10 +39,11 @@ module.exports.verifyDeviceForUser = async function(session, name, expectedDevic
|
||||||
// expect "Verify device" dialog and click "Begin Verification"
|
// expect "Verify device" dialog and click "Begin Verification"
|
||||||
const dialogHeader = await session.innerText(await session.query(".mx_Dialog .mx_Dialog_title"));
|
const dialogHeader = await session.innerText(await session.query(".mx_Dialog .mx_Dialog_title"));
|
||||||
assert(dialogHeader, "Verify device");
|
assert(dialogHeader, "Verify device");
|
||||||
const beginVerificationButton = await session.query(".mx_Dialog .mx_Dialog_primary")
|
const beginVerificationButton = await session.query(".mx_Dialog .mx_Dialog_primary");
|
||||||
await beginVerificationButton.click();
|
await beginVerificationButton.click();
|
||||||
// get emoji SAS labels
|
// get emoji SAS labels
|
||||||
const sasLabelElements = await session.queryAll(".mx_VerificationShowSas .mx_VerificationShowSas_emojiSas .mx_VerificationShowSas_emojiSas_label");
|
const sasLabelElements = await session.queryAll(
|
||||||
|
".mx_VerificationShowSas .mx_VerificationShowSas_emojiSas .mx_VerificationShowSas_emojiSas_label");
|
||||||
const sasLabels = await Promise.all(sasLabelElements.map(e => session.innerText(e)));
|
const sasLabels = await Promise.all(sasLabelElements.map(e => session.innerText(e)));
|
||||||
console.log("my sas labels", sasLabels);
|
console.log("my sas labels", sasLabels);
|
||||||
|
|
||||||
|
@ -58,7 +59,7 @@ module.exports.verifyDeviceForUser = async function(session, name, expectedDevic
|
||||||
const closeMemberInfo = await session.query(".mx_MemberInfo_cancel");
|
const closeMemberInfo = await session.query(".mx_MemberInfo_cancel");
|
||||||
await closeMemberInfo.click();
|
await closeMemberInfo.click();
|
||||||
session.log.done();
|
session.log.done();
|
||||||
}
|
};
|
||||||
|
|
||||||
async function getMembersInMemberlist(session) {
|
async function getMembersInMemberlist(session) {
|
||||||
const memberNameElements = await session.queryAll(".mx_MemberList .mx_EntityTile_name");
|
const memberNameElements = await session.queryAll(".mx_MemberList .mx_EntityTile_name");
|
||||||
|
|
|
@ -96,4 +96,4 @@ module.exports = async function changeRoomSettings(session, settings) {
|
||||||
await closeButton.click();
|
await closeButton.click();
|
||||||
|
|
||||||
session.log.endGroup();
|
session.log.endGroup();
|
||||||
}
|
};
|
||||||
|
|
|
@ -31,4 +31,4 @@ module.exports = async function sendMessage(session, message) {
|
||||||
// wait for the message to appear sent
|
// wait for the message to appear sent
|
||||||
await session.query(".mx_EventTile_last:not(.mx_EventTile_sending)");
|
await session.query(".mx_EventTile_last:not(.mx_EventTile_sending)");
|
||||||
session.log.done();
|
session.log.done();
|
||||||
}
|
};
|
||||||
|
|
|
@ -22,7 +22,8 @@ async function openSettings(session, section) {
|
||||||
const settingsItem = await session.query(".mx_TopLeftMenu_icon_settings");
|
const settingsItem = await session.query(".mx_TopLeftMenu_icon_settings");
|
||||||
await settingsItem.click();
|
await settingsItem.click();
|
||||||
if (section) {
|
if (section) {
|
||||||
const sectionButton = await session.query(`.mx_UserSettingsDialog .mx_TabbedView_tabLabels .mx_UserSettingsDialog_${section}Icon`);
|
const sectionButton = await session.query(
|
||||||
|
`.mx_UserSettingsDialog .mx_TabbedView_tabLabels .mx_UserSettingsDialog_${section}Icon`);
|
||||||
await sectionButton.click();
|
await sectionButton.click();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -37,7 +38,7 @@ module.exports.enableLazyLoading = async function(session) {
|
||||||
const closeButton = await session.query(".mx_RoomHeader_cancelButton");
|
const closeButton = await session.query(".mx_RoomHeader_cancelButton");
|
||||||
await closeButton.click();
|
await closeButton.click();
|
||||||
session.log.done();
|
session.log.done();
|
||||||
}
|
};
|
||||||
|
|
||||||
module.exports.getE2EDeviceFromSettings = async function(session) {
|
module.exports.getE2EDeviceFromSettings = async function(session) {
|
||||||
session.log.step(`gets e2e device/key from settings`);
|
session.log.step(`gets e2e device/key from settings`);
|
||||||
|
@ -50,4 +51,4 @@ module.exports.getE2EDeviceFromSettings = async function(session) {
|
||||||
await closeButton.click();
|
await closeButton.click();
|
||||||
session.log.done();
|
session.log.done();
|
||||||
return {id, key};
|
return {id, key};
|
||||||
}
|
};
|
||||||
|
|
|
@ -60,8 +60,8 @@ module.exports = async function signup(session, username, password, homeserver)
|
||||||
// Password validation is async, wait for it to complete before submit
|
// Password validation is async, wait for it to complete before submit
|
||||||
await session.query(".mx_Field_valid #mx_RegistrationForm_password");
|
await session.query(".mx_Field_valid #mx_RegistrationForm_password");
|
||||||
//check no errors
|
//check no errors
|
||||||
const error_text = await session.tryGetInnertext('.mx_Login_error');
|
const errorText = await session.tryGetInnertext('.mx_Login_error');
|
||||||
assert.strictEqual(!!error_text, false);
|
assert.strictEqual(!!errorText, false);
|
||||||
//submit form
|
//submit form
|
||||||
//await page.screenshot({path: "beforesubmit.png", fullPage: true});
|
//await page.screenshot({path: "beforesubmit.png", fullPage: true});
|
||||||
await registerButton.click();
|
await registerButton.click();
|
||||||
|
@ -87,4 +87,4 @@ module.exports = async function signup(session, username, password, homeserver)
|
||||||
});
|
});
|
||||||
assert(foundHomeUrl);
|
assert(foundHomeUrl);
|
||||||
session.log.done();
|
session.log.done();
|
||||||
}
|
};
|
||||||
|
|
|
@ -36,11 +36,11 @@ module.exports.scrollToTimelineTop = async function(session) {
|
||||||
} else {
|
} else {
|
||||||
await new Promise((resolve) => setTimeout(resolve, 50));
|
await new Promise((resolve) => setTimeout(resolve, 50));
|
||||||
}
|
}
|
||||||
} while (!timedOut)
|
} while (!timedOut);
|
||||||
|
});
|
||||||
});
|
});
|
||||||
})
|
|
||||||
session.log.done();
|
session.log.done();
|
||||||
}
|
};
|
||||||
|
|
||||||
module.exports.receiveMessage = async function(session, expectedMessage) {
|
module.exports.receiveMessage = async function(session, expectedMessage) {
|
||||||
session.log.step(`receives message "${expectedMessage.body}" from ${expectedMessage.sender}`);
|
session.log.step(`receives message "${expectedMessage.body}" from ${expectedMessage.sender}`);
|
||||||
|
@ -56,7 +56,7 @@ module.exports.receiveMessage = async function(session, expectedMessage) {
|
||||||
await session.poll(async () => {
|
await session.poll(async () => {
|
||||||
try {
|
try {
|
||||||
lastMessage = await getLastMessage();
|
lastMessage = await getLastMessage();
|
||||||
} catch(err) {
|
} catch (err) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
// stop polling when found the expected message
|
// stop polling when found the expected message
|
||||||
|
@ -66,10 +66,10 @@ module.exports.receiveMessage = async function(session, expectedMessage) {
|
||||||
});
|
});
|
||||||
assertMessage(lastMessage, expectedMessage);
|
assertMessage(lastMessage, expectedMessage);
|
||||||
session.log.done();
|
session.log.done();
|
||||||
}
|
};
|
||||||
|
|
||||||
|
|
||||||
module.exports.checkTimelineContains = async function (session, expectedMessages, sendersDescription) {
|
module.exports.checkTimelineContains = async function(session, expectedMessages, sendersDescription) {
|
||||||
session.log.step(`checks timeline contains ${expectedMessages.length} ` +
|
session.log.step(`checks timeline contains ${expectedMessages.length} ` +
|
||||||
`given messages${sendersDescription ? ` from ${sendersDescription}`:""}`);
|
`given messages${sendersDescription ? ` from ${sendersDescription}`:""}`);
|
||||||
const eventTiles = await getAllEventTiles(session);
|
const eventTiles = await getAllEventTiles(session);
|
||||||
|
@ -94,14 +94,14 @@ module.exports.checkTimelineContains = async function (session, expectedMessages
|
||||||
});
|
});
|
||||||
try {
|
try {
|
||||||
assertMessage(foundMessage, expectedMessage);
|
assertMessage(foundMessage, expectedMessage);
|
||||||
} catch(err) {
|
} catch (err) {
|
||||||
console.log("timelineMessages", timelineMessages);
|
console.log("timelineMessages", timelineMessages);
|
||||||
throw err;
|
throw err;
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
session.log.done();
|
session.log.done();
|
||||||
}
|
};
|
||||||
|
|
||||||
function assertMessage(foundMessage, expectedMessage) {
|
function assertMessage(foundMessage, expectedMessage) {
|
||||||
assert(foundMessage, `message ${JSON.stringify(expectedMessage)} not found in timeline`);
|
assert(foundMessage, `message ${JSON.stringify(expectedMessage)} not found in timeline`);
|
||||||
|
|
|
@ -31,7 +31,8 @@ async function startVerification(session, name) {
|
||||||
}
|
}
|
||||||
|
|
||||||
async function getSasCodes(session) {
|
async function getSasCodes(session) {
|
||||||
const sasLabelElements = await session.queryAll(".mx_VerificationShowSas .mx_VerificationShowSas_emojiSas .mx_VerificationShowSas_emojiSas_label");
|
const sasLabelElements = await session.queryAll(
|
||||||
|
".mx_VerificationShowSas .mx_VerificationShowSas_emojiSas .mx_VerificationShowSas_emojiSas_label");
|
||||||
const sasLabels = await Promise.all(sasLabelElements.map(e => session.innerText(e)));
|
const sasLabels = await Promise.all(sasLabelElements.map(e => session.innerText(e)));
|
||||||
return sasLabels;
|
return sasLabels;
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,8 +20,8 @@ module.exports.range = function(start, amount, step = 1) {
|
||||||
r.push(start + (i * step));
|
r.push(start + (i * step));
|
||||||
}
|
}
|
||||||
return r;
|
return r;
|
||||||
}
|
};
|
||||||
|
|
||||||
module.exports.delay = function(ms) {
|
module.exports.delay = function(ms) {
|
||||||
return new Promise((resolve) => setTimeout(resolve, ms));
|
return new Promise((resolve) => setTimeout(resolve, ms));
|
||||||
}
|
};
|
||||||
|
|
|
@ -14,7 +14,6 @@ See the License for the specific language governing permissions and
|
||||||
limitations under the License.
|
limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
const assert = require('assert');
|
|
||||||
const RiotSession = require('./src/session');
|
const RiotSession = require('./src/session');
|
||||||
const scenario = require('./src/scenario');
|
const scenario = require('./src/scenario');
|
||||||
const RestSessionCreator = require('./src/rest/creator');
|
const RestSessionCreator = require('./src/rest/creator');
|
||||||
|
@ -35,7 +34,7 @@ program
|
||||||
const hsUrl = 'http://localhost:5005';
|
const hsUrl = 'http://localhost:5005';
|
||||||
|
|
||||||
async function runTests() {
|
async function runTests() {
|
||||||
let sessions = [];
|
const sessions = [];
|
||||||
const options = {
|
const options = {
|
||||||
slowMo: program.slowMo ? 20 : undefined,
|
slowMo: program.slowMo ? 20 : undefined,
|
||||||
devtools: program.devTools,
|
devtools: program.devTools,
|
||||||
|
@ -54,7 +53,7 @@ async function runTests() {
|
||||||
const restCreator = new RestSessionCreator(
|
const restCreator = new RestSessionCreator(
|
||||||
'synapse/installations/consent/env/bin',
|
'synapse/installations/consent/env/bin',
|
||||||
hsUrl,
|
hsUrl,
|
||||||
__dirname
|
__dirname,
|
||||||
);
|
);
|
||||||
|
|
||||||
async function createSession(username) {
|
async function createSession(username) {
|
||||||
|
@ -66,7 +65,7 @@ async function runTests() {
|
||||||
let failure = false;
|
let failure = false;
|
||||||
try {
|
try {
|
||||||
await scenario(createSession, restCreator);
|
await scenario(createSession, restCreator);
|
||||||
} catch(err) {
|
} catch (err) {
|
||||||
failure = true;
|
failure = true;
|
||||||
console.log('failure: ', err);
|
console.log('failure: ', err);
|
||||||
if (program.logDirectory) {
|
if (program.logDirectory) {
|
||||||
|
@ -90,15 +89,15 @@ async function runTests() {
|
||||||
}
|
}
|
||||||
|
|
||||||
async function writeLogs(sessions, dir) {
|
async function writeLogs(sessions, dir) {
|
||||||
let logs = "";
|
const logs = "";
|
||||||
for(let i = 0; i < sessions.length; ++i) {
|
for (let i = 0; i < sessions.length; ++i) {
|
||||||
const session = sessions[i];
|
const session = sessions[i];
|
||||||
const userLogDir = `${dir}/${session.username}`;
|
const userLogDir = `${dir}/${session.username}`;
|
||||||
fs.mkdirSync(userLogDir);
|
fs.mkdirSync(userLogDir);
|
||||||
const consoleLogName = `${userLogDir}/console.log`;
|
const consoleLogName = `${userLogDir}/console.log`;
|
||||||
const networkLogName = `${userLogDir}/network.log`;
|
const networkLogName = `${userLogDir}/network.log`;
|
||||||
const appHtmlName = `${userLogDir}/app.html`;
|
const appHtmlName = `${userLogDir}/app.html`;
|
||||||
documentHtml = await session.page.content();
|
const documentHtml = await session.page.content();
|
||||||
fs.writeFileSync(appHtmlName, documentHtml);
|
fs.writeFileSync(appHtmlName, documentHtml);
|
||||||
fs.writeFileSync(networkLogName, session.networkLogs());
|
fs.writeFileSync(networkLogName, session.networkLogs());
|
||||||
fs.writeFileSync(consoleLogName, session.consoleLogs());
|
fs.writeFileSync(consoleLogName, session.consoleLogs());
|
||||||
|
|
Loading…
Reference in a new issue