Update mock-server, upload ci logs on failure

This commit is contained in:
Fedor Indutny 2022-02-24 17:21:56 -08:00 committed by GitHub
parent 21db47c423
commit 1d89ffcc2d
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
10 changed files with 83 additions and 10 deletions

View file

@ -13,6 +13,7 @@ jobs:
linux: linux:
runs-on: ubuntu-latest runs-on: ubuntu-latest
if: ${{ github.repository == 'signalapp/Signal-Desktop-Private' }} if: ${{ github.repository == 'signalapp/Signal-Desktop-Private' }}
timeout-minutes: 30
steps: steps:
- name: Get system specs - name: Get system specs
@ -62,6 +63,7 @@ jobs:
NODE_ENV: production NODE_ENV: production
RUN_COUNT: 10 RUN_COUNT: 10
ELECTRON_ENABLE_STACK_DUMPING: on ELECTRON_ENABLE_STACK_DUMPING: on
ARTIFACTS_DIR: artifacts/startup
- name: Run send benchmarks - name: Run send benchmarks
run: | run: |
@ -74,6 +76,7 @@ jobs:
NODE_ENV: production NODE_ENV: production
RUN_COUNT: 100 RUN_COUNT: 100
ELECTRON_ENABLE_STACK_DUMPING: on ELECTRON_ENABLE_STACK_DUMPING: on
ARTIFACTS_DIR: artifacts/send
- name: Run group send benchmarks - name: Run group send benchmarks
run: | run: |
@ -87,6 +90,7 @@ jobs:
NODE_ENV: production NODE_ENV: production
RUN_COUNT: 100 RUN_COUNT: 100
ELECTRON_ENABLE_STACK_DUMPING: on ELECTRON_ENABLE_STACK_DUMPING: on
ARTIFACTS_DIR: artifacts/group-send
- name: Run conversation open benchmarks - name: Run conversation open benchmarks
run: | run: |
@ -100,6 +104,14 @@ jobs:
NODE_ENV: production NODE_ENV: production
RUN_COUNT: 100 RUN_COUNT: 100
ELECTRON_ENABLE_STACK_DUMPING: on ELECTRON_ENABLE_STACK_DUMPING: on
ARTIFACTS_DIR: artifacts/convo-open
- name: Upload benchmark logs on failure
if: failure()
uses: actions/upload-artifact@v2
with:
name: logs
path: artifacts
- name: Clone benchmark repo - name: Clone benchmark repo
uses: actions/checkout@v2 uses: actions/checkout@v2

View file

@ -12,6 +12,7 @@ on:
jobs: jobs:
lint: lint:
runs-on: ubuntu-latest runs-on: ubuntu-latest
timeout-minutes: 30
steps: steps:
- run: lsb_release -a - run: lsb_release -a
@ -42,6 +43,7 @@ jobs:
needs: lint needs: lint
runs-on: macos-11.0 runs-on: macos-11.0
if: github.ref == 'refs/heads/development' || github.ref == 'refs/heads/master' if: github.ref == 'refs/heads/development' || github.ref == 'refs/heads/master'
timeout-minutes: 30
steps: steps:
- run: uname -a - run: uname -a
@ -70,6 +72,7 @@ jobs:
run: yarn electron:install-app-deps run: yarn electron:install-app-deps
- run: yarn test-node - run: yarn test-node
- run: yarn test-electron - run: yarn test-electron
timeout-minutes: 5
- run: yarn test-release - run: yarn test-release
env: env:
NODE_ENV: production NODE_ENV: production
@ -77,6 +80,7 @@ jobs:
linux: linux:
needs: lint needs: lint
runs-on: ubuntu-latest runs-on: ubuntu-latest
timeout-minutes: 30
steps: steps:
- run: lsb_release -a - run: lsb_release -a
@ -105,6 +109,7 @@ jobs:
DISABLE_INSPECT_FUSE: on DISABLE_INSPECT_FUSE: on
- run: xvfb-run --auto-servernum yarn test-node - run: xvfb-run --auto-servernum yarn test-node
- run: xvfb-run --auto-servernum yarn test-electron - run: xvfb-run --auto-servernum yarn test-electron
timeout-minutes: 5
env: env:
LANG: en_US LANG: en_US
LANGUAGE: en_US LANGUAGE: en_US
@ -114,7 +119,8 @@ jobs:
windows: windows:
needs: lint needs: lint
runs-on: windows-latest runs-on: windows-2019
timeout-minutes: 30
steps: steps:
- run: systeminfo - run: systeminfo
@ -146,6 +152,7 @@ jobs:
env: env:
DISABLE_INSPECT_FUSE: on DISABLE_INSPECT_FUSE: on
- run: yarn test-electron - run: yarn test-electron
timeout-minutes: 5
- run: yarn test-release - run: yarn test-release
env: env:
SIGNAL_ENV: production SIGNAL_ENV: production
@ -154,6 +161,7 @@ jobs:
needs: lint needs: lint
runs-on: ubuntu-latest runs-on: ubuntu-latest
if: ${{ github.repository == 'signalapp/Signal-Desktop-Private' }} if: ${{ github.repository == 'signalapp/Signal-Desktop-Private' }}
timeout-minutes: 30
steps: steps:
- name: Get system specs - name: Get system specs

