1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79
// Licensed to the Apache Software Foundation (ASF) under one
// or more contributor license agreements. See the NOTICE file
// distributed with this work for additional information
// regarding copyright ownership. The ASF licenses this file
// to you under the Apache License, Version 2.0 (the
// "License"); you may not use this file except in compliance
// with the License. You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing,
// software distributed under the License is distributed on an
// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
// KIND, either express or implied. See the License for the
// specific language governing permissions and limitations
// under the License.
use crate::LOG_MESSAGES;
use lazy_static::lazy_static;
use log::{LevelFilter, Log, Metadata};
use ref_thread_local::RefThreadLocal;
struct TestLogger {
delegate: env_logger::Logger,
}
impl Log for TestLogger {
#[inline]
fn enabled(&self, _metadata: &Metadata) -> bool {
true
}
fn log(&self, record: &log::Record) {
if self.enabled(record.metadata()) {
LOG_MESSAGES.borrow_mut().push(format!("{}", record.args()));
self.delegate.log(record);
}
}
fn flush(&self) {}
}
lazy_static! {
// Lazy static because the Logger has to be 'static
static ref TEST_LOGGER: TestLogger = TestLogger {
delegate: env_logger::Builder::from_default_env()
.filter_level(LevelFilter::Off)
.parse_default_env()
.build(),
};
}
pub fn clear_log_messages() {
LOG_MESSAGES.borrow_mut().clear();
}
pub fn assert_not_logged(unexpected_message: &str) {
match LOG_MESSAGES.borrow().last() {
Some(last_log) if last_log == unexpected_message => {
panic!("The following log message should not have been logged: '{unexpected_message}'")
}
_ => (),
}
}
pub fn assert_logged(expected_message: &str) {
assert_eq!(LOG_MESSAGES.borrow_mut().pop().unwrap(), expected_message);
}
#[cfg(not(target_arch = "wasm32"))]
pub(crate) fn install() {
log::set_logger(&*TEST_LOGGER)
.map(|_| log::set_max_level(LevelFilter::Trace))
.map_err(|err| {
eprintln!("Failed to set the custom logger: {err:?}");
})
.unwrap();
}