【发布时间】:2021-04-22 22:05:05
【问题描述】:
我正在按照这个解决方法来获取信息!,记录!等正在进行测试:
https://stackoverflow.com/a/67105052/5884503
这就是我所做的。我创建了要在我们测试的情况下导入的代理函数,如下所示:
#[cfg(not(test))]
use log::{info, error}; // Use log crate when building application
#[cfg(test)]
use crate::{info, error}; // Workaround to use prinltn! for logs.
这里是:
#[macro_export]
macro_rules! info {
(target: $target:expr, $($arg:tt)*) => { println!("target: {}, info: {}", $target, $($arg),*) };
($($arg:tt)*) => { println!("info: {}", $($arg),*) };
}
#[macro_export]
macro_rules! error {
(target: $target:expr, $($arg:tt)*) => { printn!("target: {}, info: {}", $target, $($arg),*) };
($($arg:tt)*) => { println!("error: {}", $($arg),*) };
}
然后我这样调用:
error!("Unauthorized message has authentication header but WwwAuthenticate fails to parse. RTSP Message: {:?}", message);
但我明白了:
error: expected expression, found `,`
--> src/rtsp_machine.rs:440:96
|
440 | "Unauthorized message has no AuthenticationInfo header. RTSP Message: {:?}",
| ^ expected expression
宏参数中的重复有问题,但我不知道具体是什么
【问题讨论】: