Fixup base integration test
This commit is contained in:
@@ -133,11 +133,8 @@ export function createConnectionManager$({
|
|||||||
*/
|
*/
|
||||||
const transports$ = scope.behavior(
|
const transports$ = scope.behavior(
|
||||||
combineLatest([running$, inputTransports$]).pipe(
|
combineLatest([running$, inputTransports$]).pipe(
|
||||||
map(([running, transports]) => ({
|
map(([running, transports]) => (running ? transports : [])),
|
||||||
epoch: transports.epoch,
|
map((transports) => removeDuplicateTransports(transports)),
|
||||||
value: running ? transports.value : [],
|
|
||||||
})),
|
|
||||||
map((transports) => removeDuplicateTransports(transports.value)),
|
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|||||||
@@ -13,7 +13,7 @@ import {
|
|||||||
type LivekitTransport,
|
type LivekitTransport,
|
||||||
type CallMembership,
|
type CallMembership,
|
||||||
} from "matrix-js-sdk/lib/matrixrtc";
|
} from "matrix-js-sdk/lib/matrixrtc";
|
||||||
import { combineLatest, filter, map, skipWhile, type Observable } from "rxjs";
|
import { combineLatest, map } from "rxjs";
|
||||||
// eslint-disable-next-line rxjs/no-internal
|
// eslint-disable-next-line rxjs/no-internal
|
||||||
import { type NodeStyleEventEmitter } from "rxjs/internal/observable/fromEvent";
|
import { type NodeStyleEventEmitter } from "rxjs/internal/observable/fromEvent";
|
||||||
import { type Room as MatrixRoom, type RoomMember } from "matrix-js-sdk";
|
import { type Room as MatrixRoom, type RoomMember } from "matrix-js-sdk";
|
||||||
@@ -91,12 +91,12 @@ export function createMatrixLivekitMembers$({
|
|||||||
connectionManager.connectionManagerData$,
|
connectionManager.connectionManagerData$,
|
||||||
displaynameMap$,
|
displaynameMap$,
|
||||||
]).pipe(
|
]).pipe(
|
||||||
filter(
|
// filter(
|
||||||
([membershipsWithTransports, managerData, displaynames]) =>
|
// ([membershipsWithTransports, managerData, displaynames]) =>
|
||||||
// for each change in
|
// // for each change in
|
||||||
displaynames.size === membershipsWithTransports.length &&
|
// displaynames.size === membershipsWithTransports.length &&
|
||||||
displaynames.size === managerData.getConnections().length,
|
// displaynames.size === managerData.getConnections().length,
|
||||||
),
|
// ),
|
||||||
map(([memberships, managerData, displaynames]) => {
|
map(([memberships, managerData, displaynames]) => {
|
||||||
const items: MatrixLivekitMember[] = memberships.map(
|
const items: MatrixLivekitMember[] = memberships.map(
|
||||||
({ membership, transport }) => {
|
({ membership, transport }) => {
|
||||||
|
|||||||
@@ -6,12 +6,13 @@ Please see LICENSE in the repository root for full details.
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
import { test, vi, expect, beforeEach, afterEach } from "vitest";
|
import { test, vi, expect, beforeEach, afterEach } from "vitest";
|
||||||
import { BehaviorSubject, map } from "rxjs";
|
import { BehaviorSubject } from "rxjs";
|
||||||
import { type Room as LivekitRoom } from "livekit-client";
|
import { type Room as LivekitRoom } from "livekit-client";
|
||||||
import EventEmitter from "events";
|
import EventEmitter from "events";
|
||||||
import fetchMock from "fetch-mock";
|
import fetchMock from "fetch-mock";
|
||||||
import { type LivekitTransport } from "matrix-js-sdk/lib/matrixrtc";
|
import { type LivekitTransport } from "matrix-js-sdk/lib/matrixrtc";
|
||||||
import { type Room as MatrixRoom, type RoomMember } from "matrix-js-sdk";
|
import { type Room as MatrixRoom, type RoomMember } from "matrix-js-sdk";
|
||||||
|
import { logger } from "matrix-js-sdk/lib/logger";
|
||||||
|
|
||||||
import { ObservableScope } from "../ObservableScope.ts";
|
import { ObservableScope } from "../ObservableScope.ts";
|
||||||
import { ECConnectionFactory } from "./ConnectionFactory.ts";
|
import { ECConnectionFactory } from "./ConnectionFactory.ts";
|
||||||
@@ -23,15 +24,12 @@ import {
|
|||||||
} from "../../utils/test";
|
} from "../../utils/test";
|
||||||
import { type ProcessorState } from "../../livekit/TrackProcessorContext.tsx";
|
import { type ProcessorState } from "../../livekit/TrackProcessorContext.tsx";
|
||||||
import {
|
import {
|
||||||
|
areLivekitTransportsEqual,
|
||||||
createMatrixLivekitMembers$,
|
createMatrixLivekitMembers$,
|
||||||
type MatrixLivekitMember,
|
type MatrixLivekitMember,
|
||||||
} from "./MatrixLivekitMembers.ts";
|
} from "./MatrixLivekitMembers.ts";
|
||||||
import {
|
import { createConnectionManager$ } from "./ConnectionManager.ts";
|
||||||
ConnectionManagerData,
|
|
||||||
createConnectionManager$,
|
|
||||||
} from "./ConnectionManager.ts";
|
|
||||||
import { membershipsAndTransports$ } from "../SessionBehaviors.ts";
|
import { membershipsAndTransports$ } from "../SessionBehaviors.ts";
|
||||||
import { Connection } from "./Connection.ts";
|
|
||||||
|
|
||||||
// Test the integration of ConnectionManager and MatrixLivekitMerger
|
// Test the integration of ConnectionManager and MatrixLivekitMerger
|
||||||
|
|
||||||
@@ -108,12 +106,22 @@ afterEach(() => {
|
|||||||
fetchMock.reset();
|
fetchMock.reset();
|
||||||
});
|
});
|
||||||
|
|
||||||
test("example test 2", () => {
|
test("bob, carl, then bob joining no tracks yet", () => {
|
||||||
withTestScheduler(({ schedule, expectObservable, behavior, cold }) => {
|
withTestScheduler(({ expectObservable, behavior }) => {
|
||||||
const bobMembership = mockCallMembership("@bob:example.com", "BDEV000");
|
const bobMembership = mockCallMembership("@bob:example.com", "BDEV000");
|
||||||
const carlMembership = mockCallMembership("@carl:example.com", "CDEV000");
|
const carlMembership = mockCallMembership("@carl:example.com", "CDEV000");
|
||||||
const daveMembership = mockCallMembership("@dave:foo.bar", "DDEV000");
|
const daveMembership = mockCallMembership("@dave:foo.bar", "DDEV000");
|
||||||
const memberships$ = behavior("abc", {
|
|
||||||
|
// We add the `---` because there is a limitation in rxjs marbles https://github.com/ReactiveX/rxjs/issues/5677
|
||||||
|
// Because we several values emitted at the same frame, so we use the grouping format
|
||||||
|
// e.g. a(bc) to indicate that b and c are emitted at the same time. But rxjs marbles advance the
|
||||||
|
// time by the number of characters in the marble diagram, so we need to add some padding to avoid so that
|
||||||
|
// the next emission is testable
|
||||||
|
// ab---c---
|
||||||
|
// a(bc)(de)
|
||||||
|
const eMarble = "ab----c----";
|
||||||
|
const vMarble = "a(xxb)(xxc)";
|
||||||
|
const memberships$ = behavior(eMarble, {
|
||||||
a: [bobMembership],
|
a: [bobMembership],
|
||||||
b: [bobMembership, carlMembership],
|
b: [bobMembership, carlMembership],
|
||||||
c: [bobMembership, carlMembership, daveMembership],
|
c: [bobMembership, carlMembership, daveMembership],
|
||||||
@@ -138,70 +146,73 @@ test("example test 2", () => {
|
|||||||
matrixRoom: mockMatrixRoom,
|
matrixRoom: mockMatrixRoom,
|
||||||
});
|
});
|
||||||
|
|
||||||
expectObservable(membershipsAndTransports.transports$).toBe("abc", {
|
expectObservable(matrixLivekitItems$).toBe(vMarble, {
|
||||||
a: expect.toSatisfy((t: LivekitTransport[]) => t.length === 1),
|
|
||||||
b: expect.toSatisfy((t: LivekitTransport[]) => t.length === 2),
|
|
||||||
c: expect.toSatisfy((t: LivekitTransport[]) => t.length === 3),
|
|
||||||
});
|
|
||||||
|
|
||||||
expectObservable(membershipsAndTransports.membershipsWithTransport$).toBe(
|
|
||||||
"abc",
|
|
||||||
{
|
|
||||||
a: expect.toSatisfy((t: LivekitTransport[]) => t.length === 1),
|
|
||||||
b: expect.toSatisfy((t: LivekitTransport[]) => t.length === 2),
|
|
||||||
c: expect.toSatisfy((t: LivekitTransport[]) => t.length === 3),
|
|
||||||
},
|
|
||||||
);
|
|
||||||
|
|
||||||
expectObservable(connectionManager.transports$).toBe("abc", {
|
|
||||||
a: expect.toSatisfy((t: LivekitTransport[]) => t.length === 1),
|
|
||||||
b: expect.toSatisfy((t: LivekitTransport[]) => t.length === 1),
|
|
||||||
c: expect.toSatisfy((t: LivekitTransport[]) => t.length === 2),
|
|
||||||
});
|
|
||||||
|
|
||||||
expectObservable(connectionManager.connectionManagerData$).toBe("abc", {
|
|
||||||
a: expect.toSatisfy(
|
|
||||||
(d: ConnectionManagerData) => d.getConnections().length === 1,
|
|
||||||
),
|
|
||||||
b: expect.toSatisfy(
|
|
||||||
(d: ConnectionManagerData) => d.getConnections().length === 1,
|
|
||||||
),
|
|
||||||
c: expect.toSatisfy(
|
|
||||||
(d: ConnectionManagerData) => d.getConnections().length === 2,
|
|
||||||
),
|
|
||||||
});
|
|
||||||
|
|
||||||
expectObservable(connectionManager.connections$).toBe("abc", {
|
|
||||||
a: expect.toSatisfy((t: Connection[]) => t.length === 1),
|
|
||||||
b: expect.toSatisfy((t: Connection[]) => t.length === 1),
|
|
||||||
c: expect.toSatisfy((t: Connection[]) => t.length === 2),
|
|
||||||
});
|
|
||||||
|
|
||||||
expectObservable(matrixLivekitItems$).toBe("abc", {
|
|
||||||
a: expect.toSatisfy((items: MatrixLivekitMember[]) => {
|
a: expect.toSatisfy((items: MatrixLivekitMember[]) => {
|
||||||
// expect(items.length).toBe(1);
|
expect(items.length).toBe(1);
|
||||||
// const item = items[0]!;
|
const item = items[0]!;
|
||||||
// expect(item.membership).toStrictEqual(bobMembership);
|
expect(item.membership).toStrictEqual(bobMembership);
|
||||||
// expect(item.participant).toBeUndefined();
|
expect(
|
||||||
|
areLivekitTransportsEqual(
|
||||||
|
item.connection!.transport,
|
||||||
|
bobMembership.transports[0]! as LivekitTransport,
|
||||||
|
),
|
||||||
|
).toBe(true);
|
||||||
|
expect(item.participant).toBeUndefined();
|
||||||
return true;
|
return true;
|
||||||
}),
|
}),
|
||||||
b: expect.toSatisfy((items: MatrixLivekitMember[]) => {
|
b: expect.toSatisfy((items: MatrixLivekitMember[]) => {
|
||||||
|
expect(items.length).toBe(2);
|
||||||
|
|
||||||
|
{
|
||||||
|
const item = items[0]!;
|
||||||
|
expect(item.membership).toStrictEqual(bobMembership);
|
||||||
|
expect(item.participant).toBeUndefined();
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
const item = items[1]!;
|
||||||
|
expect(item.membership).toStrictEqual(carlMembership);
|
||||||
|
expect(item.participantId).toStrictEqual(
|
||||||
|
`${carlMembership.userId}:${carlMembership.deviceId}`,
|
||||||
|
);
|
||||||
|
expect(
|
||||||
|
areLivekitTransportsEqual(
|
||||||
|
item.connection!.transport,
|
||||||
|
carlMembership.transports[0]! as LivekitTransport,
|
||||||
|
),
|
||||||
|
).toBe(true);
|
||||||
|
expect(item.participant).toBeUndefined();
|
||||||
|
}
|
||||||
return true;
|
return true;
|
||||||
}),
|
}),
|
||||||
c: expect.toSatisfy(() => true),
|
c: expect.toSatisfy((items: MatrixLivekitMember[]) => {
|
||||||
|
logger.info(`E Items length: ${items.length}`);
|
||||||
|
expect(items.length).toBe(3);
|
||||||
|
{
|
||||||
|
expect(items[0]!.membership).toStrictEqual(bobMembership);
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
expect(items[1]!.membership).toStrictEqual(carlMembership);
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
const item = items[2]!;
|
||||||
|
expect(item.membership).toStrictEqual(daveMembership);
|
||||||
|
expect(item.participantId).toStrictEqual(
|
||||||
|
`${daveMembership.userId}:${daveMembership.deviceId}`,
|
||||||
|
);
|
||||||
|
expect(
|
||||||
|
areLivekitTransportsEqual(
|
||||||
|
item.connection!.transport,
|
||||||
|
daveMembership.transports[0]! as LivekitTransport,
|
||||||
|
),
|
||||||
|
).toBe(true);
|
||||||
|
expect(item.participant).toBeUndefined();
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}),
|
||||||
|
x: expect.anything(),
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
// test("Tryng", () => {
|
|
||||||
//
|
|
||||||
// withTestScheduler(({ schedule, expectObservable, behavior, cold }) => {
|
|
||||||
// const one = cold("a-b-c", { a: 1, b: 2, c: 3 });
|
|
||||||
// const a = one.pipe(map(() => 1));
|
|
||||||
// const b = one.pipe(map(() => 2));
|
|
||||||
// const combined = combineLatest([a,b])
|
|
||||||
// .pipe(map(([a,b])=>`${a}${b}`));
|
|
||||||
// expectObservable(combined).toBe("a-b-c", { a: 1, b: expect.anything(), c: 3 });
|
|
||||||
//
|
|
||||||
// })
|
|
||||||
// })
|
|
||||||
|
|||||||
Reference in New Issue
Block a user