mirror of
https://github.com/vector-im/element-call.git
synced 2024-11-24 00:38:31 +08:00
Simplify diff
This commit is contained in:
parent
b7ecd396c5
commit
18e7ca567c
@ -357,29 +357,29 @@ test("screen sharing activates spotlight layout", () => {
|
|||||||
|
|
||||||
test("participants stay in the same order unless to appear/disappear", () => {
|
test("participants stay in the same order unless to appear/disappear", () => {
|
||||||
withTestScheduler(({ hot, schedule, expectObservable }) => {
|
withTestScheduler(({ hot, schedule, expectObservable }) => {
|
||||||
const inputModeMarbles = " g";
|
const modeMarbles = " a";
|
||||||
// First Bob speaks, then Dave, then Alice
|
// First Bob speaks, then Dave, then Alice
|
||||||
const inputASpeakingMarbles = "n- 1998ms - 1999ms y";
|
const aSpeakingMarbles = "n- 1998ms - 1999ms y";
|
||||||
const inputBSpeakingMarbles = "ny 1998ms n 1999ms -";
|
const bSpeakingMarbles = "ny 1998ms n 1999ms -";
|
||||||
const inputDSpeakingMarbles = "n- 1998ms y 1999ms n";
|
const dSpeakingMarbles = "n- 1998ms y 1999ms n";
|
||||||
// Nothing should change when Bob speaks, because Bob is already on screen.
|
// Nothing should change when Bob speaks, because Bob is already on screen.
|
||||||
// When Dave speaks he should switch with Alice because she's the one who
|
// When Dave speaks he should switch with Alice because she's the one who
|
||||||
// hasn't spoken at all. Then when Alice speaks, she should return to her
|
// hasn't spoken at all. Then when Alice speaks, she should return to her
|
||||||
// place at the top.
|
// place at the top.
|
||||||
const expectedLayoutMarbles = "a 1999ms b 1999ms a 57999ms c 1999ms a";
|
const layoutMarbles = " a 1999ms b 1999ms a 57999ms c 1999ms a";
|
||||||
|
|
||||||
withCallViewModel(
|
withCallViewModel(
|
||||||
of([aliceParticipant, bobParticipant, daveParticipant]),
|
of([aliceParticipant, bobParticipant, daveParticipant]),
|
||||||
of([aliceRtcMember, bobRtcMember, daveRtcMember]),
|
of([aliceRtcMember, bobRtcMember, daveRtcMember]),
|
||||||
of(ConnectionState.Connected),
|
of(ConnectionState.Connected),
|
||||||
new Map([
|
new Map([
|
||||||
[aliceParticipant, hot(inputASpeakingMarbles, { y: true, n: false })],
|
[aliceParticipant, hot(aSpeakingMarbles, { y: true, n: false })],
|
||||||
[bobParticipant, hot(inputBSpeakingMarbles, { y: true, n: false })],
|
[bobParticipant, hot(bSpeakingMarbles, { y: true, n: false })],
|
||||||
[daveParticipant, hot(inputDSpeakingMarbles, { y: true, n: false })],
|
[daveParticipant, hot(dSpeakingMarbles, { y: true, n: false })],
|
||||||
]),
|
]),
|
||||||
(vm) => {
|
(vm) => {
|
||||||
schedule(inputModeMarbles, {
|
schedule(modeMarbles, {
|
||||||
g: () => {
|
a: () => {
|
||||||
// We imagine that only three tiles (the first three) will be visible
|
// We imagine that only three tiles (the first three) will be visible
|
||||||
// on screen at a time
|
// on screen at a time
|
||||||
vm.layout.subscribe((layout) => {
|
vm.layout.subscribe((layout) => {
|
||||||
@ -391,9 +391,7 @@ test("participants stay in the same order unless to appear/disappear", () => {
|
|||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|
||||||
expectObservable(summarizeLayout(vm.layout)).toBe(
|
expectObservable(summarizeLayout(vm.layout)).toBe(layoutMarbles, {
|
||||||
expectedLayoutMarbles,
|
|
||||||
{
|
|
||||||
a: {
|
a: {
|
||||||
type: "grid",
|
type: "grid",
|
||||||
spotlight: undefined,
|
spotlight: undefined,
|
||||||
@ -409,8 +407,7 @@ test("participants stay in the same order unless to appear/disappear", () => {
|
|||||||
spotlight: undefined,
|
spotlight: undefined,
|
||||||
grid: ["local:0", `${aliceId}:0`, `${daveId}:0`, `${bobId}:0`],
|
grid: ["local:0", `${aliceId}:0`, `${daveId}:0`, `${bobId}:0`],
|
||||||
},
|
},
|
||||||
},
|
});
|
||||||
);
|
|
||||||
},
|
},
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
Loading…
Reference in New Issue
Block a user