2020-02-18 14:25:19 +03:00
|
|
|
import {_waitForMember, canEncryptToAllUsers} from '../src/createRoom';
|
2020-02-13 17:13:10 +03:00
|
|
|
import {EventEmitter} from 'events';
|
|
|
|
|
|
|
|
/* Shorter timeout, we've got tests to run */
|
|
|
|
const timeout = 30;
|
|
|
|
|
|
|
|
describe("waitForMember", () => {
|
|
|
|
let client;
|
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
client = new EventEmitter();
|
|
|
|
});
|
|
|
|
|
|
|
|
it("resolves with false if the timeout is reached", (done) => {
|
|
|
|
_waitForMember(client, "", "", { timeout: 0 }).then((r) => {
|
|
|
|
expect(r).toBe(false);
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it("resolves with false if the timeout is reached, even if other RoomState.newMember events fire", (done) => {
|
|
|
|
const roomId = "!roomId:domain";
|
|
|
|
const userId = "@clientId:domain";
|
|
|
|
_waitForMember(client, roomId, userId, { timeout }).then((r) => {
|
|
|
|
expect(r).toBe(false);
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
client.emit("RoomState.newMember", undefined, undefined, { roomId, userId: "@anotherClient:domain" });
|
2020-02-17 19:00:25 +03:00
|
|
|
});
|
2020-02-13 17:13:10 +03:00
|
|
|
|
|
|
|
it("resolves with true if RoomState.newMember fires", (done) => {
|
|
|
|
const roomId = "!roomId:domain";
|
|
|
|
const userId = "@clientId:domain";
|
|
|
|
_waitForMember(client, roomId, userId, { timeout }).then((r) => {
|
|
|
|
expect(r).toBe(true);
|
|
|
|
expect(client.listeners("RoomState.newMember").length).toBe(0);
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
client.emit("RoomState.newMember", undefined, undefined, { roomId, userId });
|
2020-02-17 19:00:25 +03:00
|
|
|
});
|
|
|
|
});
|
2020-02-18 14:25:19 +03:00
|
|
|
|
|
|
|
describe("canEncryptToAllUsers", () => {
|
|
|
|
const trueUser = {
|
|
|
|
"@goodUser:localhost": {
|
|
|
|
"DEV1": {},
|
|
|
|
"DEV2": {},
|
|
|
|
},
|
|
|
|
};
|
|
|
|
const falseUser = {
|
|
|
|
"@badUser:localhost": {},
|
|
|
|
};
|
|
|
|
|
|
|
|
it("returns true if all devices have crypto", async (done) => {
|
|
|
|
const client = {
|
|
|
|
downloadKeys: async function(userIds) { return trueUser; },
|
|
|
|
};
|
|
|
|
const response = await canEncryptToAllUsers(client, ["@goodUser:localhost"]);
|
|
|
|
expect(response).toBe(true);
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
it("returns false if not all users have crypto", async (done) => {
|
|
|
|
const client = {
|
|
|
|
downloadKeys: async function(userIds) { return {...trueUser, ...falseUser}; },
|
|
|
|
};
|
|
|
|
const response = await canEncryptToAllUsers(client, ["@goodUser:localhost", "@badUser:localhost"]);
|
|
|
|
expect(response).toBe(false);
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|