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';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* In production, logs an error and continues. In all other environments, throws an error.
|
|
|
|
*/
|
|
|
|
export function assert(condition: unknown, message: string): asserts condition {
|
|
|
|
if (!condition) {
|
|
|
|
const err = new Error(message);
|
|
|
|
if (getEnvironment() !== Environment.Production) {
|
|
|
|
if (getEnvironment() === Environment.Development) {
|
|
|
|
debugger; // eslint-disable-line no-debugger
|
|
|
|
}
|
|
|
|
throw err;
|
|
|
|
}
|
2021-05-19 22:00:57 +00:00
|
|
|
log.error('assert failure:', err && err.stack ? err.stack : 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.
|
|
|
|
*/
|
|
|
|
export function strictAssert(
|
|
|
|
condition: unknown,
|
|
|
|
message: string
|
|
|
|
): asserts condition {
|
|
|
|
if (!condition) {
|
|
|
|
throw new Error(message);
|
|
|
|
}
|
|
|
|
}
|
2021-10-26 22:59:08 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Asserts that the type of value is not a promise.
|
|
|
|
* (Useful for database modules)
|
|
|
|
*/
|
|
|
|
export function assertSync<T, X>(value: T extends Promise<X> ? never : T): T {
|
|
|
|
return value;
|
|
|
|
}
|