// Hi, future me (or whoever you are)! // // Yes, we do need this attr. // No, the warnings cannot be fixed otherwise. // Accept and endure. Do not touch. #![allow(unused)] use clap::CommandFactory; use snapbox::assert_data_eq; pub(crate) const FULL_TEMPLATE: &str = "\ {before-help}{name} {version} {author-with-newline}{about-with-newline} {usage-heading} {usage} {all-args}{after-help}"; pub(crate) fn get_help() -> String { let output = ::command().render_help().to_string(); eprintln!("\n%%% HELP %%%:=====\n{output}\n=====\n"); eprintln!("\n%%% HELP (DEBUG) %%%:=====\n{output:?}\n=====\n"); output } pub(crate) fn get_long_help() -> String { let output = ::command() .render_long_help() .to_string(); eprintln!("\n%%% LONG_HELP %%%:=====\n{output}\n=====\n"); eprintln!("\n%%% LONG_HELP (DEBUG) %%%:=====\n{output:?}\n=====\n"); output } pub(crate) fn get_subcommand_long_help(subcmd: &str) -> String { let output = ::command() .get_subcommands_mut() .find(|s| s.get_name() == subcmd) .unwrap() .render_long_help() .to_string(); eprintln!("\n%%% SUBCOMMAND `{subcmd}` HELP %%%:=====\n{output}\n=====\n",); eprintln!("\n%%% SUBCOMMAND `{subcmd}` HELP (DEBUG) %%%:=====\n{output:?}\n=====\n",); output } #[track_caller] pub(crate) fn assert_output( args: &str, expected: impl snapbox::IntoData, stderr: bool, ) { let res = P::try_parse_from(args.split(' ').collect::>()); let err = res.unwrap_err(); let actual = err.render().to_string(); assert_eq!( stderr, err.use_stderr(), "Should Use STDERR failed. Should be {} but is {}", stderr, err.use_stderr() ); assert_data_eq!(actual, expected); }