2021-02-04 19:54:03 +00:00
|
|
|
// Copyright 2021 Signal Messenger, LLC
|
|
|
|
// SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
|
|
|
|
import { getEnvironment, Environment } from '../environment';
|
|
|
|
import * as log from '../logging/log';
|
2022-11-22 18:43:43 +00:00
|
|
|
import * as Errors from '../types/errors';
|
2021-02-04 19:54:03 +00:00
|
|
|
|
2024-09-17 23:11:25 +00:00
|
|
|
/**
|
|
|
|
* In development, starts the debugger.
|
|
|
|
*/
|
|
|
|
export function devDebugger(): void {
|
|
|
|
if (getEnvironment() === Environment.Development) {
|
|
|
|
debugger; // eslint-disable-line no-debugger
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-05-11 23:47:19 +00:00
|
|
|
/**
|
|
|
|
* 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) {
|
2024-09-17 23:11:25 +00:00
|
|
|
devDebugger();
|
2022-05-11 23:47:19 +00:00
|
|
|
const err = new Error(message);
|
2022-11-22 18:43:43 +00:00
|
|
|
log.warn('softAssert failure:', Errors.toLogFormat(err));
|
2022-05-11 23:47:19 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-02-04 19:54:03 +00:00
|
|
|
/**
|
|
|
|
* In production, logs an error and continues. In all other environments, throws an error.
|
|
|
|
*/
|
2022-09-15 19:17:15 +00:00
|
|
|
export function assertDev(
|
|
|
|
condition: unknown,
|
|
|
|
message: string
|
|
|
|
): asserts condition {
|
2021-02-04 19:54:03 +00:00
|
|
|
if (!condition) {
|
|
|
|
const err = new Error(message);
|
2024-09-04 18:12:45 +00:00
|
|
|
if (getEnvironment() !== Environment.PackagedApp) {
|
2024-09-17 23:11:25 +00:00
|
|
|
devDebugger();
|
2021-02-04 19:54:03 +00:00
|
|
|
throw err;
|
|
|
|
}
|
2022-11-22 18:43:43 +00:00
|
|
|
log.error('assert failure:', Errors.toLogFormat(err));
|
2021-02-04 19:54:03 +00:00
|
|
|
}
|
|
|
|
}
|
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);
|
|
|
|
}
|
|
|
|
}
|