signal-desktop/ts/test-mock/benchmarks/convo_open_bench.ts

93 lines
2.7 KiB
TypeScript
Raw Normal View History

// Copyright 2022 Signal Messenger, LLC
// SPDX-License-Identifier: AGPL-3.0-only
/* eslint-disable no-await-in-loop, no-console */
2022-07-08 20:46:25 +00:00
import assert from 'assert';
import type { PrimaryDevice } from '@signalapp/mock-server';
import { Bootstrap, debug, RUN_COUNT, DISCARD_COUNT } from './fixtures';
import { stats } from '../../util/benchmark/stats';
const CONVERSATION_SIZE = 1000; // messages
const DELAY = 50; // milliseconds
2023-03-13 23:41:47 +00:00
Bootstrap.benchmark(async (bootstrap: Bootstrap): Promise<void> => {
const app = await bootstrap.link();
const { server, contacts, phone, desktop } = bootstrap;
const [first, second] = contacts;
const messages = new Array<Buffer>();
debug('encrypting');
// Send messages from just two contacts
for (const contact of [second, first]) {
for (let i = 0; i < CONVERSATION_SIZE; i += 1) {
const messageTimestamp = bootstrap.getTimestamp();
messages.push(
await contact.encryptText(
desktop,
`hello from: ${contact.profileName}`,
{
timestamp: messageTimestamp,
sealed: true,
}
)
);
messages.push(
await phone.encryptSyncRead(desktop, {
timestamp: bootstrap.getTimestamp(),
messages: [
{
2023-08-16 20:54:39 +00:00
senderAci: contact.device.aci,
timestamp: messageTimestamp,
2023-03-13 23:41:47 +00:00
},
],
})
);
}
2023-03-13 23:41:47 +00:00
}
2023-03-13 23:41:47 +00:00
const sendQueue = async (): Promise<void> => {
await Promise.all(messages.map(message => server.send(desktop, message)));
};
2023-03-13 23:41:47 +00:00
const measure = async (): Promise<void> => {
assert(app);
const window = await app.getWindow();
const leftPane = window.locator('#LeftPane');
2023-03-13 23:41:47 +00:00
const openConvo = async (contact: PrimaryDevice): Promise<void> => {
debug('opening conversation', contact.profileName);
const item = leftPane.locator(
2023-08-16 20:54:39 +00:00
`[data-testid="${contact.toContact().aci}"]`
2023-03-13 23:41:47 +00:00
);
2023-03-13 23:41:47 +00:00
await item.click();
};
2023-03-13 23:41:47 +00:00
const deltaList = new Array<number>();
for (let runId = 0; runId < RUN_COUNT + DISCARD_COUNT; runId += 1) {
await openConvo(runId % 2 === 0 ? first : second);
2023-03-13 23:41:47 +00:00
debug('waiting for timing from the app');
const { delta } = await app.waitForConversationOpen();
2023-03-13 23:41:47 +00:00
// Let render complete
await new Promise(resolve => setTimeout(resolve, DELAY));
2023-03-13 23:41:47 +00:00
if (runId >= DISCARD_COUNT) {
deltaList.push(delta);
console.log('run=%d info=%j', runId - DISCARD_COUNT, { delta });
} else {
console.log('discarded=%d info=%j', runId, { delta });
}
2023-03-13 23:41:47 +00:00
}
2023-03-13 23:41:47 +00:00
console.log('stats info=%j', { delta: stats(deltaList, [99, 99.8]) });
};
2023-03-13 23:41:47 +00:00
await Promise.all([sendQueue(), measure()]);
});