View file

@ -185,7 +185,7 @@
"@babel/preset-typescript": "7.16.0", "@babel/preset-typescript": "7.16.0",
"@chanzuckerberg/axe-storybook-testing": "3.0.2", "@chanzuckerberg/axe-storybook-testing": "3.0.2",
"@electron/fuses": "1.5.0", "@electron/fuses": "1.5.0",
"@signalapp/mock-server": "1.1.0", "@signalapp/mock-server": "1.1.1",
"@storybook/addon-actions": "5.1.11", "@storybook/addon-actions": "5.1.11",
"@storybook/addon-knobs": "5.1.11", "@storybook/addon-knobs": "5.1.11",
"@storybook/addons": "5.1.11", "@storybook/addons": "5.1.11",

View file

@ -4,7 +4,14 @@
import type { PrimaryDevice } from '@signalapp/mock-server'; import type { PrimaryDevice } from '@signalapp/mock-server';
import { Bootstrap, debug, stats, RUN_COUNT, DISCARD_COUNT } from './fixtures'; import {
Bootstrap,
debug,
saveLogs,
stats,
RUN_COUNT,
DISCARD_COUNT,
} from './fixtures';
const CONVERSATION_SIZE = 1000; // messages const CONVERSATION_SIZE = 1000; // messages
const DELAY = 50; // milliseconds const DELAY = 50; // milliseconds
@ -94,6 +101,9 @@ const DELAY = 50; // milliseconds
}; };
await Promise.all([sendQueue(), measure()]); await Promise.all([sendQueue(), measure()]);
} catch (error) {
await saveLogs(bootstrap);
throw error;
} finally { } finally {
await app.close(); await app.close();
await bootstrap.teardown(); await bootstrap.teardown();

View file

@ -3,10 +3,14 @@
/* eslint-disable no-await-in-loop, no-console */ /* eslint-disable no-await-in-loop, no-console */
import createDebug from 'debug'; import createDebug from 'debug';
import fs from 'fs/promises';
import path from 'path';
import { Bootstrap } from '../bootstrap';
export const debug = createDebug('mock:benchmarks'); export const debug = createDebug('mock:benchmarks');
export { Bootstrap } from '../bootstrap'; export { Bootstrap };
export { App } from '../playwright'; export { App } from '../playwright';
export type StatsType = { export type StatsType = {
@ -59,6 +63,19 @@ export function stats(
return result; return result;
} }
export async function saveLogs(bootstrap: Bootstrap): Promise<void> {
const { ARTIFACTS_DIR } = process.env;
if (!ARTIFACTS_DIR) {
console.error('Not saving logs. Please set ARTIFACTS_DIR env variable');
return;
}
await fs.mkdir(ARTIFACTS_DIR, { recursive: true });
const { logsDir } = bootstrap;
await fs.rename(logsDir, path.join(ARTIFACTS_DIR, 'logs'));
}
// Can happen if electron exits prematurely // Can happen if electron exits prematurely
process.on('unhandledRejection', reason => { process.on('unhandledRejection', reason => {
console.error('Unhandled rejection:'); console.error('Unhandled rejection:');

View file

@ -12,6 +12,7 @@ import {
import { import {
Bootstrap, Bootstrap,
debug, debug,
saveLogs,
stats, stats,
RUN_COUNT, RUN_COUNT,
GROUP_SIZE, GROUP_SIZE,
@ -177,6 +178,9 @@ const LAST_MESSAGE = 'start sending messages now';
} }
console.log('stats info=%j', { delta: stats(deltaList, [99, 99.8]) }); console.log('stats info=%j', { delta: stats(deltaList, [99, 99.8]) });
} catch (error) {
await saveLogs(bootstrap);
throw error;
} finally { } finally {
await app.close(); await app.close();
await bootstrap.teardown(); await bootstrap.teardown();

View file

@ -6,7 +6,14 @@ import assert from 'assert';
import { ReceiptType } from '@signalapp/mock-server'; import { ReceiptType } from '@signalapp/mock-server';
import { Bootstrap, debug, stats, RUN_COUNT, DISCARD_COUNT } from './fixtures'; import {
Bootstrap,
debug,
saveLogs,
stats,
RUN_COUNT,
DISCARD_COUNT,
} from './fixtures';
const CONVERSATION_SIZE = 500; // messages const CONVERSATION_SIZE = 500; // messages
@ -128,6 +135,9 @@ const LAST_MESSAGE = 'start sending messages now';
} }
console.log('stats info=%j', { delta: stats(deltaList, [99, 99.8]) }); console.log('stats info=%j', { delta: stats(deltaList, [99, 99.8]) });
} catch (error) {
await saveLogs(bootstrap);
throw error;
} finally { } finally {
await app.close(); await app.close();
await bootstrap.teardown(); await bootstrap.teardown();

View file

@ -4,7 +4,7 @@
import { ReceiptType } from '@signalapp/mock-server'; import { ReceiptType } from '@signalapp/mock-server';
import { debug, Bootstrap, stats, RUN_COUNT } from './fixtures'; import { debug, Bootstrap, saveLogs, stats, RUN_COUNT } from './fixtures';
const MESSAGE_BATCH_SIZE = 1000; // messages const MESSAGE_BATCH_SIZE = 1000; // messages
@ -127,6 +127,9 @@ const ENABLE_RECEIPTS = Boolean(process.env.ENABLE_RECEIPTS);
if (messagesPerSec.length !== 0) { if (messagesPerSec.length !== 0) {
console.log('stats info=%j', { messagesPerSec: stats(messagesPerSec) }); console.log('stats info=%j', { messagesPerSec: stats(messagesPerSec) });
} }
} catch (error) {
await saveLogs(bootstrap);
throw error;
} finally { } finally {
await bootstrap.teardown(); await bootstrap.teardown();
} }

View file

@ -148,6 +148,15 @@ export class Bootstrap {
debug('setting storage path=%j', this.storagePath); debug('setting storage path=%j', this.storagePath);
} }
public get logsDir(): string {
assert(
this.storagePath !== undefined,
'Bootstrap has to be initialized first, see: bootstrap.init()'
);
return path.join(this.storagePath, 'logs');
}
public async teardown(): Promise<void> { public async teardown(): Promise<void> {
debug('tearing down'); debug('tearing down');

View file

@ -1349,10 +1349,10 @@
"@react-spring/shared" "~9.4.0" "@react-spring/shared" "~9.4.0"
"@react-spring/types" "~9.4.0" "@react-spring/types" "~9.4.0"
"@signalapp/mock-server@1.1.0": "@signalapp/mock-server@1.1.1":
version "1.1.0" version "1.1.1"
resolved "https://registry.yarnpkg.com/@signalapp/mock-server/-/mock-server-1.1.0.tgz#1b6ca0f4c89fb2f0b803af06bb6571780edebf10" resolved "https://registry.yarnpkg.com/@signalapp/mock-server/-/mock-server-1.1.1.tgz#b290feeb107a3d644851708ff31bb4cd9733aa87"
integrity sha512-dsrxPhvbNM5kdaGzQSwLc2jgDNkNi93DvccWwSl8P28Wfir/1IVt+8/9alaTen0xr0UBbscfreZ2sJ8junNLjA== integrity sha512-bk+fMFwRtwE4zbhryIhqPoumXX1L91kJQbHjfl2i4If47LDM9ik44vVGblIqO7l8Wf1nKDD/tTemZU5w69f5qA==
dependencies: dependencies:
"@signalapp/signal-client" "0.12.1" "@signalapp/signal-client" "0.12.1"
debug "^4.3.2" debug "^4.3.2"