2024-01-01 14:58:21 -05:00
|
|
|
// Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.
|
2023-05-22 21:28:36 -04:00
|
|
|
|
2024-03-13 22:15:39 -04:00
|
|
|
use std::io::Write;
|
|
|
|
|
2023-09-14 12:21:57 -04:00
|
|
|
use crate::colors;
|
|
|
|
|
2023-05-22 21:28:36 -04:00
|
|
|
#[macro_export]
|
|
|
|
macro_rules! assert_starts_with {
|
|
|
|
($string:expr, $($test:expr),+) => {
|
|
|
|
let string = $string; // This might be a function call or something
|
|
|
|
if !($(string.starts_with($test))||+) {
|
|
|
|
panic!("{:?} does not start with {:?}", string, [$($test),+]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2023-01-13 02:51:32 -05:00
|
|
|
|
2022-06-21 15:25:07 -04:00
|
|
|
#[macro_export]
|
|
|
|
macro_rules! assert_ends_with {
|
|
|
|
($left:expr, $right:expr $(,)?) => {
|
|
|
|
match (&$left, &$right) {
|
|
|
|
(actual, expected) => {
|
|
|
|
let actual = if expected.len() > actual.len() {
|
|
|
|
actual
|
|
|
|
} else {
|
|
|
|
&actual[actual.len() - expected.len()..]
|
|
|
|
};
|
|
|
|
pretty_assertions::assert_eq!(
|
|
|
|
actual,
|
|
|
|
*expected,
|
|
|
|
"should end with expected."
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
#[macro_export]
|
|
|
|
macro_rules! assert_contains {
|
|
|
|
($string:expr, $($test:expr),+ $(,)?) => {
|
|
|
|
let string = &$string; // This might be a function call or something
|
|
|
|
if !($(string.contains($test))||+) {
|
|
|
|
panic!("{:?} does not contain any of {:?}", string, [$($test),+]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#[macro_export]
|
|
|
|
macro_rules! assert_not_contains {
|
|
|
|
($string:expr, $($test:expr),+ $(,)?) => {
|
|
|
|
let string = &$string; // This might be a function call or something
|
|
|
|
if !($(!string.contains($test))||+) {
|
|
|
|
panic!("{:?} contained {:?}", string, [$($test),+]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2023-06-26 15:53:17 -04:00
|
|
|
|
|
|
|
#[track_caller]
|
|
|
|
pub fn assert_wildcard_match(actual: &str, expected: &str) {
|
2024-03-13 22:15:39 -04:00
|
|
|
assert_wildcard_match_with_logger(actual, expected, &mut std::io::stderr())
|
|
|
|
}
|
|
|
|
|
|
|
|
#[track_caller]
|
|
|
|
pub fn assert_wildcard_match_with_logger(
|
|
|
|
actual: &str,
|
|
|
|
expected: &str,
|
|
|
|
logger: &mut dyn Write,
|
|
|
|
) {
|
2024-03-08 17:16:07 -05:00
|
|
|
if !expected.contains("[WILD") && !expected.contains("[UNORDERED_START]") {
|
2023-06-26 15:53:17 -04:00
|
|
|
pretty_assertions::assert_eq!(actual, expected);
|
2023-09-14 12:21:57 -04:00
|
|
|
} else {
|
|
|
|
match crate::wildcard_match_detailed(expected, actual) {
|
|
|
|
crate::WildcardMatchResult::Success => {
|
|
|
|
// ignore
|
|
|
|
}
|
|
|
|
crate::WildcardMatchResult::Fail(debug_output) => {
|
2024-03-13 22:15:39 -04:00
|
|
|
writeln!(
|
|
|
|
logger,
|
2023-09-14 12:21:57 -04:00
|
|
|
"{}{}{}",
|
|
|
|
colors::bold("-- "),
|
|
|
|
colors::bold_red("OUTPUT"),
|
|
|
|
colors::bold(" START --"),
|
2024-03-13 22:15:39 -04:00
|
|
|
)
|
|
|
|
.unwrap();
|
|
|
|
writeln!(logger, "{}", actual).unwrap();
|
|
|
|
writeln!(logger, "{}", colors::bold("-- OUTPUT END --")).unwrap();
|
|
|
|
writeln!(
|
|
|
|
logger,
|
2023-09-14 12:21:57 -04:00
|
|
|
"{}{}{}",
|
|
|
|
colors::bold("-- "),
|
|
|
|
colors::bold_green("EXPECTED"),
|
|
|
|
colors::bold(" START --"),
|
2024-03-13 22:15:39 -04:00
|
|
|
)
|
|
|
|
.unwrap();
|
|
|
|
writeln!(logger, "{}", expected).unwrap();
|
|
|
|
writeln!(logger, "{}", colors::bold("-- EXPECTED END --")).unwrap();
|
|
|
|
writeln!(
|
|
|
|
logger,
|
2023-09-14 12:21:57 -04:00
|
|
|
"{}{}{}",
|
|
|
|
colors::bold("-- "),
|
|
|
|
colors::bold_blue("DEBUG"),
|
|
|
|
colors::bold(" START --"),
|
2024-03-13 22:15:39 -04:00
|
|
|
)
|
|
|
|
.unwrap();
|
|
|
|
writeln!(logger, "{debug_output}").unwrap();
|
|
|
|
writeln!(logger, "{}", colors::bold("-- DEBUG END --")).unwrap();
|
2023-09-14 12:21:57 -04:00
|
|
|
panic!("pattern match failed");
|
|
|
|
}
|
|
|
|
}
|
2023-06-26 15:53:17 -04:00
|
|
|
}
|
|
|
|
}
|