signal-desktop/ts/util/assert.ts

70 lines
1.9 KiB
TypeScript
Raw Normal View History

// Copyright 2021 Signal Messenger, LLC
// SPDX-License-Identifier: AGPL-3.0-only
import { getEnvironment, Environment } from '../environment';
import * as log from '../logging/log';
import * as Errors from '../types/errors';
/**
* In production and beta, logs a warning and continues. For development it
* starts the debugger.
*/
export function softAssert(condition: unknown, message: string): void {
if (!condition) {
if (getEnvironment() === Environment.Development) {
debugger; // eslint-disable-line no-debugger
}
const err = new Error(message);
log.warn('softAssert failure:', Errors.toLogFormat(err));
}
}
/**
* In production, logs an error and continues. In all other environments, throws an error.
*/
export function assertDev(
condition: unknown,
message: string
): asserts condition {
if (!condition) {
const err = new Error(message);
2024-09-04 18:12:45 +00:00
if (getEnvironment() !== Environment.PackagedApp) {
if (getEnvironment() === Environment.Development) {
debugger; // eslint-disable-line no-debugger
}
throw err;
}
log.error('assert failure:', Errors.toLogFormat(err));
}
}
2021-06-22 14:46:42 +00:00
/**
* Throws an error if the condition is falsy, regardless of environment.
*/
2022-09-14 16:40:50 +00:00
/**
* Asserts an expression is true.
*
* @param value - An expression to assert is true.
* @param message - An optional message for the assertion error thrown.
*/
export function strictAssert(value: boolean, message: string): asserts value;
/**
* Asserts a nullable value is non-null.
*
* @param value - A nullable value to assert is non-null.
* @param message - An optional message for the assertion error thrown.
*/
export function strictAssert<T>(
value: T | null | undefined,
2021-06-22 14:46:42 +00:00
message: string
2022-09-14 16:40:50 +00:00
): asserts value is T;
export function strictAssert(condition: unknown, message: string): void {
if (condition === false || condition == null) {
2021-06-22 14:46:42 +00:00
throw new Error(message);
}
}