// Copyright 2018-2024 the Deno authors. All rights reserved. MIT license. // This module is browser compatible. import { AssertionError } from "./assertion_error.ts"; /** * Make an assertion that `actual` not match RegExp `expected`. If match * then throw. * * @example Usage * ```ts no-eval * import { assertNotMatch } from "@std/assert/assert-not-match"; * * assertNotMatch("Denosaurus", RegExp(/Raptor/)); // Doesn't throw * assertNotMatch("Raptor", RegExp(/Raptor/)); // Throws * ``` * * @param actual The actual value to match. * @param expected The expected value to not match. * @param msg The optional message to display if the assertion fails. */ export function assertNotMatch( actual: string, expected: RegExp, msg?: string, ) { if (expected.test(actual)) { const msgSuffix = msg ? `: ${msg}` : "."; msg = `Expected actual: "${actual}" to not match: "${expected}"${msgSuffix}`; throw new AssertionError(msg); } }