#[doc(hidden)]
#[macro_export]
macro_rules! _function_name {
() => {{
fn f() {}
fn type_name_of_val<T>(_: T) -> &'static str {
$crate::_macro_support::any::type_name::<T>()
}
let mut name = type_name_of_val(f).strip_suffix("::f").unwrap_or("");
while let Some(rest) = name.strip_suffix("::{{closure}}") {
name = rest;
}
name
}};
}
#[doc(hidden)]
#[macro_export]
macro_rules! _get_workspace_root {
() => {{
use $crate::_macro_support::{env, option_env};
const WORKSPACE_ROOT: $crate::_macro_support::Workspace = if let Some(root) = option_env!("INSTA_WORKSPACE_ROOT") {
$crate::_macro_support::Workspace::UseAsIs(root)
} else {
$crate::_macro_support::Workspace::DetectWithCargo(env!("CARGO_MANIFEST_DIR"))
};
$crate::_macro_support::get_cargo_workspace(WORKSPACE_ROOT)
}};
}
#[cfg(feature = "csv")]
#[cfg_attr(docsrs, doc(cfg(feature = "csv")))]
#[macro_export]
macro_rules! assert_csv_snapshot {
($($arg:tt)*) => {
$crate::_assert_serialized_snapshot!(format=Csv, $($arg)*);
};
}
#[cfg(feature = "toml")]
#[cfg_attr(docsrs, doc(cfg(feature = "toml")))]
#[macro_export]
macro_rules! assert_toml_snapshot {
($($arg:tt)*) => {
$crate::_assert_serialized_snapshot!(format=Toml, $($arg)*);
};
}
#[cfg_attr(feature = "redactions", doc = " ```no_run")]
#[cfg_attr(not(feature = "redactions"), doc = " ```ignore")]
#[cfg(feature = "yaml")]
#[cfg_attr(docsrs, doc(cfg(feature = "yaml")))]
#[macro_export]
macro_rules! assert_yaml_snapshot {
($($arg:tt)*) => {
$crate::_assert_serialized_snapshot!(format=Yaml, $($arg)*);
};
}
#[cfg(feature = "ron")]
#[cfg_attr(docsrs, doc(cfg(feature = "ron")))]
#[macro_export]
macro_rules! assert_ron_snapshot {
($($arg:tt)*) => {
$crate::_assert_serialized_snapshot!(format=Ron, $($arg)*);
};
}
#[cfg(feature = "json")]
#[cfg_attr(docsrs, doc(cfg(feature = "json")))]
#[macro_export]
macro_rules! assert_json_snapshot {
($($arg:tt)*) => {
$crate::_assert_serialized_snapshot!(format=Json, $($arg)*);
};
}
#[cfg(feature = "json")]
#[cfg_attr(docsrs, doc(cfg(feature = "json")))]
#[macro_export]
macro_rules! assert_compact_json_snapshot {
($($arg:tt)*) => {
$crate::_assert_serialized_snapshot!(format=JsonCompact, $($arg)*);
};
}
#[doc(hidden)]
#[macro_export]
macro_rules! _assert_serialized_snapshot {
(format=$format:ident, $value:expr, $(match ..)? {$($k:expr => $v:expr),* $(,)?} $($arg:tt)*) => {{
let transform = |value| {
$crate::_prepare_snapshot_for_redaction!(value, {$($k => $v),*}, $format)
};
$crate::_assert_snapshot_base!(transform=transform, $value $($arg)*);
}};
(format=$format:ident, $name:expr, $value:expr, $(match ..)? {$($k:expr => $v:expr),* $(,)?}, $debug_expr:expr $(,)?) => {{
let transform = |value| {
$crate::_prepare_snapshot_for_redaction!(value, {$($k => $v),*}, $format)
};
$crate::_assert_snapshot_base!(transform=transform, $name, $value, $debug_expr);
}};
(format=$format:ident, $name:expr, $value:expr, $(match ..)? {$($k:expr => $v:expr),* $(,)?} $(,)?) => {{
let transform = |value| {
$crate::_prepare_snapshot_for_redaction!(value, {$($k => $v),*}, $format)
};
$crate::_assert_snapshot_base!(transform=transform, $name, $value);
}};
(format=$format:ident, $($arg:tt)*) => {{
let transform = |value| {$crate::_macro_support::serialize_value(
&value,
$crate::_macro_support::SerializationFormat::$format,
)};
$crate::_assert_snapshot_base!(transform=transform, $($arg)*);
}};
}
#[cfg(feature = "redactions")]
#[doc(hidden)]
#[macro_export]
macro_rules! _prepare_snapshot_for_redaction {
($value:expr, {$($k:expr => $v:expr),*}, $format:ident) => {
{
let vec = $crate::_macro_support::vec![
$((
$crate::_macro_support::Selector::parse($k).unwrap(),
$crate::_macro_support::Redaction::from($v)
),)*
];
$crate::_macro_support::serialize_value_redacted(
&$value,
&vec,
$crate::_macro_support::SerializationFormat::$format,
)
}
}
}
#[cfg(not(feature = "redactions"))]
#[doc(hidden)]
#[macro_export]
macro_rules! _prepare_snapshot_for_redaction {
($value:expr, {$($k:expr => $v:expr),*}, $format:ident) => {
compile_error!(
"insta was compiled without redactions support. Enable the `redactions` feature."
)
};
}
#[macro_export]
macro_rules! assert_debug_snapshot {
($($arg:tt)*) => {
$crate::_assert_snapshot_base!(transform=|v| $crate::_macro_support::format!("{:#?}", v), $($arg)*)
};
}
#[macro_export]
macro_rules! assert_compact_debug_snapshot {
($($arg:tt)*) => {
$crate::_assert_snapshot_base!(transform=|v| $crate::_macro_support::format!("{:?}", v), $($arg)*)
};
}
#[doc(hidden)]
#[macro_export]
macro_rules! _assert_snapshot_base {
(transform=$transform:expr, $($arg:expr),*, @$snapshot:literal $(,)?) => {
$crate::_assert_snapshot_base!(
transform = $transform,
#[allow(clippy::needless_raw_string_hashes)]
$crate::_macro_support::InlineValue($snapshot),
$($arg),*
)
};
(transform=$transform:expr, $name:expr, $value:expr $(,)?) => {
$crate::_assert_snapshot_base!(transform = $transform, $name, $value, stringify!($value))
};
(transform=$transform:expr, $value:expr $(,)?) => {
$crate::_assert_snapshot_base!(
transform = $transform,
$crate::_macro_support::AutoName,
$value
)
};
(transform=$transform:expr, $name:expr, $value:expr, $debug_expr:expr $(,)?) => {
$crate::_macro_support::assert_snapshot(
(
$name,
#[allow(clippy::redundant_closure_call)]
$transform(&$value).as_str(),
).into(),
$crate::_get_workspace_root!().as_path(),
$crate::_function_name!(),
$crate::_macro_support::module_path!(),
$crate::_macro_support::file!(),
$crate::_macro_support::line!(),
$debug_expr,
)
.unwrap()
};
}
#[macro_export]
macro_rules! assert_binary_snapshot {
($name_and_extension:expr, $value:expr $(,)?) => {
$crate::assert_binary_snapshot!($name_and_extension, $value, stringify!($value));
};
($name_and_extension:expr, $value:expr, $debug_expr:expr $(,)?) => {
$crate::_macro_support::assert_snapshot(
$crate::_macro_support::BinarySnapshotValue {
name_and_extension: $name_and_extension,
content: $value,
}
.into(),
$crate::_get_workspace_root!().as_path(),
$crate::_function_name!(),
$crate::_macro_support::module_path!(),
$crate::_macro_support::file!(),
$crate::_macro_support::line!(),
$debug_expr,
)
.unwrap()
};
}
#[macro_export]
#[deprecated = "use assert_snapshot!() instead"]
macro_rules! assert_display_snapshot {
($($arg:tt)*) => {
$crate::assert_snapshot!($($arg)*)
};
}
#[macro_export]
macro_rules! assert_snapshot {
($($arg:tt)*) => {
$crate::_assert_snapshot_base!(transform=|v| $crate::_macro_support::format!("{}", v), $($arg)*)
};
}
#[macro_export]
macro_rules! with_settings {
({$($k:ident => $v:expr),*$(,)?}, $body:block) => {{
let mut settings = $crate::Settings::clone_current();
$(
settings._private_inner_mut().$k($v);
)*
settings.bind(|| $body)
}}
}
#[cfg(feature = "glob")]
#[cfg_attr(docsrs, doc(cfg(feature = "glob")))]
#[macro_export]
macro_rules! glob {
($base_path:expr, $glob:expr, $closure:expr) => {{
use $crate::_macro_support::path::Path;
let base = $crate::_get_workspace_root!()
.join(Path::new(file!()).parent().unwrap())
.join($base_path)
.to_path_buf();
let base = base.canonicalize().unwrap_or_else(|_| base);
$crate::_macro_support::glob_exec(
$crate::_get_workspace_root!().as_path(),
&base,
$glob,
$closure,
);
}};
($glob:expr, $closure:expr) => {{
$crate::glob!(".", $glob, $closure)
}};
}
#[macro_export]
macro_rules! allow_duplicates {
($($x:tt)*) => {
$crate::_macro_support::with_allow_duplicates(|| {
$($x)*
})
}
}