Skip to content
Snippets Groups Projects
Select Git revision
  • 68d547e776bda540ec008cc9257d23d86f60298f
  • dev default protected
  • vainamoinen197-transactiondocument-replace-vec-fields-by-smallvec-2
  • dvermd/200-keypairs-dewif
  • elois/wot
  • jawaka/155-dbex-add-dump-fork-tree-command
  • elois/195-bcdbwriteop
  • elois/deps-crypto
  • elois/gva-monetary-mass
  • elois/191-sled
  • elois/195
  • ji_emme/gva-humantimefield
  • 184-gva-rename-commontime-field-to-blockchaintime
  • ji_emme/182-gva-implement-block-meta-data
  • ji_emme/rml14
  • hugo/151-ws2pv2-sync
  • ji_emme/181-gva-implement-identity-request
  • ji_emme/89-implement-client-api-gva-graphql-verification-api
  • logo
  • test-juniper-from-schema
  • elois/exemple-gva-global-context
  • v0.2.0-a4 protected
  • v0.2.0-a2 protected
  • v0.2.0-a protected
  • v0.1.1-a1 protected
  • documents/v0.10.0-b1 protected
  • crypto/v0.4.0-b1 protected
  • crypto/v0.3.0-b3 protected
  • crypto/v0.3.0-b2 protected
  • crypto/v0.3.0-b1 protected
  • wot/v0.8.0-a0.9 protected
  • wot/v0.8.0-a0.8 protected
  • 0.1.0-a0.1 protected
  • v0.0.1-a0.12 protected
  • v0.0.1-a0.11 protected
  • v0.0.1-a0.10 protected
  • v0.0.1-a0.9 protected
  • v0.0.1-a0.8 protected
  • v0.0.1-a0.7 protected
  • v0.0.1-a0.6 protected
  • v0.0.1-a0.5 protected
41 results

logger.rs

Blame
  • logger.rs 3.21 KiB
    //  Copyright (C) 2017-2019  The AXIOM TEAM Association.
    //
    // This program is free software: you can redistribute it and/or modify
    // it under the terms of the GNU Affero General Public License as
    // published by the Free Software Foundation, either version 3 of the
    // License, or (at your option) any later version.
    //
    // This program is distributed in the hope that it will be useful,
    // but WITHOUT ANY WARRANTY; without even the implied warranty of
    // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    // GNU Affero General Public License for more details.
    //
    // You should have received a copy of the GNU Affero General Public License
    // along with this program.  If not, see <https://www.gnu.org/licenses/>.
    
    //! Common test tools for DURS project.
    
    use fern::colors::{Color, ColoredLevelConfig};
    use log::LevelFilter;
    use std::sync::Once;
    
    static ONCE: Once = Once::new();
    
    /// Initialize stdout logger
    pub fn init_logger_stdout(off_targets: Vec<&'static str>) {
        ONCE.call_once(|| {
            init_logger_stdout_(off_targets);
        });
    }
    
    fn init_logger_stdout_(off_targets: Vec<&'static str>) {
        let colors = match std::env::var("DURS_TESTS_LOG_COLOR")
            .unwrap_or_else(|_| String::from("no"))
            .as_str()
        {
            "yes" => true,
            "no" => false,
            v => panic!(
                "Unexpected value '{}' for env var DURS_TESTS_LOG_COLOR !",
                v
            ),
        };
    
        let level_filter = match std::env::var("DURS_TESTS_LOG_LEVEL")
            .unwrap_or_else(|_| String::from("debug"))
            .as_str()
        {
            "off" => LevelFilter::Off,
            "error" => LevelFilter::Error,
            "warn" => LevelFilter::Warn,
            "info" => LevelFilter::Info,
            "debug" => LevelFilter::Debug,
            "trace" => LevelFilter::Trace,
            v => panic!(
                "Unexpected value '{}' for env var DURS_TESTS_LOG_LEVEL !",
                v
            ),
        };
    
        // Config logger
        let mut logger_config = fern::Dispatch::new()
            .level(level_filter)
            .format(move |out, message, record| {
                if colors {
                    let colors_config = ColoredLevelConfig::new()
                        .info(Color::Green)
                        .debug(Color::Cyan);
                    out.finish(format_args!(
                        "{}[{}:{}][{}] {}",
                        chrono::Local::now().format("[%Y-%m-%d][%H:%M:%S]"),
                        record.file_static().unwrap_or("unknown source file"),
                        record.line().unwrap_or(0),
                        colors_config.color(record.level()),
                        message
                    ))
                } else {
                    out.finish(format_args!(
                        "{}[{}:{}][{}] {}",
                        chrono::Local::now().format("[%Y-%m-%d][%H:%M:%S]"),
                        record.file_static().unwrap_or("unknown source file"),
                        record.line().unwrap_or(0),
                        record.level(),
                        message
                    ))
                }
            })
            .chain(std::io::stdout());
    
        for target in off_targets {
            logger_config = logger_config.level_for(target, LevelFilter::Off);
        }
    
        // Active stdout logger
        logger_config
            .apply()
            .expect("TESTS: fail to init stdout logger !");
    }