2022-09-19 16:54:06 +00:00
#![ cfg(feature = " help " ) ]
2022-08-01 14:02:52 +00:00
use clap ::{ arg , builder ::PossibleValue , error ::ErrorKind , Arg , ArgAction , ArgGroup , Command } ;
2024-05-24 15:13:50 +00:00
use snapbox ::assert_data_eq ;
use snapbox ::str ;
2016-05-09 03:20:50 +00:00
2022-09-19 14:59:04 +00:00
use super ::utils ;
2022-08-15 19:29:46 +00:00
fn setup ( ) -> Command {
2022-02-12 03:48:29 +00:00
Command ::new ( " test " )
2016-01-13 17:03:27 +00:00
. author ( " Kevin K. " )
. about ( " tests stuff " )
. version ( " 1.3 " )
2017-11-22 09:09:51 +00:00
}
2020-08-18 18:50:17 +00:00
fn empty_args ( ) -> impl IntoIterator < Item = String > {
std ::iter ::empty ( )
}
2017-11-22 09:09:51 +00:00
#[ test ]
fn help_short ( ) {
2018-10-19 20:42:13 +00:00
let m = setup ( ) . try_get_matches_from ( vec! [ " myprog " , " -h " ] ) ;
2016-01-13 17:03:27 +00:00
assert! ( m . is_err ( ) ) ;
2022-01-25 22:19:28 +00:00
assert_eq! ( m . unwrap_err ( ) . kind ( ) , ErrorKind ::DisplayHelp ) ;
2016-01-13 17:03:27 +00:00
}
#[ test ]
fn help_long ( ) {
2018-10-19 20:42:13 +00:00
let m = setup ( ) . try_get_matches_from ( vec! [ " myprog " , " --help " ] ) ;
2016-01-13 17:03:27 +00:00
assert! ( m . is_err ( ) ) ;
2022-01-25 22:19:28 +00:00
assert_eq! ( m . unwrap_err ( ) . kind ( ) , ErrorKind ::DisplayHelp ) ;
2016-01-13 17:03:27 +00:00
}
2015-09-09 02:39:31 +00:00
2016-01-15 04:23:50 +00:00
#[ test ]
fn help_no_subcommand ( ) {
2018-10-19 20:42:13 +00:00
let m = setup ( ) . try_get_matches_from ( vec! [ " myprog " , " help " ] ) ;
2016-01-15 04:23:50 +00:00
assert! ( m . is_err ( ) ) ;
2022-01-25 22:19:28 +00:00
assert_eq! ( m . unwrap_err ( ) . kind ( ) , ErrorKind ::UnknownArgument ) ;
2016-01-15 04:23:50 +00:00
}
#[ test ]
fn help_subcommand ( ) {
2017-11-22 09:09:51 +00:00
let m = setup ( )
2018-01-25 04:05:05 +00:00
. subcommand (
2022-02-12 03:48:29 +00:00
Command ::new ( " test " )
2018-01-25 04:05:05 +00:00
. about ( " tests things " )
2021-11-19 20:33:11 +00:00
. arg ( arg! ( - v - - verbose " with verbosity " ) ) ,
2018-01-25 04:05:05 +00:00
)
2018-10-19 20:42:13 +00:00
. try_get_matches_from ( vec! [ " myprog " , " help " ] ) ;
2016-01-15 04:23:50 +00:00
assert! ( m . is_err ( ) ) ;
2022-01-25 22:19:28 +00:00
assert_eq! ( m . unwrap_err ( ) . kind ( ) , ErrorKind ::DisplayHelp ) ;
2016-01-15 04:23:50 +00:00
}
2017-11-22 09:09:51 +00:00
2022-04-30 01:25:05 +00:00
#[ test ]
2022-09-19 14:59:04 +00:00
#[ cfg(feature = " error-context " ) ]
2022-04-30 01:25:05 +00:00
fn help_multi_subcommand_error ( ) {
let cmd = Command ::new ( " ctest " ) . subcommand (
Command ::new ( " subcmd " ) . subcommand (
Command ::new ( " multi " )
. about ( " tests subcommands " )
. author ( " Kevin K. <kbknapp@gmail.com> " )
. version ( " 0.1 " )
. arg ( arg! (
- f - - flag " tests flags "
) )
. arg (
arg! (
- o - - option < scoption > " tests options "
)
. required ( false )
2022-08-03 16:20:07 +00:00
. num_args ( 1 .. )
2022-06-07 18:48:48 +00:00
. action ( ArgAction ::Append ) ,
2022-04-30 01:25:05 +00:00
) ,
) ,
) ;
let err = cmd
. try_get_matches_from ( [ " ctest " , " help " , " subcmd " , " multi " , " foo " ] )
. unwrap_err ( ) ;
2024-07-08 22:15:54 +00:00
assert_data_eq! (
err . to_string ( ) ,
str ! [ [ r #"
2024-05-24 15:13:50 +00:00
error : unrecognized subcommand ' foo '
2022-04-30 01:25:05 +00:00
2022-09-07 16:03:55 +00:00
Usage : ctest subcmd multi [ OPTIONS ]
2022-04-30 01:25:05 +00:00
2023-01-03 19:22:35 +00:00
For more information , try ' - - help ' .
2024-05-24 15:13:50 +00:00
2024-07-31 20:58:24 +00:00
" #]]
) ;
2022-04-30 01:25:05 +00:00
}
2017-05-07 00:18:11 +00:00
#[ test ]
fn req_last_arg_usage ( ) {
2022-02-14 21:47:20 +00:00
let cmd = Command ::new ( " example " )
2021-10-11 19:42:17 +00:00
. version ( " 1.0 " )
2022-08-03 16:20:07 +00:00
. arg ( Arg ::new ( " FIRST " ) . help ( " First " ) . num_args ( 1 .. ) . required ( true ) )
2021-10-11 19:42:17 +00:00
. arg (
Arg ::new ( " SECOND " )
2021-11-18 16:17:15 +00:00
. help ( " Second " )
2022-08-03 16:20:07 +00:00
. num_args ( 1 .. )
2021-10-11 19:42:17 +00:00
. required ( true )
. last ( true ) ,
) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
Usage : example < FIRST > .. . - - < SECOND > .. .
2022-07-22 20:43:49 +00:00
2022-08-26 14:40:23 +00:00
Arguments :
2024-07-31 20:58:24 +00:00
< FIRST > .. . First
< SECOND > .. . Second
2022-07-22 20:43:49 +00:00
2022-08-26 14:40:23 +00:00
Options :
2024-07-31 20:58:24 +00:00
- h , - - help Print help
- V , - - version Print version
" #]];
utils ::assert_output ( cmd , " example --help " , expected , false ) ;
}
2022-07-22 20:43:49 +00:00
2024-07-31 20:58:24 +00:00
#[ test ]
fn args_with_last_usage ( ) {
2022-02-14 21:47:20 +00:00
let cmd = Command ::new ( " flamegraph " )
2017-05-06 23:52:12 +00:00
. version ( " 0.1 " )
2018-01-25 04:05:05 +00:00
. arg (
2020-05-14 20:50:56 +00:00
Arg ::new ( " verbose " )
2021-11-18 16:17:15 +00:00
. help ( " Prints out more stuff. " )
2018-07-23 19:09:42 +00:00
. short ( 'v' )
2018-01-25 04:05:05 +00:00
. long ( " verbose " )
2022-06-07 18:48:48 +00:00
. action ( ArgAction ::SetTrue ) ,
2018-11-14 17:05:06 +00:00
)
. arg (
2020-05-14 20:50:56 +00:00
Arg ::new ( " timeout " )
2021-11-18 16:17:15 +00:00
. help ( " Timeout in seconds. " )
2018-07-23 19:09:42 +00:00
. short ( 't' )
2018-01-25 04:05:05 +00:00
. long ( " timeout " )
2018-01-31 20:15:01 +00:00
. value_name ( " SECONDS " ) ,
2018-11-14 17:05:06 +00:00
)
. arg (
2020-05-14 20:50:56 +00:00
Arg ::new ( " frequency " )
2021-11-18 16:17:15 +00:00
. help ( " The sampling frequency. " )
2018-07-23 19:09:42 +00:00
. short ( 'f' )
2018-01-25 04:05:05 +00:00
. long ( " frequency " )
2018-01-31 20:15:01 +00:00
. value_name ( " HERTZ " ) ,
2018-11-14 17:05:06 +00:00
)
. arg (
2020-05-14 20:50:56 +00:00
Arg ::new ( " binary path " )
2021-11-18 16:17:15 +00:00
. help ( " The path of the binary to be profiled. for a binary. " )
2018-01-25 04:05:05 +00:00
. value_name ( " BINFILE " ) ,
2018-11-14 17:05:06 +00:00
)
. arg (
2020-05-14 20:50:56 +00:00
Arg ::new ( " pass through args " )
2021-11-18 16:17:15 +00:00
. help ( " Any arguments you wish to pass to the being profiled. " )
2022-07-26 00:17:01 +00:00
. action ( ArgAction ::Set )
2022-08-03 16:20:07 +00:00
. num_args ( 1 .. )
2021-11-29 14:56:30 +00:00
. last ( true )
2018-11-14 17:05:06 +00:00
. value_name ( " ARGS " ) ,
2017-05-06 23:52:12 +00:00
) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
Usage : flamegraph [ OPTIONS ] [ BINFILE ] [ - - < ARGS > .. . ]
Arguments :
[ BINFILE ] The path of the binary to be profiled . for a binary .
[ ARGS ] .. . Any arguments you wish to pass to the being profiled .
Options :
- v , - - verbose Prints out more stuff .
- t , - - timeout < SECONDS > Timeout in seconds .
- f , - - frequency < HERTZ > The sampling frequency .
- h , - - help Print help
- V , - - version Print version
" #]];
utils ::assert_output ( cmd , " flamegraph --help " , expected , false ) ;
2017-05-06 23:52:12 +00:00
}
2015-09-09 02:39:31 +00:00
#[ test ]
2016-05-09 03:20:50 +00:00
fn subcommand_short_help ( ) {
2020-02-04 08:10:53 +00:00
let m = utils ::complex_app ( ) . try_get_matches_from ( vec! [ " clap-test " , " subcmd " , " -h " ] ) ;
2015-09-09 02:39:31 +00:00
2016-05-09 03:20:50 +00:00
assert! ( m . is_err ( ) ) ;
2022-01-25 22:19:28 +00:00
assert_eq! ( m . unwrap_err ( ) . kind ( ) , ErrorKind ::DisplayHelp ) ;
2016-05-09 03:20:50 +00:00
}
2015-09-09 02:39:31 +00:00
2016-05-09 03:20:50 +00:00
#[ test ]
fn subcommand_long_help ( ) {
2020-02-04 08:10:53 +00:00
let m = utils ::complex_app ( ) . try_get_matches_from ( vec! [ " clap-test " , " subcmd " , " --help " ] ) ;
2015-09-09 02:39:31 +00:00
2016-05-09 03:20:50 +00:00
assert! ( m . is_err ( ) ) ;
2022-01-25 22:19:28 +00:00
assert_eq! ( m . unwrap_err ( ) . kind ( ) , ErrorKind ::DisplayHelp ) ;
2016-05-09 03:20:50 +00:00
}
2015-09-09 02:39:31 +00:00
2016-05-09 03:20:50 +00:00
#[ test ]
fn subcommand_help_rev ( ) {
2020-02-04 08:10:53 +00:00
let m = utils ::complex_app ( ) . try_get_matches_from ( vec! [ " clap-test " , " help " , " subcmd " ] ) ;
2016-05-09 03:20:50 +00:00
assert! ( m . is_err ( ) ) ;
2022-01-25 22:19:28 +00:00
assert_eq! ( m . unwrap_err ( ) . kind ( ) , ErrorKind ::DisplayHelp ) ;
2015-09-09 02:39:31 +00:00
}
2016-02-02 08:13:43 +00:00
#[ test ]
2016-05-09 03:20:50 +00:00
fn complex_help_output ( ) {
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2022-08-31 14:29:00 +00:00
clap - test v1 . 4.8
2022-07-22 20:43:49 +00:00
Kevin K . < kbknapp @ gmail . com >
tests clap library
2022-09-07 16:03:55 +00:00
Usage : clap - test [ OPTIONS ] [ positional ] [ positional2 ] [ positional3 ] .. . [ COMMAND ]
2022-07-22 20:43:49 +00:00
2022-08-31 02:38:37 +00:00
Commands :
2022-09-07 20:29:15 +00:00
subcmd tests subcommands
help Print this message or the help of the given subcommand ( s )
2022-08-26 15:59:27 +00:00
2022-08-26 14:40:23 +00:00
Arguments :
2022-09-07 20:29:15 +00:00
[ positional ] tests positionals
[ positional2 ] tests positionals with exclusions
[ positional3 ] .. . tests specific values [ possible values : vi , emacs ]
Options :
- o , - - option < opt > .. . tests options
- f , - - flag .. . tests flags
- F tests flags with exclusions
- - long - option - 2 < option2 > tests long options with exclusions
- O , - - option3 < option3 > specific vals [ possible values : fast , slow ]
- - multvals < one > < two > Tests multiple values , not mult occs
- - multvalsmo < one > < two > Tests multiple values , and mult occs
- - minvals2 < minvals > < minvals > .. . Tests 2 min vals
- - maxvals3 < maxvals > .. . Tests 3 max vals
- - optvaleq [ = < optval > ] Tests optional value , require = sign
- - optvalnoeq [ < optval > ] Tests optional value
2023-01-03 16:49:43 +00:00
- h , - - help Print help
- V , - - version Print version
2022-07-22 20:43:49 +00:00
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( utils ::complex_app ( ) , " clap-test --help " , expected , false ) ;
2016-05-09 03:20:50 +00:00
}
2016-02-02 08:13:43 +00:00
2016-05-30 10:01:00 +00:00
#[ test ]
fn after_and_before_help_output ( ) {
2024-07-31 20:58:24 +00:00
let cmd = Command ::new ( " clap-test " )
. version ( " v1.4.8 " )
. about ( " tests clap library " )
. before_help ( " some text that comes before the help " )
. after_help ( " some text that comes after the help " ) ;
let expected = str ! [ [ r #"
some text that comes before the help
2022-07-22 20:43:49 +00:00
tests clap library
2022-09-07 16:03:55 +00:00
Usage : clap - test
2022-07-22 20:43:49 +00:00
2022-08-26 14:40:23 +00:00
Options :
2023-01-03 16:49:43 +00:00
- h , - - help Print help
- V , - - version Print version
2022-07-22 20:43:49 +00:00
some text that comes after the help
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd . clone ( ) , " clap-test -h " , expected , false ) ;
2016-05-30 10:01:00 +00:00
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
some text that comes before the help
2022-07-22 20:43:49 +00:00
tests clap library
2022-09-07 16:03:55 +00:00
Usage : clap - test
2022-07-22 20:43:49 +00:00
2022-08-26 14:40:23 +00:00
Options :
2024-07-31 20:58:24 +00:00
- h , - - help Print help
2023-01-03 16:49:43 +00:00
- V , - - version Print version
2022-07-22 20:43:49 +00:00
some text that comes after the help
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " clap-test --help " , expected , false ) ;
}
#[ test ]
fn after_and_before_long_help_output ( ) {
let cmd = Command ::new ( " clap-test " )
. version ( " v1.4.8 " )
. about ( " tests clap library " )
. before_help ( " some text that comes before the help " )
. after_help ( " some text that comes after the help " )
. before_long_help ( " some longer text that comes before the help " )
. after_long_help ( " some longer text that comes after the help " ) ;
let expected = str ! [ [ r #"
some longer text that comes before the help
2022-07-22 20:43:49 +00:00
tests clap library
2022-09-07 16:03:55 +00:00
Usage : clap - test
2022-07-22 20:43:49 +00:00
2022-08-26 14:40:23 +00:00
Options :
2022-09-07 20:29:15 +00:00
- h , - - help
2023-01-03 16:49:43 +00:00
Print help ( see a summary with ' - h ' )
2022-07-22 20:43:49 +00:00
2022-09-07 20:29:15 +00:00
- V , - - version
2023-01-03 16:49:43 +00:00
Print version
2022-07-22 20:43:49 +00:00
some longer text that comes after the help
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd . clone ( ) , " clap-test --help " , expected , false ) ;
2020-07-11 15:06:57 +00:00
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
some text that comes before the help
2022-07-22 20:43:49 +00:00
2024-07-31 20:58:24 +00:00
tests clap library
Usage : clap - test
2022-07-22 20:43:49 +00:00
2022-08-26 14:40:23 +00:00
Options :
2024-07-31 20:58:24 +00:00
- h , - - help Print help ( see more with ' - - help ' )
- V , - - version Print version
some text that comes after the help
" #]];
utils ::assert_output ( cmd , " clap-test -h " , expected , false ) ;
}
2022-07-22 20:43:49 +00:00
2016-08-20 21:14:18 +00:00
#[ test ]
fn multi_level_sc_help ( ) {
2022-02-14 21:47:20 +00:00
let cmd = Command ::new ( " ctest " ) . subcommand (
2022-02-12 03:48:29 +00:00
Command ::new ( " subcmd " ) . subcommand (
Command ::new ( " multi " )
2018-01-25 04:05:05 +00:00
. about ( " tests subcommands " )
. author ( " Kevin K. <kbknapp@gmail.com> " )
. version ( " 0.1 " )
2021-11-19 20:33:11 +00:00
. arg ( arg! (
- f - - flag " tests flags "
2021-11-18 20:17:31 +00:00
) )
2021-11-19 20:33:11 +00:00
. arg (
arg! (
- o - - option < scoption > " tests options "
)
. required ( false )
2022-08-03 16:20:07 +00:00
. num_args ( 1 .. )
2022-06-07 18:48:48 +00:00
. action ( ArgAction ::Append ) ,
2021-11-19 20:33:11 +00:00
) ,
2018-01-25 04:05:05 +00:00
) ,
) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
tests subcommands
Usage : ctest subcmd multi [ OPTIONS ]
Options :
- f , - - flag tests flags
- o , - - option < scoption > .. . tests options
- h , - - help Print help
- V , - - version Print version
" #]];
utils ::assert_output ( cmd , " ctest help subcmd multi " , expected , false ) ;
2016-08-20 21:14:18 +00:00
}
2017-09-06 23:19:08 +00:00
#[ test ]
fn no_wrap_default_help ( ) {
2024-07-31 20:58:24 +00:00
let cmd = Command ::new ( " ctest " ) . version ( " 1.0 " ) . term_width ( 0 ) ;
let expected = str ! [ [ r #"
2022-09-07 16:03:55 +00:00
Usage : ctest
2022-07-22 20:43:49 +00:00
2022-08-26 14:40:23 +00:00
Options :
2023-01-03 16:49:43 +00:00
- h , - - help Print help
- V , - - version Print version
2022-07-22 20:43:49 +00:00
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " ctest --help " , expected , false ) ;
2017-09-06 23:19:08 +00:00
}
2024-07-08 22:15:54 +00:00
#[ test ]
fn try_help_default ( ) {
2024-07-31 20:58:24 +00:00
let cmd = Command ::new ( " ctest " ) . version ( " 1.0 " ) . term_width ( 0 ) ;
let expected = str ! [ [ r #"
2024-07-08 22:15:54 +00:00
error : unexpected argument ' bar ' found
Usage : ctest
For more information , try ' - - help ' .
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " ctest bar " , expected , true ) ;
2024-07-08 22:15:54 +00:00
}
#[ test ]
fn try_help_custom_flag ( ) {
let cmd = Command ::new ( " ctest " )
. version ( " 1.0 " )
. disable_help_flag ( true )
. arg (
Arg ::new ( " help " )
. long ( " help " )
. short ( 'h' )
. action ( ArgAction ::Help ) ,
)
. term_width ( 0 ) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2024-07-08 22:15:54 +00:00
error : unexpected argument ' bar ' found
Usage : ctest
2024-07-08 22:29:42 +00:00
2024-07-31 20:58:24 +00:00
For more information , try ' - - help ' .
" #]];
utils ::assert_output ( cmd , " ctest bar " , expected , true ) ;
}
2024-07-08 22:15:54 +00:00
2024-07-31 20:58:24 +00:00
#[ test ]
fn try_help_custom_flag_short ( ) {
2024-07-08 22:15:54 +00:00
let cmd = Command ::new ( " ctest " )
. version ( " 1.0 " )
. disable_help_flag ( true )
. arg ( Arg ::new ( " help " ) . short ( 'h' ) . action ( ArgAction ::HelpShort ) )
. term_width ( 0 ) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2024-07-08 22:15:54 +00:00
error : unexpected argument ' bar ' found
Usage : ctest
2024-07-08 22:29:42 +00:00
2024-07-31 20:58:24 +00:00
For more information , try ' - h ' .
" #]];
utils ::assert_output ( cmd , " ctest bar " , expected , true ) ;
}
2024-07-08 22:15:54 +00:00
2024-07-31 20:58:24 +00:00
#[ test ]
fn try_help_custom_flag_long ( ) {
2024-07-08 22:15:54 +00:00
let cmd = Command ::new ( " ctest " )
. version ( " 1.0 " )
. disable_help_flag ( true )
. arg ( Arg ::new ( " help " ) . long ( " help " ) . action ( ArgAction ::HelpShort ) )
. term_width ( 0 ) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2024-07-08 22:15:54 +00:00
error : unexpected argument ' bar ' found
Usage : ctest
2024-07-31 20:58:24 +00:00
For more information , try ' - - help ' .
" #]];
utils ::assert_output ( cmd , " ctest bar " , expected , true ) ;
}
#[ test ]
fn try_help_custom_flag_no_action ( ) {
2024-07-08 22:15:54 +00:00
let cmd = Command ::new ( " ctest " )
. version ( " 1.0 " )
. disable_help_flag ( true )
// Note `ArgAction::Help` is excluded
. arg ( Arg ::new ( " help " ) . long ( " help " ) . global ( true ) )
. term_width ( 0 ) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
error : unexpected argument ' bar ' found
2024-07-08 22:15:54 +00:00
2024-07-31 20:58:24 +00:00
Usage : ctest
2024-07-08 22:15:54 +00:00
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " ctest bar " , expected , true ) ;
}
2024-07-08 22:15:54 +00:00
2024-07-31 20:58:24 +00:00
#[ test ]
fn try_help_subcommand_default ( ) {
2024-07-08 22:15:54 +00:00
let cmd = Command ::new ( " ctest " )
. version ( " 1.0 " )
. subcommand ( Command ::new ( " foo " ) )
. term_width ( 0 ) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2024-07-08 22:15:54 +00:00
error : unrecognized subcommand ' bar '
Usage : ctest [ COMMAND ]
2024-07-08 22:29:42 +00:00
For more information , try ' - - help ' .
2024-07-08 22:15:54 +00:00
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " ctest bar " , expected , true ) ;
}
#[ test ]
fn try_help_subcommand_custom_flag ( ) {
2024-07-08 22:15:54 +00:00
let cmd = Command ::new ( " ctest " )
. version ( " 1.0 " )
. disable_help_flag ( true )
. arg (
Arg ::new ( " help " )
. long ( " help " )
. short ( 'h' )
. action ( ArgAction ::Help )
. global ( true ) ,
)
. subcommand ( Command ::new ( " foo " ) )
. term_width ( 0 ) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2024-07-08 22:15:54 +00:00
error : unrecognized subcommand ' bar '
Usage : ctest [ COMMAND ]
2024-07-31 20:58:24 +00:00
For more information , try ' - - help ' .
" #]];
utils ::assert_output ( cmd , " ctest bar " , expected , true ) ;
}
2024-07-08 22:15:54 +00:00
2024-07-31 20:58:24 +00:00
#[ test ]
fn try_help_subcommand_custom_flag_no_action ( ) {
2024-07-08 22:15:54 +00:00
let cmd = Command ::new ( " ctest " )
. version ( " 1.0 " )
. disable_help_flag ( true )
// Note `ArgAction::Help` is excluded
. arg ( Arg ::new ( " help " ) . long ( " help " ) . global ( true ) )
. subcommand ( Command ::new ( " foo " ) )
. term_width ( 0 ) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
error : unrecognized subcommand ' bar '
Usage : ctest [ COMMAND ]
For more information , try ' help ' .
" #]];
utils ::assert_output ( cmd , " ctest bar " , expected , true ) ;
2024-07-08 22:15:54 +00:00
}
2020-10-25 13:09:14 +00:00
#[ test ]
#[ cfg(feature = " wrap_help " ) ]
fn wrapped_help ( ) {
2022-02-14 21:47:20 +00:00
let cmd = Command ::new ( " test " )
2020-10-25 13:09:14 +00:00
. term_width ( 67 )
. arg (
Arg ::new ( " all " )
. short ( 'a' )
. long ( " all " )
2022-08-05 18:31:33 +00:00
. action ( ArgAction ::SetTrue )
2021-11-18 16:17:15 +00:00
. help ( " Also do versioning for private crates (will not be published) " ) ,
2020-10-25 13:09:14 +00:00
)
. arg (
Arg ::new ( " exact " )
. long ( " exact " )
2022-08-05 18:31:33 +00:00
. action ( ArgAction ::SetTrue )
2021-11-18 16:17:15 +00:00
. help ( " Specify inter dependency version numbers exactly with `=` " ) ,
2020-10-25 13:09:14 +00:00
)
. arg (
Arg ::new ( " no_git_commit " )
. long ( " no-git-commit " )
2022-08-05 18:31:33 +00:00
. action ( ArgAction ::SetTrue )
2021-11-18 16:17:15 +00:00
. help ( " Do not commit version changes " ) ,
2020-10-25 13:09:14 +00:00
)
. arg (
Arg ::new ( " no_git_push " )
. long ( " no-git-push " )
2022-08-05 18:31:33 +00:00
. action ( ArgAction ::SetTrue )
2021-11-18 16:17:15 +00:00
. help ( " Do not push generated commit and tags to git remote " ) ,
2024-07-31 21:03:39 +00:00
)
. subcommand (
Command ::new ( " sub1 " )
. about ( " One two three four five six seven eight nine ten eleven twelve thirteen fourteen fifteen " )
2020-10-25 13:09:14 +00:00
) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2024-07-31 21:03:39 +00:00
Usage : test [ OPTIONS ] [ COMMAND ]
Commands :
sub1 One two three four five six seven eight nine ten eleven
2024-07-31 21:16:52 +00:00
twelve thirteen fourteen fifteen
help Print this message or the help of the given subcommand ( s )
2020-10-25 13:09:14 +00:00
2022-08-26 14:40:23 +00:00
Options :
2022-09-07 20:29:15 +00:00
- a , - - all Also do versioning for private crates ( will
not be published )
- - exact Specify inter dependency version numbers
exactly with ` = `
- - no - git - commit Do not commit version changes
- - no - git - push Do not push generated commit and tags to git
remote
2023-01-03 16:49:43 +00:00
- h , - - help Print help
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " test --help " , expected , false ) ;
}
#[ test ]
#[ cfg(feature = " wrap_help " ) ]
fn unwrapped_help ( ) {
2022-02-14 21:47:20 +00:00
let cmd = Command ::new ( " test " )
2020-10-25 13:09:14 +00:00
. term_width ( 68 )
. arg (
Arg ::new ( " all " )
. short ( 'a' )
. long ( " all " )
2022-08-05 18:31:33 +00:00
. action ( ArgAction ::SetTrue )
2021-11-18 16:17:15 +00:00
. help ( " Also do versioning for private crates (will not be published) " ) ,
2020-10-25 13:09:14 +00:00
)
. arg (
Arg ::new ( " exact " )
. long ( " exact " )
2022-08-05 18:31:33 +00:00
. action ( ArgAction ::SetTrue )
2021-11-18 16:17:15 +00:00
. help ( " Specify inter dependency version numbers exactly with `=` " ) ,
2020-10-25 13:09:14 +00:00
)
. arg (
Arg ::new ( " no_git_commit " )
. long ( " no-git-commit " )
2022-08-05 18:31:33 +00:00
. action ( ArgAction ::SetTrue )
2021-11-18 16:17:15 +00:00
. help ( " Do not commit version changes " ) ,
2020-10-25 13:09:14 +00:00
)
. arg (
Arg ::new ( " no_git_push " )
. long ( " no-git-push " )
2022-08-05 18:31:33 +00:00
. action ( ArgAction ::SetTrue )
2021-11-18 16:17:15 +00:00
. help ( " Do not push generated commit and tags to git remote " ) ,
2024-07-31 21:03:39 +00:00
)
. subcommand (
Command ::new ( " sub1 " )
. about ( " One two three four five six seven eight nine ten eleven twelve thirteen fourteen fifteen " )
2020-10-25 13:09:14 +00:00
) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2024-07-31 21:03:39 +00:00
Usage : test [ OPTIONS ] [ COMMAND ]
Commands :
sub1 One two three four five six seven eight nine ten eleven
2024-07-31 21:16:52 +00:00
twelve thirteen fourteen fifteen
help Print this message or the help of the given subcommand ( s )
2022-03-02 15:15:28 +00:00
2022-08-26 14:40:23 +00:00
Options :
2024-07-31 20:58:24 +00:00
- a , - - all Also do versioning for private crates ( will
not be published )
- - exact Specify inter dependency version numbers
exactly with ` = `
- - no - git - commit Do not commit version changes
- - no - git - push Do not push generated commit and tags to git
remote
- h , - - help Print help
2022-03-02 15:15:28 +00:00
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " test --help " , expected , false ) ;
}
2022-07-22 20:43:49 +00:00
2024-07-31 20:58:24 +00:00
#[ test ]
#[ cfg(feature = " wrap_help " ) ]
fn possible_value_wrapped_help ( ) {
2022-03-02 15:15:28 +00:00
let cmd = Command ::new ( " test " )
. term_width ( 67 )
. arg (
Arg ::new ( " possible_values " )
. long ( " possible-values " )
2022-07-26 00:17:01 +00:00
. action ( ArgAction ::Set )
2022-05-24 01:16:02 +00:00
. value_parser ( [
2022-03-02 15:15:28 +00:00
PossibleValue ::new ( " short_name " )
. help ( " Long enough help message, barely warrant wrapping " ) ,
PossibleValue ::new ( " second " ) . help ( " Short help gets handled the same " ) ,
2022-05-24 01:16:02 +00:00
] ) ,
2022-03-02 15:15:28 +00:00
)
. arg (
Arg ::new ( " possible_values_with_new_line " )
. long ( " possible-values-with-new-line " )
2022-07-26 00:17:01 +00:00
. action ( ArgAction ::Set )
2022-05-24 01:16:02 +00:00
. value_parser ( [
2022-03-02 15:15:28 +00:00
PossibleValue ::new ( " long enough name to trigger new line " ) . help (
" Really long enough help message to clearly warrant wrapping believe me " ,
) ,
2022-05-24 01:16:02 +00:00
PossibleValue ::new ( " second " ) ,
] ) ,
2022-03-02 15:15:28 +00:00
)
. arg (
Arg ::new ( " possible_values_without_new_line " )
. long ( " possible-values-without-new-line " )
2022-07-26 00:17:01 +00:00
. action ( ArgAction ::Set )
2022-05-24 01:16:02 +00:00
. value_parser ( [
2022-03-02 15:15:28 +00:00
PossibleValue ::new ( " name " ) . help ( " Short enough help message with no wrapping " ) ,
2022-05-24 01:16:02 +00:00
PossibleValue ::new ( " second " ) . help ( " short help " ) ,
] ) ,
2022-03-02 15:15:28 +00:00
) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
Usage : test [ OPTIONS ]
Options :
- - possible - values < possible_values >
Possible values :
- short_name : Long enough help message , barely warrant
wrapping
- second : Short help gets handled the same
- - possible - values - with - new - line < possible_values_with_new_line >
Possible values :
- long enough name to trigger new line : Really long
enough help message to clearly warrant wrapping believe
me
- second
- - possible - values - without - new - line < possible_values_without_new_line >
Possible values :
- name : Short enough help message with no wrapping
- second : short help
- h , - - help
Print help ( see a summary with ' - h ' )
" #]];
utils ::assert_output ( cmd , " test --help " , expected , false ) ;
}
#[ test ]
2016-05-09 03:20:50 +00:00
fn complex_subcommand_help_output ( ) {
2024-07-31 20:58:24 +00:00
let a = utils ::complex_app ( ) ;
let expected = str ! [ [ r #"
clap - test - subcmd 0.1
2022-07-22 20:43:49 +00:00
Kevin K . < kbknapp @ gmail . com >
tests subcommands
2022-09-07 16:03:55 +00:00
Usage : clap - test subcmd [ OPTIONS ] [ scpositional ]
2022-07-22 20:43:49 +00:00
2022-08-26 14:40:23 +00:00
Arguments :
2022-09-07 20:29:15 +00:00
[ scpositional ] tests positionals
2022-07-22 20:43:49 +00:00
2022-08-26 14:40:23 +00:00
Options :
2022-09-07 20:29:15 +00:00
- o , - - option < scoption > .. . tests options
- f , - - flag .. . tests flags
- s , - - subcmdarg < subcmdarg > tests other args
2023-01-03 16:49:43 +00:00
- h , - - help Print help
- V , - - version Print version
2022-07-22 20:43:49 +00:00
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( a , " clap-test subcmd --help " , expected , false ) ;
2016-02-02 08:13:43 +00:00
}
2016-08-25 01:50:20 +00:00
#[ test ]
2022-09-26 16:35:18 +00:00
#[ cfg(feature = " wrap_help " ) ]
2016-08-25 01:50:20 +00:00
fn issue_626_unicode_cutoff ( ) {
2022-02-14 21:47:20 +00:00
let cmd = Command ::new ( " ctest " ) . version ( " 0.1 " ) . term_width ( 70 ) . arg (
2020-05-14 20:50:56 +00:00
Arg ::new ( " cafe " )
2018-07-23 19:09:42 +00:00
. short ( 'c' )
2017-02-21 04:51:20 +00:00
. long ( " cafe " )
. value_name ( " FILE " )
2021-11-18 16:17:15 +00:00
. help (
2018-01-25 04:05:05 +00:00
" A coffeehouse, coffee shop, or café is an establishment \
2022-09-07 20:29:15 +00:00
which primarily serves hot coffee , related coffee beverages \
( e . g . , café latte , cappuccino , espresso ) , tea , and other hot \
beverages . Some coffeehouses also serve cold beverages such as \
iced coffee and iced tea . Many cafés also serve some type of \
food , such as light snacks , muffins , or pastries . " ,
2018-11-14 17:05:06 +00:00
)
2022-07-26 00:17:01 +00:00
. action ( ArgAction ::Set ) ,
2018-01-25 04:05:05 +00:00
) ;
2016-08-25 01:50:20 +00:00
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2022-09-07 16:03:55 +00:00
Usage : ctest [ OPTIONS ]
2022-07-22 20:43:49 +00:00
2022-08-26 14:40:23 +00:00
Options :
2024-07-31 20:58:24 +00:00
- c , - - cafe < FILE > A coffeehouse , coffee shop , or café is an
establishment which primarily serves hot coffee ,
related coffee beverages ( e . g . , café latte ,
cappuccino , espresso ) , tea , and other hot
beverages . Some coffeehouses also serve cold
beverages such as iced coffee and iced tea . Many
cafés also serve some type of food , such as light
snacks , muffins , or pastries .
2023-01-03 16:49:43 +00:00
- h , - - help Print help
- V , - - version Print version
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " ctest --help " , expected , false ) ;
}
2022-07-22 20:43:49 +00:00
2016-09-11 03:08:40 +00:00
#[ test ]
fn hide_possible_vals ( ) {
2022-02-14 21:47:20 +00:00
let cmd = Command ::new ( " ctest " )
2016-09-11 03:08:40 +00:00
. version ( " 0.1 " )
2018-01-25 04:05:05 +00:00
. arg (
2020-05-14 20:50:56 +00:00
Arg ::new ( " pos " )
2018-07-23 19:09:42 +00:00
. short ( 'p' )
2018-01-25 04:05:05 +00:00
. long ( " pos " )
. value_name ( " VAL " )
2022-05-24 01:16:02 +00:00
. value_parser ( [ " fast " , " slow " ] )
2021-11-18 16:17:15 +00:00
. help ( " Some vals " )
2022-07-26 00:17:01 +00:00
. action ( ArgAction ::Set ) ,
2018-11-14 17:05:06 +00:00
)
. arg (
2020-05-14 20:50:56 +00:00
Arg ::new ( " cafe " )
2018-07-23 19:09:42 +00:00
. short ( 'c' )
2018-01-25 04:05:05 +00:00
. long ( " cafe " )
. value_name ( " FILE " )
. hide_possible_values ( true )
2022-05-24 01:16:02 +00:00
. value_parser ( [ " fast " , " slow " ] )
2021-11-18 16:17:15 +00:00
. help ( " A coffeehouse, coffee shop, or café. " )
2022-07-26 00:17:01 +00:00
. action ( ArgAction ::Set ) ,
2021-09-19 10:29:09 +00:00
) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
Usage : ctest [ OPTIONS ]
Options :
- p , - - pos < VAL > Some vals [ possible values : fast , slow ]
- c , - - cafe < FILE > A coffeehouse , coffee shop , or café .
- h , - - help Print help
- V , - - version Print version
" #]];
utils ::assert_output ( cmd , " ctest --help " , expected , false ) ;
2021-09-19 10:29:09 +00:00
}
#[ test ]
fn hide_single_possible_val ( ) {
2022-02-14 21:47:20 +00:00
let cmd = Command ::new ( " ctest " )
2021-09-19 10:29:09 +00:00
. version ( " 0.1 " )
. arg (
Arg ::new ( " pos " )
. short ( 'p' )
. long ( " pos " )
. value_name ( " VAL " )
2022-05-24 01:16:02 +00:00
. value_parser ( [
" fast " . into ( ) ,
" slow " . into ( ) ,
PossibleValue ::new ( " secret speed " ) . hide ( true ) ,
] )
2021-11-18 16:17:15 +00:00
. help ( " Some vals " )
2022-07-26 00:17:01 +00:00
. action ( ArgAction ::Set ) ,
2021-09-19 10:29:09 +00:00
)
. arg (
Arg ::new ( " cafe " )
. short ( 'c' )
. long ( " cafe " )
. value_name ( " FILE " )
2021-11-18 16:17:15 +00:00
. help ( " A coffeehouse, coffee shop, or café. " )
2022-07-26 00:17:01 +00:00
. action ( ArgAction ::Set ) ,
2018-01-25 04:05:05 +00:00
) ;
2016-09-11 03:08:40 +00:00
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2022-09-07 16:03:55 +00:00
Usage : ctest [ OPTIONS ]
2022-03-02 15:15:28 +00:00
2022-08-26 14:40:23 +00:00
Options :
2024-07-31 20:58:24 +00:00
- p , - - pos < VAL > Some vals [ possible values : fast , slow ]
- c , - - cafe < FILE > A coffeehouse , coffee shop , or café .
- h , - - help Print help
- V , - - version Print version
2022-07-22 20:43:49 +00:00
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " ctest --help " , expected , false ) ;
}
2022-07-22 20:43:49 +00:00
2024-07-31 20:58:24 +00:00
#[ test ]
fn possible_vals_with_help ( ) {
2022-03-02 15:15:28 +00:00
let app = Command ::new ( " ctest " )
. version ( " 0.1 " )
. arg (
Arg ::new ( " pos " )
. short ( 'p' )
. long ( " pos " )
. value_name ( " VAL " )
2022-05-24 01:16:02 +00:00
. value_parser ( [
PossibleValue ::new ( " fast " ) ,
PossibleValue ::new ( " slow " ) . help ( " not as fast " ) ,
PossibleValue ::new ( " secret speed " ) . hide ( true ) ,
] )
2022-03-02 15:15:28 +00:00
. help ( " Some vals " )
2022-07-26 00:17:01 +00:00
. action ( ArgAction ::Set ) ,
2022-03-02 15:15:28 +00:00
)
. arg (
Arg ::new ( " cafe " )
. short ( 'c' )
. long ( " cafe " )
. value_name ( " FILE " )
. help ( " A coffeehouse, coffee shop, or café. " )
2022-07-26 00:17:01 +00:00
. action ( ArgAction ::Set ) ,
2022-03-02 15:15:28 +00:00
) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
Usage : ctest [ OPTIONS ]
Options :
- p , - - pos < VAL >
Some vals
Possible values :
- fast
- slow : not as fast
- c , - - cafe < FILE >
A coffeehouse , coffee shop , or café .
- h , - - help
Print help ( see a summary with ' - h ' )
- V , - - version
Print version
" #]];
utils ::assert_output ( app , " ctest --help " , expected , false ) ;
2022-03-02 15:15:28 +00:00
}
2023-02-15 17:33:35 +00:00
#[ test ]
fn hidden_possible_vals ( ) {
let app = Command ::new ( " ctest " ) . arg (
Arg ::new ( " pos " )
. hide_possible_values ( true )
. value_parser ( [
PossibleValue ::new ( " fast " ) ,
PossibleValue ::new ( " slow " ) . help ( " not as fast " ) ,
] )
. action ( ArgAction ::Set ) ,
) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
Usage : ctest [ pos ]
Arguments :
[ pos ]
Options :
- h , - - help Print help
" #]];
utils ::assert_output ( app , " ctest --help " , expected , false ) ;
2023-02-15 17:33:35 +00:00
}
2016-08-25 01:50:20 +00:00
#[ test ]
2022-09-26 16:35:18 +00:00
#[ cfg(feature = " wrap_help " ) ]
2016-08-25 01:50:20 +00:00
fn issue_626_panic ( ) {
2024-07-31 20:58:24 +00:00
let cmd = Command ::new ( " ctest " )
. version ( " 0.1 " )
. term_width ( 52 )
. arg ( Arg ::new ( " cafe " )
. short ( 'c' )
. long ( " cafe " )
. value_name ( " FILE " )
. help ( " La culture du café est très développée dans de nombreux pays à climat chaud d'Amérique, \
d ' Afrique et d ' Asie , dans des plantations qui sont cultivées pour les marchés d ' exportation . \
Le café est souvent une contribution majeure aux exportations des régions productrices . " )
. action ( ArgAction ::Set ) ) ;
let expected = str ! [ [ r #"
2022-09-07 16:03:55 +00:00
Usage : ctest [ OPTIONS ]
2022-07-22 20:43:49 +00:00
2022-08-26 14:40:23 +00:00
Options :
2022-09-07 20:29:15 +00:00
- c , - - cafe < FILE >
La culture du café est très développée
dans de nombreux pays à climat chaud
2024-07-31 20:58:24 +00:00
d ' Amérique , d ' Afrique et d ' Asie , dans des
2022-09-07 20:29:15 +00:00
plantations qui sont cultivées pour les
2024-07-31 20:58:24 +00:00
marchés d ' exportation . Le café est souvent
2022-09-07 20:29:15 +00:00
une contribution majeure aux exportations
des régions productrices .
- h , - - help
2023-01-03 16:49:43 +00:00
Print help
2022-09-07 20:29:15 +00:00
- V , - - version
2023-01-03 16:49:43 +00:00
Print version
2022-07-22 20:43:49 +00:00
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " ctest --help " , expected , false ) ;
2016-08-25 01:50:20 +00:00
}
2016-08-25 22:50:48 +00:00
#[ test ]
2022-09-26 16:35:18 +00:00
#[ cfg(feature = " wrap_help " ) ]
2016-08-25 22:50:48 +00:00
fn issue_626_variable_panic ( ) {
for i in 10 .. 320 {
2022-02-12 03:48:29 +00:00
let _ = Command ::new ( " ctest " )
2016-08-25 22:50:48 +00:00
. version ( " 0.1 " )
2020-05-18 07:51:36 +00:00
. term_width ( i )
2020-05-14 20:50:56 +00:00
. arg ( Arg ::new ( " cafe " )
2018-07-23 19:09:42 +00:00
. short ( 'c' )
2016-08-25 22:50:48 +00:00
. long ( " cafe " )
. value_name ( " FILE " )
2021-11-18 16:17:15 +00:00
. help ( " La culture du café est très développée dans de nombreux pays à climat chaud d'Amérique, \
2016-08-25 22:50:48 +00:00
d ' Afrique et d ' Asie , dans des plantations qui sont cultivées pour les marchés d ' exportation . \
Le café est souvent une contribution majeure aux exportations des régions productrices . " )
2022-07-26 00:17:01 +00:00
. action ( ArgAction ::Set ) )
2018-10-19 20:42:13 +00:00
. try_get_matches_from ( vec! [ " ctest " , " --help " ] ) ;
2016-08-25 22:50:48 +00:00
}
}
2016-09-13 03:20:40 +00:00
2017-01-29 19:54:47 +00:00
#[ test ]
2022-09-26 16:35:18 +00:00
#[ cfg(feature = " wrap_help " ) ]
2017-01-29 19:54:47 +00:00
fn final_word_wrapping ( ) {
2024-07-31 20:58:24 +00:00
let cmd = Command ::new ( " ctest " ) . version ( " 0.1 " ) . term_width ( 24 ) ;
let expected = str ! [ [ r #"
2022-09-07 16:03:55 +00:00
Usage : ctest
2022-07-22 20:43:49 +00:00
2022-08-26 14:40:23 +00:00
Options :
2022-09-07 20:29:15 +00:00
- h , - - help
Print help
- V , - - version
Print version
2022-07-22 20:43:49 +00:00
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " ctest --help " , expected , false ) ;
2017-01-29 19:54:47 +00:00
}
2022-09-26 16:35:18 +00:00
#[ test ]
#[ cfg(feature = " wrap_help " ) ]
fn wrapping_newline_chars ( ) {
2024-07-31 20:58:24 +00:00
let cmd = Command ::new ( " ctest " )
. version ( " 0.1 " )
. term_width ( 60 )
. arg ( Arg ::new ( " mode " ) . help (
" x, max, maximum 20 characters, contains symbols. \n \
l , long Copy - friendly , 14 characters , contains symbols . \ n \
m , med , medium Copy - friendly , 8 characters , contains symbols . \ n " ,
) ) ;
let expected = str ! [ [ r #"
2022-09-07 16:03:55 +00:00
Usage : ctest [ mode ]
2022-07-22 20:43:49 +00:00
2022-08-26 14:40:23 +00:00
Arguments :
2022-09-07 20:29:15 +00:00
[ mode ] x , max , maximum 20 characters , contains symbols .
l , long Copy - friendly , 14 characters ,
contains symbols .
m , med , medium Copy - friendly , 8 characters ,
contains symbols .
2022-07-22 20:43:49 +00:00
2022-08-26 14:40:23 +00:00
Options :
2023-01-03 16:49:43 +00:00
- h , - - help Print help
- V , - - version Print version
2022-07-22 20:43:49 +00:00
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " ctest --help " , expected , false ) ;
}
#[ test ]
#[ cfg(feature = " wrap_help " ) ]
fn wrapped_indentation ( ) {
2022-02-14 21:47:20 +00:00
let cmd = Command ::new ( " ctest " )
2020-05-14 20:50:56 +00:00
. version ( " 0.1 " )
2020-05-18 07:51:36 +00:00
. term_width ( 60 )
2021-11-18 16:17:15 +00:00
. arg ( Arg ::new ( " mode " ) . help (
2024-07-31 20:58:24 +00:00
" Some values:
- l , long Copy - friendly , 14 characters , contains symbols .
- m , med , medium Copy - friendly , 8 characters , contains symbols . " ,
2020-05-14 20:50:56 +00:00
) ) ;
2017-01-29 20:38:30 +00:00
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2023-04-19 15:15:38 +00:00
Usage : ctest [ mode ]
Arguments :
[ mode ] Some values :
- l , long Copy - friendly , 14
2023-04-19 16:55:53 +00:00
characters , contains symbols .
2023-04-19 15:15:38 +00:00
- m , med , medium Copy - friendly , 8 characters ,
2023-04-19 16:55:53 +00:00
contains symbols .
2023-04-19 15:15:38 +00:00
Options :
- h , - - help Print help
- V , - - version Print version
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " ctest --help " , expected , false ) ;
}
#[ test ]
#[ cfg(feature = " wrap_help " ) ]
fn wrapping_newline_variables ( ) {
2023-04-19 15:15:38 +00:00
let cmd = Command ::new ( " ctest " )
. version ( " 0.1 " )
. term_width ( 60 )
. arg ( Arg ::new ( " mode " ) . help (
2024-07-31 20:58:24 +00:00
" x, max, maximum 20 characters, contains symbols.{n} \
l , long Copy - friendly , 14 characters , contains symbols . { n } \
m , med , medium Copy - friendly , 8 characters , contains symbols . { n } " ,
2023-04-19 15:15:38 +00:00
) ) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2022-09-26 16:35:18 +00:00
Usage : ctest [ mode ]
Arguments :
[ mode ] x , max , maximum 20 characters , contains symbols .
l , long Copy - friendly , 14 characters ,
contains symbols .
m , med , medium Copy - friendly , 8 characters ,
contains symbols .
Options :
2023-01-03 16:49:43 +00:00
- h , - - help Print help
- V , - - version Print version
2022-09-26 16:35:18 +00:00
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " ctest --help " , expected , false ) ;
2021-12-30 17:08:53 +00:00
}
2022-05-04 21:00:05 +00:00
#[ test ]
2022-09-26 16:35:18 +00:00
#[ cfg(feature = " wrap_help " ) ]
2022-05-04 21:00:05 +00:00
fn dont_wrap_urls ( ) {
let cmd = Command ::new ( " Example " )
. term_width ( 30 )
. subcommand ( Command ::new ( " update " ) . arg (
Arg ::new ( " force-non-host " )
. help ( " Install toolchains that require an emulator. See https://github.com/rust-lang/rustup/wiki/Non-host-toolchains " )
. long ( " force-non-host " )
2022-07-29 21:36:03 +00:00
. action ( ArgAction ::SetTrue ) )
2022-05-04 21:00:05 +00:00
) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2022-09-07 16:03:55 +00:00
Usage : Example update [ OPTIONS ]
2022-05-04 21:00:05 +00:00
2022-08-26 14:40:23 +00:00
Options :
2022-09-07 20:29:15 +00:00
- - force - non - host
Install toolchains
that require an
emulator . See
https ://github.com/rust-lang/rustup/wiki/Non-host-toolchains
- h , - - help
Print help
2022-07-22 20:43:49 +00:00
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " Example update --help " , expected , false ) ;
}
2022-07-22 20:43:49 +00:00
2016-09-13 03:20:40 +00:00
#[ test ]
fn old_newline_chars ( ) {
2022-02-14 21:47:20 +00:00
let cmd = Command ::new ( " ctest " ) . version ( " 0.1 " ) . arg (
2020-05-14 20:50:56 +00:00
Arg ::new ( " mode " )
2018-07-23 19:09:42 +00:00
. short ( 'm' )
2022-07-26 00:17:01 +00:00
. action ( ArgAction ::SetTrue )
2021-11-18 16:17:15 +00:00
. help ( " Some help with some wrapping \n (Defaults to something) " ) ,
2018-01-25 04:05:05 +00:00
) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
Usage : ctest [ OPTIONS ]
Options :
- m Some help with some wrapping
( Defaults to something )
- h , - - help Print help
- V , - - version Print version
" #]];
utils ::assert_output ( cmd , " ctest --help " , expected , false ) ;
2016-09-13 03:20:40 +00:00
}
2016-10-20 23:37:39 +00:00
2021-12-30 17:08:53 +00:00
#[ test ]
fn old_newline_variables ( ) {
2022-02-14 21:47:20 +00:00
let cmd = Command ::new ( " ctest " ) . version ( " 0.1 " ) . arg (
2021-12-30 17:08:53 +00:00
Arg ::new ( " mode " )
. short ( 'm' )
2022-07-26 00:17:01 +00:00
. action ( ArgAction ::SetTrue )
2021-12-30 17:08:53 +00:00
. help ( " Some help with some wrapping{n}(Defaults to something) " ) ,
) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
Usage : ctest [ OPTIONS ]
Options :
- m Some help with some wrapping
( Defaults to something )
- h , - - help Print help
- V , - - version Print version
" #]];
utils ::assert_output ( cmd , " ctest --help " , expected , false ) ;
2021-12-30 17:08:53 +00:00
}
2016-10-20 23:37:39 +00:00
#[ test ]
2022-09-26 16:35:18 +00:00
#[ cfg(feature = " wrap_help " ) ]
2021-11-29 16:45:30 +00:00
fn issue_688_hide_pos_vals ( ) {
2023-07-17 14:40:49 +00:00
#[ cfg(not(feature = " unstable-v5 " )) ]
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2022-09-07 16:03:55 +00:00
Usage : ctest [ OPTIONS ]
2022-07-22 20:43:49 +00:00
2022-08-26 14:40:23 +00:00
Options :
2022-09-07 20:29:15 +00:00
- - filter < filter > Sets the filter , or sampling method , to use for interpolation when resizing the particle
images . The default is Linear ( Bilinear ) . [ possible values : Nearest , Linear , Cubic , Gaussian ,
Lanczos3 ]
2023-01-03 16:49:43 +00:00
- h , - - help Print help
- V , - - version Print version
2024-07-31 20:58:24 +00:00
" #]];
2022-07-22 20:43:49 +00:00
2023-07-17 14:40:49 +00:00
#[ cfg(feature = " unstable-v5 " ) ]
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2023-07-17 14:40:49 +00:00
Usage : ctest [ OPTIONS ]
Options :
- - filter < filter > Sets the filter , or sampling method , to use for interpolation when resizing
the particle images . The default is Linear ( Bilinear ) . [ possible values :
Nearest , Linear , Cubic , Gaussian , Lanczos3 ]
- h , - - help Print help
- V , - - version Print version
2024-07-31 20:58:24 +00:00
" #]];
2023-07-17 14:40:49 +00:00
2017-02-21 04:51:20 +00:00
let filter_values = [ " Nearest " , " Linear " , " Cubic " , " Gaussian " , " Lanczos3 " ] ;
2016-10-20 23:37:39 +00:00
2022-02-12 03:48:29 +00:00
let app1 = Command ::new ( " ctest " )
2022-09-07 20:29:15 +00:00
. version ( " 0.1 " )
2020-05-18 07:51:36 +00:00
. term_width ( 120 )
2022-02-10 17:51:40 +00:00
. hide_possible_values ( true )
2020-05-14 20:50:56 +00:00
. arg ( Arg ::new ( " filter " )
2021-11-18 16:17:15 +00:00
. help ( " Sets the filter, or sampling method, to use for interpolation when resizing the particle \
2022-09-07 20:29:15 +00:00
images . The default is Linear ( Bilinear ) . [ possible values : Nearest , Linear , Cubic , Gaussian , Lanczos3 ] " )
2016-10-20 23:37:39 +00:00
. long ( " filter " )
2022-05-24 01:16:02 +00:00
. value_parser ( filter_values )
2022-07-26 00:17:01 +00:00
. action ( ArgAction ::Set ) ) ;
2024-07-31 20:58:24 +00:00
utils ::assert_output ( app1 , " ctest --help " , expected . clone ( ) , false ) ;
2016-10-20 23:37:39 +00:00
2022-02-12 03:48:29 +00:00
let app2 = Command ::new ( " ctest " )
2022-09-07 20:29:15 +00:00
. version ( " 0.1 " )
2020-05-18 07:51:36 +00:00
. term_width ( 120 )
2020-05-14 20:50:56 +00:00
. arg ( Arg ::new ( " filter " )
2021-11-18 16:17:15 +00:00
. help ( " Sets the filter, or sampling method, to use for interpolation when resizing the particle \
2022-09-07 20:29:15 +00:00
images . The default is Linear ( Bilinear ) . " )
2016-10-20 23:37:39 +00:00
. long ( " filter " )
2022-05-24 01:16:02 +00:00
. value_parser ( filter_values )
2022-07-26 00:17:01 +00:00
. action ( ArgAction ::Set ) ) ;
2024-07-31 20:58:24 +00:00
utils ::assert_output ( app2 , " ctest --help " , expected . clone ( ) , false ) ;
2016-10-20 23:37:39 +00:00
2022-02-12 03:48:29 +00:00
let app3 = Command ::new ( " ctest " )
2022-09-07 20:29:15 +00:00
. version ( " 0.1 " )
2020-05-18 07:51:36 +00:00
. term_width ( 120 )
2020-05-14 20:50:56 +00:00
. arg ( Arg ::new ( " filter " )
2021-11-18 16:17:15 +00:00
. help ( " Sets the filter, or sampling method, to use for interpolation when resizing the particle \
2022-09-07 20:29:15 +00:00
images . The default is Linear ( Bilinear ) . [ possible values : Nearest , Linear , Cubic , Gaussian , Lanczos3 ] " )
2016-10-20 23:37:39 +00:00
. long ( " filter " )
2022-07-26 00:17:01 +00:00
. action ( ArgAction ::Set ) ) ;
2024-07-31 20:58:24 +00:00
utils ::assert_output ( app3 , " ctest --help " , expected . clone ( ) , false ) ;
2016-10-24 09:56:21 +00:00
}
#[ test ]
fn issue_702_multiple_values ( ) {
2022-02-14 21:47:20 +00:00
let cmd = Command ::new ( " myapp " )
2016-10-24 09:56:21 +00:00
. version ( " 1.0 " )
. author ( " foo " )
. about ( " bar " )
2021-11-18 16:17:15 +00:00
. arg ( Arg ::new ( " arg1 " ) . help ( " some option " ) )
2021-02-24 15:07:57 +00:00
. arg (
Arg ::new ( " arg2 " )
2022-07-26 00:17:01 +00:00
. action ( ArgAction ::Set )
2022-08-03 16:20:07 +00:00
. num_args ( 1 .. )
2021-11-18 16:17:15 +00:00
. help ( " some option " ) ,
2021-02-24 15:07:57 +00:00
)
2018-01-25 04:05:05 +00:00
. arg (
2020-05-14 20:50:56 +00:00
Arg ::new ( " some " )
2021-11-18 16:17:15 +00:00
. help ( " some option " )
2018-07-23 19:09:42 +00:00
. short ( 's' )
2018-01-25 04:05:05 +00:00
. long ( " some " )
2022-07-26 00:17:01 +00:00
. action ( ArgAction ::Set ) ,
2018-11-14 17:05:06 +00:00
)
. arg (
2020-05-14 20:50:56 +00:00
Arg ::new ( " other " )
2021-11-18 16:17:15 +00:00
. help ( " some other option " )
2018-07-23 19:09:42 +00:00
. short ( 'o' )
2018-01-25 04:05:05 +00:00
. long ( " other " )
2022-07-26 00:17:01 +00:00
. action ( ArgAction ::Set ) ,
2018-11-14 17:05:06 +00:00
)
. arg (
2020-05-14 20:50:56 +00:00
Arg ::new ( " label " )
2021-11-18 16:17:15 +00:00
. help ( " a label " )
2018-07-23 19:09:42 +00:00
. short ( 'l' )
2018-01-25 04:05:05 +00:00
. long ( " label " )
2022-08-03 16:20:07 +00:00
. num_args ( 1 .. )
2022-07-26 00:17:01 +00:00
. action ( ArgAction ::Set ) ,
2018-01-25 04:05:05 +00:00
) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
bar
Usage : myapp [ OPTIONS ] [ arg1 ] [ arg2 ] .. .
Arguments :
[ arg1 ] some option
[ arg2 ] .. . some option
Options :
- s , - - some < some > some option
- o , - - other < other > some other option
- l , - - label < label > .. . a label
- h , - - help Print help
- V , - - version Print version
" #]];
utils ::assert_output ( cmd , " myapp --help " , expected , false ) ;
2016-12-01 23:47:20 +00:00
}
2017-09-13 18:41:49 +00:00
#[ test ]
fn long_about ( ) {
2024-07-31 20:58:24 +00:00
let cmd = Command ::new ( " myapp " )
. version ( " 1.0 " )
. author ( " foo " )
. about ( " bar " )
. long_about (
" something really really long, with \n multiple lines of text \n that should be displayed " ,
)
. arg ( Arg ::new ( " arg1 " ) . help ( " some option " ) ) ;
let expected = str ! [ [ r #"
2022-07-22 20:43:49 +00:00
something really really long , with
multiple lines of text
that should be displayed
2022-09-07 16:03:55 +00:00
Usage : myapp [ arg1 ]
2022-07-22 20:43:49 +00:00
2022-08-26 14:40:23 +00:00
Arguments :
2022-09-07 20:29:15 +00:00
[ arg1 ]
some option
2022-07-22 20:43:49 +00:00
2022-08-26 14:40:23 +00:00
Options :
2022-09-07 20:29:15 +00:00
- h , - - help
2023-01-03 16:49:43 +00:00
Print help ( see a summary with ' - h ' )
2022-07-22 20:43:49 +00:00
2022-09-07 20:29:15 +00:00
- V , - - version
2023-01-03 16:49:43 +00:00
Print version
2022-07-22 20:43:49 +00:00
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " myapp --help " , expected , false ) ;
}
#[ test ]
fn explicit_short_long_help ( ) {
2022-02-14 21:47:20 +00:00
let cmd = Command ::new ( " myapp " )
2024-07-31 20:58:24 +00:00
. disable_help_flag ( true )
2017-09-13 18:41:49 +00:00
. version ( " 1.0 " )
. author ( " foo " )
. about ( " bar " )
2018-01-25 04:05:05 +00:00
. long_about (
" something really really long, with \n multiple lines of text \n that should be displayed " ,
2018-11-14 17:05:06 +00:00
)
2024-07-31 20:58:24 +00:00
. arg ( Arg ::new ( " arg1 " ) . help ( " some option " ) )
. arg ( Arg ::new ( " short " ) . short ( '?' ) . action ( ArgAction ::HelpShort ) )
. arg (
Arg ::new ( " long " )
. short ( 'h' )
. long ( " help " )
. action ( ArgAction ::HelpLong ) ,
) ;
2017-09-13 18:41:49 +00:00
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2023-07-17 15:37:26 +00:00
bar
2023-07-17 15:40:42 +00:00
Usage : myapp [ arg1 ]
2023-07-17 15:37:26 +00:00
Arguments :
[ arg1 ] some option
Options :
- ?
- h , - - help
- V , - - version Print version
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd . clone ( ) , " myapp -? " , expected , false ) ;
let expected = str ! [ [ r #"
2023-07-17 15:37:26 +00:00
something really really long , with
multiple lines of text
that should be displayed
2023-07-17 15:40:42 +00:00
Usage : myapp [ arg1 ]
2023-07-17 15:37:26 +00:00
Arguments :
[ arg1 ]
some option
Options :
- ?
- h , - - help
- V , - - version
Print version
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd . clone ( ) , " myapp -h " , expected , false ) ;
2023-07-17 15:37:26 +00:00
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
something really really long , with
multiple lines of text
that should be displayed
Usage : myapp [ arg1 ]
Arguments :
[ arg1 ]
some option
2022-07-22 20:43:49 +00:00
2022-08-26 14:40:23 +00:00
Options :
2024-07-31 20:58:24 +00:00
- ?
- h , - - help
- V , - - version
Print version
" #]];
utils ::assert_output ( cmd , " myapp --help " , expected , false ) ;
}
2022-07-22 20:43:49 +00:00
2024-07-31 20:58:24 +00:00
#[ test ]
fn ripgrep_usage ( ) {
2022-02-14 21:47:20 +00:00
let cmd = Command ::new ( " ripgrep " ) . version ( " 0.5 " ) . override_usage (
2018-01-25 04:05:05 +00:00
" rg [OPTIONS] <pattern> [<path> ...]
2022-09-07 16:03:55 +00:00
rg [ OPTIONS ] [ - e PATTERN | - f FILE ] .. . [ < path > .. . ]
rg [ OPTIONS ] - - files [ < path > .. . ]
rg [ OPTIONS ] - - type - list " ,
2018-01-25 04:05:05 +00:00
) ;
2017-03-24 03:51:43 +00:00
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2022-09-07 16:03:55 +00:00
Usage : rg [ OPTIONS ] < pattern > [ < path > .. . ]
rg [ OPTIONS ] [ - e PATTERN | - f FILE ] .. . [ < path > .. . ]
rg [ OPTIONS ] - - files [ < path > .. . ]
rg [ OPTIONS ] - - type - list
2022-08-31 14:29:00 +00:00
Options :
2023-01-03 16:49:43 +00:00
- h , - - help Print help
- V , - - version Print version
2022-08-31 14:29:00 +00:00
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " rg --help " , expected , false ) ;
}
#[ test ]
fn ripgrep_usage_using_templates ( ) {
2022-12-21 15:47:53 +00:00
#[ cfg(not(feature = " unstable-v5 " )) ]
let cmd = Command ::new ( " ripgrep " )
. version ( " 0.5 " )
. override_usage (
" \
rg [ OPTIONS ] < pattern > [ < path > .. . ]
rg [ OPTIONS ] [ - e PATTERN | - f FILE ] .. . [ < path > .. . ]
rg [ OPTIONS ] - - files [ < path > .. . ]
rg [ OPTIONS ] - - type - list " ,
)
. help_template (
" \
{ bin } { version }
Usage : { usage }
Options :
{ options } " ,
) ;
#[ cfg(feature = " unstable-v5 " ) ]
2022-02-14 21:47:20 +00:00
let cmd = Command ::new ( " ripgrep " )
2017-03-30 17:30:23 +00:00
. version ( " 0.5 " )
2018-10-19 20:42:13 +00:00
. override_usage (
2022-09-07 16:03:55 +00:00
" \
rg [ OPTIONS ] < pattern > [ < path > .. . ]
rg [ OPTIONS ] [ - e PATTERN | - f FILE ] .. . [ < path > .. . ]
rg [ OPTIONS ] - - files [ < path > .. . ]
rg [ OPTIONS ] - - type - list " ,
2018-01-25 04:05:05 +00:00
)
2018-10-19 20:42:13 +00:00
. help_template (
2018-01-25 04:05:05 +00:00
" \
2022-12-21 00:58:03 +00:00
{ name } { version }
2017-03-30 17:30:23 +00:00
2022-09-07 16:03:55 +00:00
Usage : { usage }
2017-03-30 17:30:23 +00:00
2022-08-26 14:40:23 +00:00
Options :
2021-10-11 22:01:33 +00:00
{ options } " ,
2018-01-25 04:05:05 +00:00
) ;
2017-03-30 17:30:23 +00:00
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
ripgrep 0.5
Usage : rg [ OPTIONS ] < pattern > [ < path > .. . ]
rg [ OPTIONS ] [ - e PATTERN | - f FILE ] .. . [ < path > .. . ]
rg [ OPTIONS ] - - files [ < path > .. . ]
rg [ OPTIONS ] - - type - list
Options :
- h , - - help Print help
- V , - - version Print version
" #]];
utils ::assert_output ( cmd , " rg --help " , expected , false ) ;
2017-03-24 03:51:43 +00:00
}
2017-03-09 13:52:37 +00:00
#[ test ]
fn sc_negates_reqs ( ) {
2024-07-31 20:58:24 +00:00
let cmd = Command ::new ( " prog " )
. version ( " 1.0 " )
. subcommand_negates_reqs ( true )
. arg ( arg! ( - o - - opt < FILE > " tests options " ) . required ( true ) )
. arg ( Arg ::new ( " PATH " ) . help ( " help " ) )
. subcommand ( Command ::new ( " test " ) ) ;
let expected = str ! [ [ r #"
2022-09-07 16:03:55 +00:00
Usage : prog - - opt < FILE > [ PATH ]
prog [ PATH ] < COMMAND >
2022-07-22 20:43:49 +00:00
2022-08-31 02:38:37 +00:00
Commands :
2022-09-07 20:29:15 +00:00
test
help Print this message or the help of the given subcommand ( s )
2022-08-26 15:59:27 +00:00
2022-08-26 14:40:23 +00:00
Arguments :
2022-09-07 20:29:15 +00:00
[ PATH ] help
2022-07-22 20:43:49 +00:00
2022-08-26 14:40:23 +00:00
Options :
2022-09-07 20:29:15 +00:00
- o , - - opt < FILE > tests options
2023-01-03 16:49:43 +00:00
- h , - - help Print help
- V , - - version Print version
2022-07-22 20:43:49 +00:00
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " prog --help " , expected , false ) ;
2017-03-09 13:52:37 +00:00
}
2022-07-22 20:43:49 +00:00
#[ test ]
fn hide_args ( ) {
2024-07-31 20:58:24 +00:00
let cmd = Command ::new ( " prog " )
. version ( " 1.0 " )
. arg ( arg! ( - f - - flag " testing flags " ) )
. arg ( arg! ( - o - - opt < FILE > " tests options " ) )
. arg ( Arg ::new ( " pos " ) . hide ( true ) ) ;
let expected = str ! [ [ r #"
2022-09-07 16:03:55 +00:00
Usage : prog [ OPTIONS ]
2022-07-22 20:43:49 +00:00
2022-08-26 14:40:23 +00:00
Options :
2022-09-07 20:29:15 +00:00
- f , - - flag testing flags
- o , - - opt < FILE > tests options
2023-01-03 16:49:43 +00:00
- h , - - help Print help
- V , - - version Print version
2022-07-22 20:43:49 +00:00
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " prog --help " , expected , false ) ;
}
#[ test ]
fn args_negate_sc ( ) {
2022-02-14 21:47:20 +00:00
let cmd = Command ::new ( " prog " )
2017-11-22 09:09:51 +00:00
. version ( " 1.0 " )
2024-07-31 20:58:24 +00:00
. args_conflicts_with_subcommands ( true )
2021-11-19 20:33:11 +00:00
. arg ( arg! ( - f - - flag " testing flags " ) )
2022-09-12 21:59:57 +00:00
. arg ( arg! ( - o - - opt < FILE > " tests options " ) )
2024-07-31 20:58:24 +00:00
. arg ( Arg ::new ( " PATH " ) . help ( " help " ) )
. subcommand ( Command ::new ( " test " ) ) ;
2017-11-22 09:09:51 +00:00
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2022-09-07 16:03:55 +00:00
Usage : prog [ OPTIONS ] [ PATH ]
prog < COMMAND >
2022-07-22 20:43:49 +00:00
2022-08-31 02:38:37 +00:00
Commands :
2022-09-07 20:29:15 +00:00
test
help Print this message or the help of the given subcommand ( s )
2022-08-26 15:59:27 +00:00
2022-08-26 14:40:23 +00:00
Arguments :
2022-09-07 20:29:15 +00:00
[ PATH ] help
2022-07-22 20:43:49 +00:00
2022-08-26 14:40:23 +00:00
Options :
2022-09-07 20:29:15 +00:00
- f , - - flag testing flags
- o , - - opt < FILE > tests options
2023-01-03 16:49:43 +00:00
- h , - - help Print help
- V , - - version Print version
2022-07-22 20:43:49 +00:00
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " prog --help " , expected , false ) ;
}
#[ test ]
fn issue_1046_hide_scs ( ) {
2022-02-14 21:47:20 +00:00
let cmd = Command ::new ( " prog " )
2017-03-09 13:52:37 +00:00
. version ( " 1.0 " )
2021-11-19 20:33:11 +00:00
. arg ( arg! ( - f - - flag " testing flags " ) )
2022-09-12 21:59:57 +00:00
. arg ( arg! ( - o - - opt < FILE > " tests options " ) )
2024-07-31 20:58:24 +00:00
. arg ( Arg ::new ( " PATH " ) . help ( " some " ) )
. subcommand ( Command ::new ( " test " ) . hide ( true ) ) ;
2017-03-09 13:52:37 +00:00
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2022-09-07 16:03:55 +00:00
Usage : prog [ OPTIONS ] [ PATH ]
2022-07-22 20:43:49 +00:00
2022-08-26 14:40:23 +00:00
Arguments :
2022-09-07 20:29:15 +00:00
[ PATH ] some
2022-07-22 20:43:49 +00:00
2022-08-26 14:40:23 +00:00
Options :
2022-09-07 20:29:15 +00:00
- f , - - flag testing flags
- o , - - opt < FILE > tests options
2023-01-03 16:49:43 +00:00
- h , - - help Print help
- V , - - version Print version
2022-07-22 20:43:49 +00:00
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " prog --help " , expected , false ) ;
2017-09-14 17:37:13 +00:00
}
2017-01-02 21:44:40 +00:00
#[ test ]
2022-09-26 16:35:18 +00:00
#[ cfg(feature = " wrap_help " ) ]
2017-01-02 21:44:40 +00:00
fn issue_777_wrap_all_things ( ) {
2024-07-31 20:58:24 +00:00
let cmd = Command ::new ( " A cmd with a crazy very long long long name hahaha " )
. version ( " 1.0 " )
. author ( " Some Very Long Name and crazy long email <email@server.com> " )
. about ( " Show how the about text is not wrapped " )
. help_template ( utils ::FULL_TEMPLATE )
. term_width ( 35 ) ;
let expected = str ! [ [ r #"
A cmd with a crazy very long long
2022-07-22 20:43:49 +00:00
long name hahaha 1.0
Some Very Long Name and crazy long
email < email @ server . com >
Show how the about text is not
wrapped
2022-09-07 16:03:55 +00:00
Usage : ctest
2022-07-22 20:43:49 +00:00
2022-08-26 14:40:23 +00:00
Options :
2023-01-03 16:49:43 +00:00
- h , - - help Print help
- V , - - version Print version
2022-07-22 20:43:49 +00:00
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " ctest --help " , expected , false ) ;
2017-01-08 11:51:20 +00:00
}
2017-03-10 06:01:32 +00:00
2023-08-22 21:00:10 +00:00
#[ test ]
fn dont_strip_padding_issue_5083 ( ) {
let cmd = Command ::new ( " test " )
. help_template ( " {subcommands} " )
. subcommands ( [
Command ::new ( " one " ) ,
Command ::new ( " two " ) ,
Command ::new ( " three " ) ,
] ) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
one
2023-08-22 21:00:10 +00:00
two
three
help Print this message or the help of the given subcommand ( s )
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " test --help " , expected , false ) ;
}
2020-10-26 08:37:45 +00:00
#[ test ]
fn override_help_short ( ) {
2022-02-14 21:47:20 +00:00
let cmd = Command ::new ( " test " )
2020-10-26 08:37:45 +00:00
. version ( " 0.1 " )
2023-01-03 16:49:43 +00:00
. arg ( arg! ( - H - - help " Print help " ) . action ( ArgAction ::Help ) )
2022-08-08 21:08:47 +00:00
. disable_help_flag ( true ) ;
2020-10-26 08:37:45 +00:00
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
Usage : test
Options :
- H , - - help Print help
- V , - - version Print version
" #]];
utils ::assert_output ( cmd . clone ( ) , " test --help " , expected , false ) ;
2020-10-26 08:37:45 +00:00
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2023-07-17 15:40:42 +00:00
Usage : test
2020-10-26 08:37:45 +00:00
2022-08-26 14:40:23 +00:00
Options :
2024-07-31 20:58:24 +00:00
- H , - - help Print help
2023-01-03 16:49:43 +00:00
- V , - - version Print version
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " test -H " , expected , false ) ;
}
2020-10-26 08:37:45 +00:00
#[ test ]
fn override_help_long ( ) {
2022-02-14 21:47:20 +00:00
let cmd = Command ::new ( " test " )
2020-10-26 08:37:45 +00:00
. version ( " 0.1 " )
2023-01-03 16:49:43 +00:00
. arg ( arg! ( - h - - hell " Print help " ) . action ( ArgAction ::Help ) )
2022-08-08 21:08:47 +00:00
. disable_help_flag ( true ) ;
2020-10-26 08:37:45 +00:00
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
Usage : test
Options :
- h , - - hell Print help
- V , - - version Print version
" #]];
utils ::assert_output ( cmd . clone ( ) , " test --hell " , expected , false ) ;
2020-10-26 08:37:45 +00:00
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2022-09-07 16:03:55 +00:00
Usage : test
2020-10-26 08:37:45 +00:00
2022-08-26 14:40:23 +00:00
Options :
2024-07-31 20:58:24 +00:00
- h , - - hell Print help
2023-01-03 16:49:43 +00:00
- V , - - version Print version
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " test -h " , expected , false ) ;
}
2020-10-26 08:37:45 +00:00
2017-03-10 06:01:32 +00:00
#[ test ]
2020-10-26 08:37:45 +00:00
fn override_help_about ( ) {
2022-02-14 21:47:20 +00:00
let cmd = Command ::new ( " test " )
2017-03-10 06:01:32 +00:00
. version ( " 0.1 " )
2022-08-10 20:13:44 +00:00
. arg ( arg! ( - h - - help " Print custom help information " ) . action ( ArgAction ::Help ) )
2022-08-08 21:08:47 +00:00
. disable_help_flag ( true ) ;
2020-10-26 08:37:45 +00:00
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
Usage : test
Options :
- h , - - help Print custom help information
- V , - - version Print version
" #]];
utils ::assert_output ( cmd . clone ( ) , " test --help " , expected , false ) ;
let expected = str ! [ [ r #"
Usage : test
Options :
- h , - - help Print custom help information
- V , - - version Print version
" #]];
utils ::assert_output ( cmd , " test -h " , expected , false ) ;
2017-03-10 06:01:32 +00:00
}
2017-03-11 05:17:57 +00:00
2020-04-08 20:26:05 +00:00
#[ test ]
2022-08-08 21:08:47 +00:00
#[ cfg(debug_assertions) ]
#[ should_panic = " Command conflict: Argument names must be unique, but 'help' is in use by more than one argument or group (call `cmd.disable_help_flag(true)` to remove the auto-generated `--help`) " ]
fn arg_id_conflict_with_help ( ) {
Command ::new ( " conflict " )
. arg ( Arg ::new ( " help " ) . short ( '?' ) . action ( ArgAction ::SetTrue ) )
. build ( ) ;
2020-04-08 20:26:05 +00:00
}
2022-08-08 21:08:47 +00:00
#[ test ]
2020-04-09 16:19:05 +00:00
#[ cfg(debug_assertions) ]
2022-08-08 21:08:47 +00:00
#[ should_panic = " Command conflict: Short option names must be unique for each argument, but '-h' is in use by both 'home' and 'help' (call `cmd.disable_help_flag(true)` to remove the auto-generated `--help`) " ]
fn arg_short_conflict_with_help ( ) {
Command ::new ( " conflict " )
. arg ( Arg ::new ( " home " ) . short ( 'h' ) . action ( ArgAction ::SetTrue ) )
. build ( ) ;
}
2020-04-08 20:26:05 +00:00
#[ test ]
2022-08-08 21:08:47 +00:00
#[ cfg(debug_assertions) ]
#[ should_panic = " Command conflict: Long option names must be unique for each argument, but '--help' is in use by both 'custom-help' and 'help' (call `cmd.disable_help_flag(true)` to remove the auto-generated `--help`) " ]
fn arg_long_conflict_with_help ( ) {
Command ::new ( " conflict " )
. arg (
Arg ::new ( " custom-help " )
. long ( " help " )
. action ( ArgAction ::SetTrue ) ,
)
. build ( ) ;
2020-04-08 20:26:05 +00:00
}
2017-03-11 05:17:57 +00:00
#[ test ]
fn last_arg_mult_usage ( ) {
2024-07-31 20:58:24 +00:00
let cmd = Command ::new ( " last " )
. version ( " 0.1 " )
. arg ( Arg ::new ( " TARGET " ) . required ( true ) . help ( " some " ) )
. arg ( Arg ::new ( " CORPUS " ) . help ( " some " ) )
. arg (
Arg ::new ( " ARGS " )
. action ( ArgAction ::Set )
. num_args ( 1 .. )
. last ( true )
. help ( " some " ) ,
) ;
let expected = str ! [ [ r #"
2022-09-07 16:03:55 +00:00
Usage : last < TARGET > [ CORPUS ] [ - - < ARGS > .. . ]
2022-07-22 20:43:49 +00:00
2022-08-26 14:40:23 +00:00
Arguments :
2022-09-07 20:29:15 +00:00
< TARGET > some
[ CORPUS ] some
[ ARGS ] .. . some
2022-07-22 20:43:49 +00:00
2022-08-26 14:40:23 +00:00
Options :
2023-01-03 16:49:43 +00:00
- h , - - help Print help
- V , - - version Print version
2022-07-22 20:43:49 +00:00
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " last --help " , expected , false ) ;
}
#[ test ]
fn last_arg_mult_usage_req ( ) {
2022-02-14 21:47:20 +00:00
let cmd = Command ::new ( " last " )
2018-01-25 04:05:05 +00:00
. version ( " 0.1 " )
2021-11-18 16:17:15 +00:00
. arg ( Arg ::new ( " TARGET " ) . required ( true ) . help ( " some " ) )
. arg ( Arg ::new ( " CORPUS " ) . help ( " some " ) )
2021-02-24 15:07:57 +00:00
. arg (
Arg ::new ( " ARGS " )
2022-07-26 00:17:01 +00:00
. action ( ArgAction ::Set )
2022-08-03 16:20:07 +00:00
. num_args ( 1 .. )
2021-02-24 15:07:57 +00:00
. last ( true )
2024-07-31 20:58:24 +00:00
. required ( true )
2021-11-18 16:17:15 +00:00
. help ( " some " ) ,
2021-02-24 15:07:57 +00:00
) ;
2017-03-11 05:17:57 +00:00
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2022-09-07 16:03:55 +00:00
Usage : last < TARGET > [ CORPUS ] - - < ARGS > .. .
2022-07-22 20:43:49 +00:00
2022-08-26 14:40:23 +00:00
Arguments :
2022-09-07 20:29:15 +00:00
< TARGET > some
[ CORPUS ] some
< ARGS > .. . some
2022-07-22 20:43:49 +00:00
2022-08-26 14:40:23 +00:00
Options :
2023-01-03 16:49:43 +00:00
- h , - - help Print help
- V , - - version Print version
2022-07-22 20:43:49 +00:00
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " last --help " , expected , false ) ;
}
#[ test ]
fn last_arg_mult_usage_req_with_sc ( ) {
let cmd = Command ::new ( " last " )
. version ( " 0.1 " )
. subcommand_negates_reqs ( true )
2021-11-18 16:17:15 +00:00
. arg ( Arg ::new ( " TARGET " ) . required ( true ) . help ( " some " ) )
. arg ( Arg ::new ( " CORPUS " ) . help ( " some " ) )
2018-01-25 04:05:05 +00:00
. arg (
2020-05-14 20:50:56 +00:00
Arg ::new ( " ARGS " )
2022-07-26 00:17:01 +00:00
. action ( ArgAction ::Set )
2022-08-03 16:20:07 +00:00
. num_args ( 1 .. )
2018-01-25 04:05:05 +00:00
. last ( true )
. required ( true )
2021-11-18 16:17:15 +00:00
. help ( " some " ) ,
2024-07-31 20:58:24 +00:00
)
. subcommand ( Command ::new ( " test " ) . about ( " some " ) ) ;
2017-03-11 05:17:57 +00:00
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2022-09-07 16:03:55 +00:00
Usage : last < TARGET > [ CORPUS ] - - < ARGS > .. .
last [ TARGET ] [ CORPUS ] < COMMAND >
2022-07-22 20:43:49 +00:00
2022-08-31 02:38:37 +00:00
Commands :
2022-09-07 20:29:15 +00:00
test some
help Print this message or the help of the given subcommand ( s )
2022-08-26 15:59:27 +00:00
2022-08-26 14:40:23 +00:00
Arguments :
2022-09-07 20:29:15 +00:00
< TARGET > some
[ CORPUS ] some
< ARGS > .. . some
2022-07-22 20:43:49 +00:00
2022-08-26 14:40:23 +00:00
Options :
2023-01-03 16:49:43 +00:00
- h , - - help Print help
- V , - - version Print version
2022-07-22 20:43:49 +00:00
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " last --help " , expected , false ) ;
}
#[ test ]
fn last_arg_mult_usage_with_sc ( ) {
2022-02-14 21:47:20 +00:00
let cmd = Command ::new ( " last " )
2018-01-25 04:05:05 +00:00
. version ( " 0.1 " )
2024-07-31 20:58:24 +00:00
. args_conflicts_with_subcommands ( true )
2021-11-18 16:17:15 +00:00
. arg ( Arg ::new ( " TARGET " ) . required ( true ) . help ( " some " ) )
. arg ( Arg ::new ( " CORPUS " ) . help ( " some " ) )
2018-01-25 04:05:05 +00:00
. arg (
2020-05-14 20:50:56 +00:00
Arg ::new ( " ARGS " )
2022-07-26 00:17:01 +00:00
. action ( ArgAction ::Set )
2022-08-03 16:20:07 +00:00
. num_args ( 1 .. )
2018-01-25 04:05:05 +00:00
. last ( true )
2021-11-18 16:17:15 +00:00
. help ( " some " ) ,
2018-01-25 04:05:05 +00:00
)
2022-02-12 03:48:29 +00:00
. subcommand ( Command ::new ( " test " ) . about ( " some " ) ) ;
2017-03-11 05:17:57 +00:00
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2022-09-07 16:03:55 +00:00
Usage : last < TARGET > [ CORPUS ] [ - - < ARGS > .. . ]
last < COMMAND >
2022-07-22 20:43:49 +00:00
2022-08-31 02:38:37 +00:00
Commands :
2022-09-07 20:29:15 +00:00
test some
help Print this message or the help of the given subcommand ( s )
2022-08-26 15:59:27 +00:00
2022-08-26 14:40:23 +00:00
Arguments :
2022-09-07 20:29:15 +00:00
< TARGET > some
[ CORPUS ] some
[ ARGS ] .. . some
2022-07-22 20:43:49 +00:00
2022-08-26 14:40:23 +00:00
Options :
2023-01-03 16:49:43 +00:00
- h , - - help Print help
- V , - - version Print version
2022-07-22 20:43:49 +00:00
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " last --help " , expected , false ) ;
2017-03-22 10:14:02 +00:00
}
#[ test ]
2021-11-29 16:45:30 +00:00
fn hide_default_val ( ) {
2022-02-12 03:48:29 +00:00
let app1 = Command ::new ( " default " ) . version ( " 0.1 " ) . term_width ( 120 ) . arg (
2020-05-14 20:50:56 +00:00
Arg ::new ( " argument " )
2021-11-18 16:17:15 +00:00
. help ( " Pass an argument to the program. [default: default-argument] " )
2018-01-25 04:05:05 +00:00
. long ( " arg " )
. default_value ( " default-argument " )
. hide_default_value ( true ) ,
) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
Usage : default [ OPTIONS ]
Options :
- - arg < argument > Pass an argument to the program . [ default : default - argument ]
- h , - - help Print help
- V , - - version Print version
" #]];
utils ::assert_output ( app1 , " default --help " , expected , false ) ;
2018-01-25 04:05:05 +00:00
2022-02-12 03:48:29 +00:00
let app2 = Command ::new ( " default " ) . version ( " 0.1 " ) . term_width ( 120 ) . arg (
2020-05-14 20:50:56 +00:00
Arg ::new ( " argument " )
2021-11-18 16:17:15 +00:00
. help ( " Pass an argument to the program. " )
2018-01-25 04:05:05 +00:00
. long ( " arg " )
. default_value ( " default-argument " ) ,
) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
Usage : default [ OPTIONS ]
Options :
- - arg < argument > Pass an argument to the program . [ default : default - argument ]
- h , - - help Print help
- V , - - version Print version
" #]];
utils ::assert_output ( app2 , " default --help " , expected , false ) ;
2017-03-22 10:14:02 +00:00
}
2017-04-04 23:54:20 +00:00
2020-09-23 08:45:14 +00:00
#[ test ]
2022-09-26 16:35:18 +00:00
#[ cfg(feature = " wrap_help " ) ]
2020-09-23 08:45:14 +00:00
fn escaped_whitespace_values ( ) {
2024-07-31 20:58:24 +00:00
let app1 = Command ::new ( " default " ) . version ( " 0.1 " ) . term_width ( 120 ) . arg (
Arg ::new ( " argument " )
. help ( " Pass an argument to the program. " )
. long ( " arg " )
. default_value ( " \n " )
. value_parser ( [ " normal " , " " , " \n " , " \t " , " other " ] ) ,
) ;
2023-07-17 14:40:49 +00:00
#[ cfg(not(feature = " unstable-v5 " )) ]
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2022-09-07 16:03:55 +00:00
Usage : default [ OPTIONS ]
2022-07-22 20:43:49 +00:00
2022-08-26 14:40:23 +00:00
Options :
2024-07-31 20:58:24 +00:00
- - arg < argument > Pass an argument to the program . [ default : " \n " ] [ possible values : normal , " " , " \n " , " \t " ,
2022-09-07 20:29:15 +00:00
other ]
2023-01-03 16:49:43 +00:00
- h , - - help Print help
- V , - - version Print version
2024-07-31 20:58:24 +00:00
" #]];
2022-07-22 20:43:49 +00:00
2023-07-17 14:40:49 +00:00
#[ cfg(feature = " unstable-v5 " ) ]
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2023-07-17 14:40:49 +00:00
Usage : default [ OPTIONS ]
Options :
2024-07-31 20:58:24 +00:00
- - arg < argument > Pass an argument to the program . [ default : " \n " ] [ possible values : normal , "
" , " \ n " , " \ t " , other]
2023-07-17 14:40:49 +00:00
- h , - - help Print help
- V , - - version Print version
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( app1 , " default --help " , expected , false ) ;
2020-09-23 08:45:14 +00:00
}
2022-08-15 19:29:46 +00:00
fn issue_1112_setup ( ) -> Command {
2022-02-12 03:48:29 +00:00
Command ::new ( " test " )
2017-04-04 23:54:20 +00:00
. version ( " 1.3 " )
2022-08-08 21:08:47 +00:00
. disable_help_flag ( true )
2022-06-10 01:03:28 +00:00
. arg (
Arg ::new ( " help1 " )
. long ( " help " )
. short ( 'h' )
. help ( " some help " )
. action ( ArgAction ::SetTrue ) ,
)
2021-02-07 11:58:43 +00:00
. subcommand (
2022-06-10 01:03:28 +00:00
Command ::new ( " foo " ) . arg (
Arg ::new ( " help1 " )
. long ( " help " )
. short ( 'h' )
. help ( " some help " )
. action ( ArgAction ::SetTrue ) ,
) ,
2021-02-07 11:58:43 +00:00
)
2017-11-22 09:09:51 +00:00
}
#[ test ]
2021-02-07 11:58:43 +00:00
fn prefer_user_help_long_1112 ( ) {
2018-10-19 20:42:13 +00:00
let m = issue_1112_setup ( ) . try_get_matches_from ( vec! [ " test " , " --help " ] ) ;
2017-04-04 23:54:20 +00:00
2021-12-27 19:57:38 +00:00
assert! ( m . is_ok ( ) , " {} " , m . unwrap_err ( ) ) ;
2022-06-10 01:03:28 +00:00
let m = m . unwrap ( ) ;
assert! ( * m . get_one ::< bool > ( " help1 " ) . expect ( " defaulted by clap " ) ) ;
2017-05-11 15:17:28 +00:00
}
2017-10-12 22:11:51 +00:00
2017-11-22 09:09:51 +00:00
#[ test ]
2021-02-07 11:58:43 +00:00
fn prefer_user_help_short_1112 ( ) {
2018-10-19 20:42:13 +00:00
let m = issue_1112_setup ( ) . try_get_matches_from ( vec! [ " test " , " -h " ] ) ;
2017-11-22 09:09:51 +00:00
2021-12-27 19:57:38 +00:00
assert! ( m . is_ok ( ) , " {} " , m . unwrap_err ( ) ) ;
2022-06-10 01:03:28 +00:00
let m = m . unwrap ( ) ;
assert! ( * m . get_one ::< bool > ( " help1 " ) . expect ( " defaulted by clap " ) ) ;
2017-11-22 09:09:51 +00:00
}
#[ test ]
2021-02-07 11:58:43 +00:00
fn prefer_user_subcmd_help_long_1112 ( ) {
2018-10-19 20:42:13 +00:00
let m = issue_1112_setup ( ) . try_get_matches_from ( vec! [ " test " , " foo " , " --help " ] ) ;
2017-11-22 09:09:51 +00:00
2021-12-27 19:57:38 +00:00
assert! ( m . is_ok ( ) , " {} " , m . unwrap_err ( ) ) ;
2022-06-10 01:03:28 +00:00
let m = m . unwrap ( ) ;
assert! ( * m
2018-11-14 17:05:06 +00:00
. subcommand_matches ( " foo " )
. unwrap ( )
2022-06-10 01:03:28 +00:00
. get_one ::< bool > ( " help1 " )
. expect ( " defaulted by clap " ) ) ;
2017-11-22 09:09:51 +00:00
}
#[ test ]
2021-02-07 11:58:43 +00:00
fn prefer_user_subcmd_help_short_1112 ( ) {
2018-10-19 20:42:13 +00:00
let m = issue_1112_setup ( ) . try_get_matches_from ( vec! [ " test " , " foo " , " -h " ] ) ;
2017-11-22 09:09:51 +00:00
2021-12-27 19:57:38 +00:00
assert! ( m . is_ok ( ) , " {} " , m . unwrap_err ( ) ) ;
2022-06-10 01:03:28 +00:00
let m = m . unwrap ( ) ;
2018-11-14 17:05:06 +00:00
assert! ( m
. subcommand_matches ( " foo " )
. unwrap ( )
2022-06-10 01:03:28 +00:00
. get_one ::< bool > ( " help1 " )
. expect ( " defaulted by clap " ) ) ;
2017-11-22 09:09:51 +00:00
}
2017-10-12 22:11:51 +00:00
#[ test ]
fn issue_1052_require_delim_help ( ) {
2022-02-14 21:47:20 +00:00
let cmd = Command ::new ( " test " )
2017-10-12 22:11:51 +00:00
. author ( " Kevin K. " )
. about ( " tests stuff " )
. version ( " 1.3 " )
2018-01-25 04:05:05 +00:00
. arg (
2022-07-21 21:36:54 +00:00
arg! ( - f - - fake < s > " some help " )
2021-11-19 20:33:11 +00:00
. required ( true )
2022-08-15 18:21:05 +00:00
. value_names ( [ " some " , " val " ] )
2022-07-26 00:17:01 +00:00
. action ( ArgAction ::Set )
2021-08-13 18:54:56 +00:00
. value_delimiter ( ':' ) ,
2018-01-25 04:05:05 +00:00
) ;
2017-10-12 22:11:51 +00:00
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
tests stuff
2022-07-22 20:43:49 +00:00
2024-07-31 20:58:24 +00:00
Usage : test - - fake < some > < val >
2022-07-22 20:43:49 +00:00
2022-08-26 14:40:23 +00:00
Options :
2022-09-07 20:29:15 +00:00
- f , - - fake < some > < val > some help
2023-01-03 16:49:43 +00:00
- h , - - help Print help
- V , - - version Print version
2022-07-22 20:43:49 +00:00
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " test --help " , expected , false ) ;
}
2022-07-22 20:43:49 +00:00
2024-07-31 20:58:24 +00:00
#[ test ]
fn custom_headers_headers ( ) {
2022-02-14 21:47:20 +00:00
let cmd = Command ::new ( " blorp " )
2018-04-04 03:27:57 +00:00
. author ( " Will M. " )
. about ( " does stuff " )
. version ( " 1.4 " )
2018-07-23 19:09:42 +00:00
. arg (
2022-07-21 21:36:54 +00:00
arg! ( - f - - fake < s > " some help " )
2021-11-19 20:33:11 +00:00
. required ( true )
2022-08-15 18:21:05 +00:00
. value_names ( [ " some " , " val " ] )
2022-07-26 00:17:01 +00:00
. action ( ArgAction ::Set )
2021-08-13 18:54:56 +00:00
. value_delimiter ( ':' ) ,
2018-11-14 17:05:06 +00:00
)
2022-02-07 21:15:40 +00:00
. next_help_heading ( Some ( " NETWORKING " ) )
2018-07-23 19:09:42 +00:00
. arg (
2020-05-14 20:50:56 +00:00
Arg ::new ( " no-proxy " )
2018-07-23 19:09:42 +00:00
. short ( 'n' )
2018-04-04 03:27:57 +00:00
. long ( " no-proxy " )
2022-07-26 00:17:01 +00:00
. action ( ArgAction ::SetTrue )
2021-11-18 16:17:15 +00:00
. help ( " Do not use system proxy settings " ) ,
2021-10-14 18:14:43 +00:00
)
2022-08-15 18:21:05 +00:00
. args ( [ Arg ::new ( " port " ) . long ( " port " ) . action ( ArgAction ::SetTrue ) ] ) ;
2018-04-04 03:27:57 +00:00
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2018-04-04 03:27:57 +00:00
does stuff
2024-07-31 20:58:24 +00:00
Usage : test [ OPTIONS ] - - fake < some > < val >
2018-04-04 03:27:57 +00:00
2022-08-26 14:40:23 +00:00
Options :
2022-09-07 20:29:15 +00:00
- f , - - fake < some > < val > some help
2023-01-03 16:49:43 +00:00
- h , - - help Print help
- V , - - version Print version
2018-04-04 03:27:57 +00:00
NETWORKING :
2024-07-31 20:58:24 +00:00
- n , - - no - proxy Do not use system proxy settings
- - port
2021-10-14 17:16:20 +00:00
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " test --help " , expected , false ) ;
}
2018-04-04 03:27:57 +00:00
#[ test ]
fn multiple_custom_help_headers ( ) {
2022-02-14 21:47:20 +00:00
let cmd = Command ::new ( " blorp " )
2018-04-04 03:27:57 +00:00
. author ( " Will M. " )
. about ( " does stuff " )
. version ( " 1.4 " )
2018-07-23 19:09:42 +00:00
. arg (
2022-07-21 21:36:54 +00:00
arg! ( - f - - fake < s > " some help " )
2021-11-19 20:33:11 +00:00
. required ( true )
2022-08-15 18:21:05 +00:00
. value_names ( [ " some " , " val " ] )
2022-07-26 00:17:01 +00:00
. action ( ArgAction ::Set )
2021-08-13 18:54:56 +00:00
. value_delimiter ( ':' ) ,
2018-11-14 17:05:06 +00:00
)
2022-02-07 21:15:40 +00:00
. next_help_heading ( Some ( " NETWORKING " ) )
2018-07-23 19:09:42 +00:00
. arg (
2020-05-14 20:50:56 +00:00
Arg ::new ( " no-proxy " )
2018-07-23 19:09:42 +00:00
. short ( 'n' )
2018-04-04 03:27:57 +00:00
. long ( " no-proxy " )
2022-07-26 00:17:01 +00:00
. action ( ArgAction ::SetTrue )
2021-11-18 16:17:15 +00:00
. help ( " Do not use system proxy settings " ) ,
2018-11-14 17:05:06 +00:00
)
2022-02-07 21:15:40 +00:00
. next_help_heading ( Some ( " SPECIAL " ) )
2020-06-01 06:04:41 +00:00
. arg (
2021-11-19 20:33:11 +00:00
arg! ( - b - - " birthday-song " < song > " Change which song is played for birthdays " )
2022-09-12 21:59:57 +00:00
. required ( true )
2021-11-19 20:33:11 +00:00
. help_heading ( Some ( " OVERRIDE SPECIAL " ) ) ,
2020-06-01 06:04:41 +00:00
)
2022-09-12 21:59:57 +00:00
. arg ( arg! ( - - style < style > " Choose musical style to play the song " ) . help_heading ( None ) )
2020-06-01 06:04:41 +00:00
. arg (
2022-09-12 21:59:57 +00:00
arg! (
- v - - " birthday-song-volume " < volume > " Change the volume of the birthday song "
)
. required ( true ) ,
2020-06-01 06:04:41 +00:00
)
2022-02-07 21:15:40 +00:00
. next_help_heading ( None )
2020-06-01 06:04:41 +00:00
. arg (
Arg ::new ( " server-addr " )
. short ( 'a' )
. long ( " server-addr " )
2022-07-26 00:17:01 +00:00
. action ( ArgAction ::SetTrue )
2021-11-18 16:17:15 +00:00
. help ( " Set server address " )
2020-06-01 06:04:41 +00:00
. help_heading ( Some ( " NETWORKING " ) ) ,
)
2018-07-23 19:09:42 +00:00
. arg (
2020-05-14 20:50:56 +00:00
Arg ::new ( " speed " )
2018-04-04 03:27:57 +00:00
. long ( " speed " )
2018-07-23 19:09:42 +00:00
. short ( 's' )
2018-04-04 03:27:57 +00:00
. value_name ( " SPEED " )
2022-05-24 01:16:02 +00:00
. value_parser ( [ " fast " , " slow " ] )
2021-11-18 16:17:15 +00:00
. help ( " How fast? " )
2022-07-26 00:17:01 +00:00
. action ( ArgAction ::Set ) ,
2018-07-23 19:09:42 +00:00
) ;
2018-04-04 03:27:57 +00:00
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2021-06-12 03:20:56 +00:00
does stuff
2024-07-31 20:58:24 +00:00
Usage : test [ OPTIONS ] - - fake < some > < val > - - birthday - song < song > - - birthday - song - volume < volume >
2021-06-12 03:20:56 +00:00
2022-08-26 14:40:23 +00:00
Options :
2024-07-31 20:58:24 +00:00
- f , - - fake < some > < val > some help
- - style < style > Choose musical style to play the song
- s , - - speed < SPEED > How fast ? [ possible values : fast , slow ]
- h , - - help Print help
- V , - - version Print version
NETWORKING :
- n , - - no - proxy Do not use system proxy settings
- a , - - server - addr Set server address
2021-06-12 03:20:56 +00:00
2021-10-14 17:16:20 +00:00
OVERRIDE SPECIAL :
2024-07-31 20:58:24 +00:00
- b , - - birthday - song < song > Change which song is played for birthdays
2021-10-14 17:16:20 +00:00
2021-06-12 03:20:56 +00:00
SPECIAL :
2024-07-31 20:58:24 +00:00
- v , - - birthday - song - volume < volume > Change the volume of the birthday song
" #]];
utils ::assert_output ( cmd , " test --help " , expected , false ) ;
}
2021-06-12 03:20:56 +00:00
#[ test ]
2021-11-29 16:45:30 +00:00
fn custom_help_headers_hide_args ( ) {
2022-02-14 21:47:20 +00:00
let cmd = Command ::new ( " blorp " )
2021-06-12 03:20:56 +00:00
. author ( " Will M. " )
. about ( " does stuff " )
. version ( " 1.4 " )
2022-02-07 21:15:40 +00:00
. next_help_heading ( Some ( " NETWORKING " ) )
2021-06-12 03:20:56 +00:00
. arg (
Arg ::new ( " no-proxy " )
. short ( 'n' )
. long ( " no-proxy " )
2021-11-18 16:17:15 +00:00
. help ( " Do not use system proxy settings " )
2021-11-29 16:45:30 +00:00
. hide_short_help ( true ) ,
2021-06-12 03:20:56 +00:00
)
2022-02-07 21:15:40 +00:00
. next_help_heading ( Some ( " SPECIAL " ) )
2021-06-12 03:20:56 +00:00
. arg (
2021-11-19 20:33:11 +00:00
arg! ( - b - - song < song > " Change which song is played for birthdays " )
2022-09-12 21:59:57 +00:00
. required ( true )
2021-10-14 17:16:20 +00:00
. help_heading ( Some ( " OVERRIDE SPECIAL " ) ) ,
2021-06-12 03:20:56 +00:00
)
2022-09-12 21:59:57 +00:00
. arg (
arg! (
- v - - " song-volume " < volume > " Change the volume of the birthday song "
)
. required ( true ) ,
)
2022-02-07 21:15:40 +00:00
. next_help_heading ( None )
2021-06-12 03:20:56 +00:00
. arg (
Arg ::new ( " server-addr " )
. short ( 'a' )
. long ( " server-addr " )
2021-11-18 16:17:15 +00:00
. help ( " Set server address " )
2021-06-12 03:20:56 +00:00
. help_heading ( Some ( " NETWORKING " ) )
2021-11-29 16:45:30 +00:00
. hide_short_help ( true ) ,
2021-06-12 03:20:56 +00:00
) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
does stuff
Usage : test [ OPTIONS ] - - song < song > - - song - volume < volume >
Options :
- h , - - help Print help ( see more with ' - - help ' )
- V , - - version Print version
OVERRIDE SPECIAL :
- b , - - song < song > Change which song is played for birthdays
SPECIAL :
- v , - - song - volume < volume > Change the volume of the birthday song
" #]];
utils ::assert_output ( cmd , " test -h " , expected , false ) ;
2021-06-12 03:20:56 +00:00
}
2024-07-31 20:58:24 +00:00
#[ test ]
fn show_long_about_issue_897 ( ) {
let cmd = Command ::new ( " ctest " ) . version ( " 0.1 " ) . subcommand (
Command ::new ( " foo " )
. version ( " 0.1 " )
. about ( " About foo " )
. long_about ( " Long about foo " ) ,
) ;
let expected = str ! [ [ r #"
2018-06-12 14:01:42 +00:00
Long about foo
2022-09-07 16:03:55 +00:00
Usage : ctest foo
2018-06-12 14:01:42 +00:00
2022-08-26 14:40:23 +00:00
Options :
2022-09-07 20:29:15 +00:00
- h , - - help
2023-01-03 16:49:43 +00:00
Print help ( see a summary with ' - h ' )
2018-06-12 14:01:42 +00:00
2022-09-07 20:29:15 +00:00
- V , - - version
2023-01-03 16:49:43 +00:00
Print version
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " ctest foo --help " , expected , false ) ;
}
2018-06-12 14:01:42 +00:00
#[ test ]
2024-07-31 20:58:24 +00:00
fn show_short_about_issue_897 ( ) {
2022-02-14 21:47:20 +00:00
let cmd = Command ::new ( " ctest " ) . version ( " 0.1 " ) . subcommand (
2022-02-12 03:48:29 +00:00
Command ::new ( " foo " )
2018-06-12 14:01:42 +00:00
. version ( " 0.1 " )
. about ( " About foo " )
2018-07-23 19:09:42 +00:00
. long_about ( " Long about foo " ) ,
) ;
2018-06-12 14:01:42 +00:00
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2020-02-13 00:31:45 +00:00
About foo
2018-06-12 14:01:42 +00:00
2022-09-07 16:03:55 +00:00
Usage : ctest foo
2018-06-12 14:01:42 +00:00
2022-08-26 14:40:23 +00:00
Options :
2023-01-03 16:49:43 +00:00
- h , - - help Print help ( see more with ' - - help ' )
- V , - - version Print version
2018-06-12 14:01:42 +00:00
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " ctest foo -h " , expected , false ) ;
2018-06-12 14:01:42 +00:00
}
2019-06-25 23:02:53 +00:00
2020-04-16 15:21:41 +00:00
#[ test ]
fn issue_1364_no_short_options ( ) {
2022-02-14 21:47:20 +00:00
let cmd = Command ::new ( " demo " )
2022-07-26 00:17:01 +00:00
. arg ( Arg ::new ( " foo " ) . short ( 'f' ) . action ( ArgAction ::SetTrue ) )
2020-04-16 15:21:41 +00:00
. arg (
2020-05-14 20:50:56 +00:00
Arg ::new ( " baz " )
2020-04-16 15:21:41 +00:00
. short ( 'z' )
. value_name ( " BAZ " )
2021-11-29 16:45:30 +00:00
. hide_short_help ( true ) ,
2020-04-16 15:21:41 +00:00
)
2021-02-24 15:07:57 +00:00
. arg (
Arg ::new ( " files " )
. value_name ( " FILES " )
2022-07-26 00:17:01 +00:00
. action ( ArgAction ::Set )
2022-08-03 16:20:07 +00:00
. num_args ( 1 .. ) ,
2021-02-24 15:07:57 +00:00
) ;
2020-04-16 15:21:41 +00:00
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
Usage : demo [ OPTIONS ] [ FILES ] .. .
Arguments :
[ FILES ] .. .
Options :
- f
- h , - - help Print help ( see more with ' - - help ' )
" #]];
utils ::assert_output ( cmd , " demo -h " , expected , false ) ;
2020-04-16 15:21:41 +00:00
}
2019-06-25 23:02:53 +00:00
#[ test ]
fn issue_1487 ( ) {
2024-07-31 20:58:24 +00:00
let cmd = Command ::new ( " test " )
. arg ( Arg ::new ( " arg1 " ) . group ( " group1 " ) )
. arg ( Arg ::new ( " arg2 " ) . group ( " group1 " ) )
. group (
ArgGroup ::new ( " group1 " )
. args ( [ " arg1 " , " arg2 " ] )
. required ( true ) ,
) ;
let expected = str ! [ [ r #"
2022-09-07 16:03:55 +00:00
Usage : ctest < arg1 | arg2 >
2022-07-22 20:43:49 +00:00
2022-08-26 14:40:23 +00:00
Arguments :
2022-09-07 20:29:15 +00:00
[ arg1 ]
[ arg2 ]
2022-07-22 20:43:49 +00:00
2022-08-26 14:40:23 +00:00
Options :
2023-01-03 16:49:43 +00:00
- h , - - help Print help
2022-07-22 20:43:49 +00:00
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " ctest -h " , expected , false ) ;
2020-01-11 18:15:46 +00:00
}
2020-02-10 10:04:18 +00:00
2020-04-09 16:19:05 +00:00
#[ cfg(debug_assertions) ]
2020-02-10 10:04:18 +00:00
#[ test ]
2022-06-08 17:06:15 +00:00
#[ should_panic = " Command::help_expected is enabled for the Command " ]
2020-02-10 10:04:18 +00:00
fn help_required_but_not_given ( ) {
2022-02-12 03:48:29 +00:00
Command ::new ( " myapp " )
2022-02-10 17:51:40 +00:00
. help_expected ( true )
2020-05-14 20:50:56 +00:00
. arg ( Arg ::new ( " foo " ) )
2021-12-27 18:56:12 +00:00
. try_get_matches_from ( empty_args ( ) )
. unwrap ( ) ;
2020-02-10 10:04:18 +00:00
}
2020-04-09 16:19:05 +00:00
#[ cfg(debug_assertions) ]
2020-02-10 10:04:18 +00:00
#[ test ]
2022-06-08 17:06:15 +00:00
#[ should_panic = " Command::help_expected is enabled for the Command " ]
2020-02-10 10:04:18 +00:00
fn help_required_but_not_given_settings_after_args ( ) {
2022-02-12 03:48:29 +00:00
Command ::new ( " myapp " )
2020-05-14 20:50:56 +00:00
. arg ( Arg ::new ( " foo " ) )
2022-02-10 17:51:40 +00:00
. help_expected ( true )
2021-12-27 18:56:12 +00:00
. try_get_matches_from ( empty_args ( ) )
. unwrap ( ) ;
2020-02-10 10:04:18 +00:00
}
2020-04-09 16:19:05 +00:00
#[ cfg(debug_assertions) ]
2020-02-10 10:04:18 +00:00
#[ test ]
2022-06-08 17:06:15 +00:00
#[ should_panic = " Command::help_expected is enabled for the Command " ]
2020-02-10 10:04:18 +00:00
fn help_required_but_not_given_for_one_of_two_arguments ( ) {
2022-02-12 03:48:29 +00:00
Command ::new ( " myapp " )
2022-02-10 17:51:40 +00:00
. help_expected ( true )
2020-05-14 20:50:56 +00:00
. arg ( Arg ::new ( " foo " ) )
2021-11-18 16:17:15 +00:00
. arg ( Arg ::new ( " bar " ) . help ( " It does bar stuff " ) )
2021-12-27 18:56:12 +00:00
. try_get_matches_from ( empty_args ( ) )
. unwrap ( ) ;
2020-02-10 10:04:18 +00:00
}
#[ test ]
2022-02-10 17:51:40 +00:00
#[ should_panic = " List of such arguments: delete " ]
fn help_required_globally ( ) {
2022-02-12 03:48:29 +00:00
Command ::new ( " myapp " )
2022-02-10 17:51:40 +00:00
. help_expected ( true )
2021-11-18 16:17:15 +00:00
. arg ( Arg ::new ( " foo " ) . help ( " It does foo stuff " ) )
2020-02-10 13:33:26 +00:00
. subcommand (
2022-02-12 03:48:29 +00:00
Command ::new ( " bar " )
2021-11-18 16:17:15 +00:00
. arg ( Arg ::new ( " create " ) . help ( " creates bar " ) )
2020-05-14 20:50:56 +00:00
. arg ( Arg ::new ( " delete " ) ) ,
2020-02-10 13:33:26 +00:00
)
2021-12-27 18:56:12 +00:00
. try_get_matches_from ( empty_args ( ) )
. unwrap ( ) ;
2020-02-10 13:33:26 +00:00
}
2020-04-09 16:19:05 +00:00
#[ cfg(debug_assertions) ]
2020-02-10 13:33:26 +00:00
#[ test ]
2022-06-08 17:06:15 +00:00
#[ should_panic = " Command::help_expected is enabled for the Command " ]
2020-02-10 13:33:26 +00:00
fn help_required_globally_but_not_given_for_subcommand ( ) {
2022-02-12 03:48:29 +00:00
Command ::new ( " myapp " )
2022-02-10 17:51:40 +00:00
. help_expected ( true )
2021-11-18 16:17:15 +00:00
. arg ( Arg ::new ( " foo " ) . help ( " It does foo stuff " ) )
2020-02-10 10:04:18 +00:00
. subcommand (
2022-02-12 03:48:29 +00:00
Command ::new ( " bar " )
2021-11-18 16:17:15 +00:00
. arg ( Arg ::new ( " create " ) . help ( " creates bar " ) )
2020-05-14 20:50:56 +00:00
. arg ( Arg ::new ( " delete " ) ) ,
2020-02-10 10:04:18 +00:00
)
2021-12-27 18:56:12 +00:00
. try_get_matches_from ( empty_args ( ) )
. unwrap ( ) ;
2020-02-10 10:04:18 +00:00
}
#[ test ]
fn help_required_and_given_for_subcommand ( ) {
2022-02-12 03:48:29 +00:00
Command ::new ( " myapp " )
2022-02-10 17:51:40 +00:00
. help_expected ( true )
2021-11-18 16:17:15 +00:00
. arg ( Arg ::new ( " foo " ) . help ( " It does foo stuff " ) )
2020-02-10 10:04:18 +00:00
. subcommand (
2022-02-12 03:48:29 +00:00
Command ::new ( " bar " )
2021-11-18 16:17:15 +00:00
. arg ( Arg ::new ( " create " ) . help ( " creates bar " ) )
. arg ( Arg ::new ( " delete " ) . help ( " deletes bar " ) ) ,
2020-02-10 10:04:18 +00:00
)
2021-12-27 18:56:12 +00:00
. try_get_matches_from ( empty_args ( ) )
. unwrap ( ) ;
2020-02-10 10:04:18 +00:00
}
#[ test ]
fn help_required_and_given ( ) {
2022-02-12 03:48:29 +00:00
Command ::new ( " myapp " )
2022-02-10 17:51:40 +00:00
. help_expected ( true )
2021-11-18 16:17:15 +00:00
. arg ( Arg ::new ( " foo " ) . help ( " It does foo stuff " ) )
2021-12-27 18:56:12 +00:00
. try_get_matches_from ( empty_args ( ) )
. unwrap ( ) ;
2020-02-10 10:04:18 +00:00
}
#[ test ]
fn help_required_and_no_args ( ) {
2022-02-12 03:48:29 +00:00
Command ::new ( " myapp " )
2022-02-10 17:51:40 +00:00
. help_expected ( true )
2021-12-27 18:56:12 +00:00
. try_get_matches_from ( empty_args ( ) )
. unwrap ( ) ;
2020-02-10 10:04:18 +00:00
}
2020-08-11 21:46:09 +00:00
#[ test ]
fn issue_1642_long_help_spacing ( ) {
2024-07-31 20:58:24 +00:00
let cmd = Command ::new ( " prog " ) . arg (
Arg ::new ( " cfg " )
. long ( " config " )
. action ( ArgAction ::SetTrue )
. long_help (
" The config file used by the myprog must be in JSON format
with only valid keys and may not contain other nonsense
that cannot be read by this program . Obviously I ' m going on
and on , so I ' ll stop now . " ,
) ,
) ;
let expected = str ! [ [ r #"
2022-09-07 16:03:55 +00:00
Usage : prog [ OPTIONS ]
2022-07-22 20:43:49 +00:00
2022-08-26 14:40:23 +00:00
Options :
2022-09-07 20:29:15 +00:00
- - config
The config file used by the myprog must be in JSON format
with only valid keys and may not contain other nonsense
that cannot be read by this program . Obviously I ' m going on
and on , so I ' ll stop now .
2022-07-22 20:43:49 +00:00
2022-09-07 20:29:15 +00:00
- h , - - help
2023-01-03 16:49:43 +00:00
Print help ( see a summary with ' - h ' )
2022-07-22 20:43:49 +00:00
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " prog --help " , expected , false ) ;
2020-08-11 21:46:09 +00:00
}
2020-08-14 20:11:12 +00:00
2022-08-31 14:29:00 +00:00
const AFTER_HELP_NO_ARGS : & str = " \
2022-09-07 16:03:55 +00:00
Usage : myapp
2020-08-14 20:11:12 +00:00
This is after help .
" ;
#[ test ]
fn after_help_no_args ( ) {
2022-02-14 21:47:20 +00:00
let mut cmd = Command ::new ( " myapp " )
2020-08-14 20:11:12 +00:00
. version ( " 1.0 " )
2022-02-10 17:51:40 +00:00
. disable_help_flag ( true )
. disable_version_flag ( true )
2020-08-14 20:11:12 +00:00
. after_help ( " This is after help. " ) ;
2022-09-22 14:39:24 +00:00
let help = cmd . render_help ( ) . to_string ( ) ;
2020-08-14 20:11:12 +00:00
assert_eq! ( help , AFTER_HELP_NO_ARGS ) ;
}
2020-09-24 21:49:12 +00:00
2022-08-08 21:08:47 +00:00
#[ test ]
fn help_subcmd_help ( ) {
2024-07-31 20:58:24 +00:00
let cmd = Command ::new ( " myapp " )
. subcommand ( Command ::new ( " subcmd " ) . subcommand ( Command ::new ( " multi " ) . version ( " 1.0 " ) ) ) ;
let expected = str ! [ [ r #"
2021-10-15 18:27:40 +00:00
Print this message or the help of the given subcommand ( s )
2022-09-07 16:03:55 +00:00
Usage : myapp help [ COMMAND ] .. .
2021-10-15 18:27:40 +00:00
2022-08-26 14:40:23 +00:00
Arguments :
2022-11-08 05:04:02 +00:00
[ COMMAND ] .. . Print help for the subcommand ( s )
2021-10-15 18:27:40 +00:00
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd . clone ( ) , " myapp help help " , expected , false ) ;
2021-10-15 18:27:40 +00:00
}
2022-08-08 21:08:47 +00:00
#[ test ]
fn subcmd_help_subcmd_help ( ) {
2024-07-31 20:58:24 +00:00
let cmd = Command ::new ( " myapp " )
. subcommand ( Command ::new ( " subcmd " ) . subcommand ( Command ::new ( " multi " ) . version ( " 1.0 " ) ) ) ;
let expected = str ! [ [ r #"
2021-10-15 18:27:40 +00:00
Print this message or the help of the given subcommand ( s )
2022-09-07 16:03:55 +00:00
Usage : myapp subcmd help [ COMMAND ] .. .
2021-10-15 18:27:40 +00:00
2022-08-26 14:40:23 +00:00
Arguments :
2022-11-08 05:04:02 +00:00
[ COMMAND ] .. . Print help for the subcommand ( s )
2021-10-15 18:27:40 +00:00
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd . clone ( ) , " myapp subcmd help help " , expected , false ) ;
2021-10-15 18:27:40 +00:00
}
2022-08-27 00:40:48 +00:00
#[ test ]
fn global_args_should_show_on_toplevel_help_message ( ) {
let cmd = Command ::new ( " myapp " )
. arg (
Arg ::new ( " someglobal " )
. short ( 'g' )
. long ( " some-global " )
. global ( true ) ,
)
. subcommand ( Command ::new ( " subcmd " ) . subcommand ( Command ::new ( " multi " ) . version ( " 1.0 " ) ) ) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
Usage : myapp [ OPTIONS ] [ COMMAND ]
Commands :
subcmd
help Print this message or the help of the given subcommand ( s )
Options :
- g , - - some - global < someglobal >
- h , - - help Print help
" #]];
utils ::assert_output ( cmd , " myapp help " , expected , false ) ;
2022-08-27 00:40:48 +00:00
}
#[ test ]
fn global_args_should_not_show_on_help_message_for_help_help ( ) {
2024-07-31 20:58:24 +00:00
let cmd = Command ::new ( " myapp " )
. arg (
Arg ::new ( " someglobal " )
. short ( 'g' )
. long ( " some-global " )
. global ( true ) ,
)
. subcommand ( Command ::new ( " subcmd " ) . subcommand ( Command ::new ( " multi " ) . version ( " 1.0 " ) ) ) ;
let expected = str ! [ [ r #"
2022-08-27 00:40:48 +00:00
Print this message or the help of the given subcommand ( s )
2022-09-07 16:03:55 +00:00
Usage : myapp help [ COMMAND ] .. .
2022-08-27 00:40:48 +00:00
Arguments :
2022-11-08 05:04:02 +00:00
[ COMMAND ] .. . Print help for the subcommand ( s )
2022-08-27 00:40:48 +00:00
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " myapp help help " , expected , false ) ;
}
#[ test ]
fn global_args_should_show_on_help_message_for_subcommand ( ) {
2022-08-27 00:40:48 +00:00
let cmd = Command ::new ( " myapp " )
. arg (
Arg ::new ( " someglobal " )
. short ( 'g' )
. long ( " some-global " )
. global ( true ) ,
)
. subcommand ( Command ::new ( " subcmd " ) . subcommand ( Command ::new ( " multi " ) . version ( " 1.0 " ) ) ) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2022-09-07 16:03:55 +00:00
Usage : myapp subcmd [ OPTIONS ] [ COMMAND ]
2022-08-27 00:40:48 +00:00
2022-08-31 02:38:37 +00:00
Commands :
2024-07-31 20:58:24 +00:00
multi
2022-09-07 20:29:15 +00:00
help Print this message or the help of the given subcommand ( s )
2022-08-27 00:40:48 +00:00
Options :
2024-07-31 20:58:24 +00:00
- g , - - some - global < someglobal >
2023-01-03 16:49:43 +00:00
- h , - - help Print help
2022-08-27 00:40:48 +00:00
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " myapp help subcmd " , expected , false ) ;
}
#[ test ]
fn global_args_should_show_on_help_message_for_nested_subcommand ( ) {
2022-08-27 00:40:48 +00:00
let cmd = Command ::new ( " myapp " )
. arg (
Arg ::new ( " someglobal " )
. short ( 'g' )
. long ( " some-global " )
. global ( true ) ,
)
. subcommand ( Command ::new ( " subcmd " ) . subcommand ( Command ::new ( " multi " ) . version ( " 1.0 " ) ) ) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2022-09-07 16:03:55 +00:00
Usage : myapp subcmd multi [ OPTIONS ]
2022-08-27 00:40:48 +00:00
Options :
2024-07-31 20:58:24 +00:00
- g , - - some - global < someglobal >
2023-01-03 16:49:43 +00:00
- h , - - help Print help
- V , - - version Print version
2022-08-27 00:40:48 +00:00
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " myapp help subcmd multi " , expected , false ) ;
2022-08-27 00:40:48 +00:00
}
2020-10-10 15:11:42 +00:00
#[ test ]
fn option_usage_order ( ) {
2022-08-15 18:21:05 +00:00
let cmd = Command ::new ( " order " ) . args ( [
2022-07-26 00:17:01 +00:00
Arg ::new ( " a " ) . short ( 'a' ) . action ( ArgAction ::SetTrue ) ,
Arg ::new ( " B " ) . short ( 'B' ) . action ( ArgAction ::SetTrue ) ,
Arg ::new ( " b " ) . short ( 'b' ) . action ( ArgAction ::SetTrue ) ,
Arg ::new ( " save " ) . short ( 's' ) . action ( ArgAction ::SetTrue ) ,
Arg ::new ( " select_file " )
. long ( " select_file " )
. action ( ArgAction ::SetTrue ) ,
Arg ::new ( " select_folder " )
. long ( " select_folder " )
. action ( ArgAction ::SetTrue ) ,
Arg ::new ( " x " ) . short ( 'x' ) . action ( ArgAction ::SetTrue ) ,
2020-10-10 15:11:42 +00:00
] ) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
Usage : order [ OPTIONS ]
Options :
- a
- B
- b
- s
- - select_file
- - select_folder
- x
- h , - - help Print help
" #]];
utils ::assert_output ( cmd , " order --help " , expected , false ) ;
2020-10-10 15:11:42 +00:00
}
2020-12-08 17:04:21 +00:00
2021-06-20 15:28:50 +00:00
#[ test ]
2021-12-17 15:24:53 +00:00
fn prefer_about_over_long_about_in_subcommands_list ( ) {
2024-07-31 20:58:24 +00:00
let cmd = Command ::new ( " about-in-subcommands-list " ) . subcommand (
Command ::new ( " sub " )
. long_about ( " long about sub " )
. about ( " short about sub " ) ,
) ;
let expected = str ! [ [ r #"
2022-09-07 16:03:55 +00:00
Usage : about - in - subcommands - list [ COMMAND ]
2022-07-22 20:43:49 +00:00
2022-08-31 02:38:37 +00:00
Commands :
2022-09-07 20:29:15 +00:00
sub short about sub
help Print this message or the help of the given subcommand ( s )
2022-08-26 15:59:27 +00:00
Options :
2023-01-03 16:49:43 +00:00
- h , - - help Print help
2021-06-20 15:28:50 +00:00
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " about-in-subcommands-list --help " , expected , false ) ;
2021-06-20 15:28:50 +00:00
}
2020-12-08 17:04:21 +00:00
#[ test ]
fn issue_1794_usage ( ) {
2024-05-04 19:59:40 +00:00
let cmd = Command ::new ( " hello " )
2020-12-08 17:04:21 +00:00
. bin_name ( " deno " )
2022-07-29 21:36:03 +00:00
. arg (
Arg ::new ( " option1 " )
. long ( " option1 " )
. action ( ArgAction ::SetTrue ) ,
)
2022-07-26 00:17:01 +00:00
. arg ( Arg ::new ( " pos1 " ) . action ( ArgAction ::Set ) )
2020-12-08 17:04:21 +00:00
. group (
ArgGroup ::new ( " arg1 " )
2022-08-12 17:40:58 +00:00
. args ( [ " pos1 " , " option1 " ] )
2020-12-08 17:04:21 +00:00
. required ( true ) ,
)
2022-07-26 00:17:01 +00:00
. arg ( Arg ::new ( " pos2 " ) . action ( ArgAction ::Set ) ) ;
2020-12-08 17:04:21 +00:00
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
Usage : deno < pos1 | - - option1 > [ pos2 ]
2021-02-08 03:33:57 +00:00
2022-08-26 14:40:23 +00:00
Arguments :
2024-07-31 20:58:24 +00:00
[ pos1 ]
[ pos2 ]
2021-02-08 03:33:57 +00:00
2022-08-26 14:40:23 +00:00
Options :
2024-07-31 20:58:24 +00:00
- - option1
2023-01-03 16:49:43 +00:00
- h , - - help Print help
2021-02-08 03:33:57 +00:00
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " deno --help " , expected , false ) ;
}
2021-02-08 03:33:57 +00:00
#[ test ]
fn custom_heading_pos ( ) {
2022-02-14 21:47:20 +00:00
let cmd = Command ::new ( " test " )
2021-02-08 03:33:57 +00:00
. version ( " 1.4 " )
2021-11-18 16:17:15 +00:00
. arg ( Arg ::new ( " gear " ) . help ( " Which gear " ) )
2022-02-07 21:15:40 +00:00
. next_help_heading ( Some ( " NETWORKING " ) )
2021-11-18 16:17:15 +00:00
. arg ( Arg ::new ( " speed " ) . help ( " How fast " ) ) ;
2021-02-08 03:33:57 +00:00
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
Usage : test [ gear ] [ speed ]
2021-02-08 03:33:57 +00:00
2024-07-31 20:58:24 +00:00
Arguments :
[ gear ] Which gear
Options :
- h , - - help Print help
- V , - - version Print version
2021-02-08 03:33:57 +00:00
NETWORKING :
2024-07-31 20:58:24 +00:00
[ speed ] How fast
" #]];
utils ::assert_output ( cmd , " test --help " , expected , false ) ;
}
2021-02-08 03:33:57 +00:00
#[ test ]
fn only_custom_heading_opts_no_args ( ) {
2022-02-14 21:47:20 +00:00
let cmd = Command ::new ( " test " )
2021-02-08 03:33:57 +00:00
. version ( " 1.4 " )
2022-02-10 17:51:40 +00:00
. disable_version_flag ( true )
2022-08-08 21:08:47 +00:00
. disable_help_flag ( true )
2022-08-10 20:13:44 +00:00
. arg ( arg! ( - - help ) . action ( ArgAction ::Help ) . hide ( true ) )
2022-02-07 21:15:40 +00:00
. next_help_heading ( Some ( " NETWORKING " ) )
2022-09-12 21:59:57 +00:00
. arg ( arg! ( - s - - speed < SPEED > " How fast " ) ) ;
2021-02-08 03:33:57 +00:00
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
Usage : test [ OPTIONS ]
2021-02-08 03:33:57 +00:00
NETWORKING :
2024-07-31 20:58:24 +00:00
- s , - - speed < SPEED > How fast
" #]];
utils ::assert_output ( cmd , " test --help " , expected , false ) ;
}
2021-02-08 03:33:57 +00:00
#[ test ]
fn only_custom_heading_pos_no_args ( ) {
2022-02-14 21:47:20 +00:00
let cmd = Command ::new ( " test " )
2021-02-08 03:33:57 +00:00
. version ( " 1.4 " )
2022-02-10 17:51:40 +00:00
. disable_version_flag ( true )
2022-08-08 21:08:47 +00:00
. disable_help_flag ( true )
2022-08-10 20:13:44 +00:00
. arg ( arg! ( - - help ) . action ( ArgAction ::Help ) . hide ( true ) )
2022-02-07 21:15:40 +00:00
. next_help_heading ( Some ( " NETWORKING " ) )
2021-11-18 16:17:15 +00:00
. arg ( Arg ::new ( " speed " ) . help ( " How fast " ) ) ;
2021-02-08 03:33:57 +00:00
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
Usage : test [ speed ]
NETWORKING :
[ speed ] How fast
" #]];
utils ::assert_output ( cmd , " test --help " , expected , false ) ;
2021-02-08 03:33:57 +00:00
}
2021-07-20 19:38:58 +00:00
#[ test ]
fn issue_2508_number_of_values_with_single_value_name ( ) {
2022-02-14 21:47:20 +00:00
let cmd = Command ::new ( " my_app " )
2022-08-03 16:20:07 +00:00
. arg ( Arg ::new ( " some_arg " ) . long ( " some_arg " ) . num_args ( 2 ) )
2021-07-20 19:38:58 +00:00
. arg (
Arg ::new ( " some_arg_issue " )
. long ( " some_arg_issue " )
2022-08-03 16:20:07 +00:00
. num_args ( 2 )
2021-07-20 19:38:58 +00:00
. value_name ( " ARG " ) ,
) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2022-09-07 16:03:55 +00:00
Usage : my_app [ OPTIONS ]
2021-07-20 19:38:58 +00:00
2022-08-26 14:40:23 +00:00
Options :
2022-09-07 20:29:15 +00:00
- - some_arg < some_arg > < some_arg >
- - some_arg_issue < ARG > < ARG >
2023-01-03 16:49:43 +00:00
- h , - - help Print help
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " my_app --help " , expected , false ) ;
2021-07-20 19:38:58 +00:00
}
2021-07-31 06:39:23 +00:00
#[ test ]
fn missing_positional_final_required ( ) {
2022-02-14 21:47:20 +00:00
let cmd = Command ::new ( " test " )
2022-02-10 17:51:40 +00:00
. allow_missing_positional ( true )
2021-07-31 06:39:23 +00:00
. arg ( Arg ::new ( " arg1 " ) )
. arg ( Arg ::new ( " arg2 " ) . required ( true ) ) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2022-09-07 16:03:55 +00:00
Usage : test [ arg1 ] < arg2 >
2021-07-31 06:39:23 +00:00
2022-08-26 14:40:23 +00:00
Arguments :
2022-09-07 20:29:15 +00:00
[ arg1 ]
< arg2 >
2021-07-31 06:39:23 +00:00
2022-08-26 14:40:23 +00:00
Options :
2023-01-03 16:49:43 +00:00
- h , - - help Print help
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " test --help " , expected , false ) ;
2021-07-31 06:39:23 +00:00
}
#[ test ]
fn missing_positional_final_multiple ( ) {
2022-02-14 21:47:20 +00:00
let cmd = Command ::new ( " test " )
2022-02-10 17:51:40 +00:00
. allow_missing_positional ( true )
2021-07-31 06:39:23 +00:00
. arg ( Arg ::new ( " foo " ) )
. arg ( Arg ::new ( " bar " ) )
2022-08-03 16:20:07 +00:00
. arg ( Arg ::new ( " baz " ) . action ( ArgAction ::Set ) . num_args ( 1 .. ) ) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2022-09-07 16:03:55 +00:00
Usage : test [ foo ] [ bar ] [ baz ] .. .
2021-07-31 06:39:23 +00:00
2022-08-26 14:40:23 +00:00
Arguments :
2022-09-07 20:29:15 +00:00
[ foo ]
[ bar ]
[ baz ] .. .
2021-07-31 06:39:23 +00:00
2022-08-26 14:40:23 +00:00
Options :
2023-01-03 16:49:43 +00:00
- h , - - help Print help
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " test --help " , expected , false ) ;
2021-07-31 06:39:23 +00:00
}
2021-09-04 20:10:24 +00:00
2021-10-30 18:42:01 +00:00
#[ test ]
fn positional_multiple_values_is_dotted ( ) {
2022-02-14 21:47:20 +00:00
let cmd = Command ::new ( " test " ) . arg (
2021-10-30 18:42:01 +00:00
Arg ::new ( " foo " )
. required ( true )
2022-07-26 00:17:01 +00:00
. action ( ArgAction ::Set )
2022-08-03 16:20:07 +00:00
. num_args ( 1 .. ) ,
2021-10-30 18:42:01 +00:00
) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2022-09-07 16:03:55 +00:00
Usage : test < foo > .. .
2021-10-30 18:42:01 +00:00
2022-08-26 14:40:23 +00:00
Arguments :
2022-09-07 20:29:15 +00:00
< foo > .. .
2021-10-30 18:42:01 +00:00
2022-08-26 14:40:23 +00:00
Options :
2023-01-03 16:49:43 +00:00
- h , - - help Print help
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " test --help " , expected , false ) ;
2021-10-30 18:42:01 +00:00
2022-02-14 21:47:20 +00:00
let cmd = Command ::new ( " test " ) . arg (
2021-10-30 18:42:01 +00:00
Arg ::new ( " foo " )
. required ( true )
2022-07-26 00:17:01 +00:00
. action ( ArgAction ::Set )
2021-10-30 18:42:01 +00:00
. value_name ( " BAR " )
2022-08-03 16:20:07 +00:00
. num_args ( 1 .. ) ,
2021-10-30 18:42:01 +00:00
) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2022-09-07 16:03:55 +00:00
Usage : test < BAR > .. .
2021-10-30 18:42:01 +00:00
2022-08-26 14:40:23 +00:00
Arguments :
2022-09-07 20:29:15 +00:00
< BAR > .. .
2021-10-30 18:42:01 +00:00
2022-08-26 14:40:23 +00:00
Options :
2023-01-03 16:49:43 +00:00
- h , - - help Print help
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " test --help " , expected , false ) ;
2021-10-30 18:42:01 +00:00
}
#[ test ]
fn positional_multiple_occurrences_is_dotted ( ) {
2022-02-14 21:47:20 +00:00
let cmd = Command ::new ( " test " ) . arg (
2021-10-30 18:42:01 +00:00
Arg ::new ( " foo " )
. required ( true )
2022-07-26 00:17:01 +00:00
. action ( ArgAction ::Set )
2022-08-03 16:20:07 +00:00
. num_args ( 1 .. )
2022-06-07 18:48:48 +00:00
. action ( ArgAction ::Append ) ,
2021-10-30 18:42:01 +00:00
) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2022-09-07 16:03:55 +00:00
Usage : test < foo > .. .
2021-10-30 18:42:01 +00:00
2022-08-26 14:40:23 +00:00
Arguments :
2022-09-07 20:29:15 +00:00
< foo > .. .
2021-10-30 18:42:01 +00:00
2022-08-26 14:40:23 +00:00
Options :
2023-01-03 16:49:43 +00:00
- h , - - help Print help
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " test --help " , expected , false ) ;
2021-10-30 18:42:01 +00:00
2022-02-14 21:47:20 +00:00
let cmd = Command ::new ( " test " ) . arg (
2021-10-30 18:42:01 +00:00
Arg ::new ( " foo " )
. required ( true )
2022-07-26 00:17:01 +00:00
. action ( ArgAction ::Set )
2021-10-30 18:42:01 +00:00
. value_name ( " BAR " )
2022-08-03 16:20:07 +00:00
. num_args ( 1 .. )
2022-06-07 18:48:48 +00:00
. action ( ArgAction ::Append ) ,
2021-10-30 18:42:01 +00:00
) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2022-09-07 16:03:55 +00:00
Usage : test < BAR > .. .
2021-10-30 18:42:01 +00:00
2022-08-26 14:40:23 +00:00
Arguments :
2022-09-07 20:29:15 +00:00
< BAR > .. .
2021-10-30 18:42:01 +00:00
2022-08-26 14:40:23 +00:00
Options :
2023-01-03 16:49:43 +00:00
- h , - - help Print help
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " test --help " , expected , false ) ;
2021-10-30 18:42:01 +00:00
}
2022-05-06 18:33:17 +00:00
#[ test ]
fn too_few_value_names_is_dotted ( ) {
let cmd = Command ::new ( " test " ) . arg (
Arg ::new ( " foo " )
. long ( " foo " )
. required ( true )
2022-07-26 00:17:01 +00:00
. action ( ArgAction ::Set )
2022-08-03 16:20:07 +00:00
. num_args ( 3 )
2022-08-15 18:21:05 +00:00
. value_names ( [ " one " , " two " ] ) ,
2022-05-06 18:33:17 +00:00
) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2022-09-07 16:03:55 +00:00
Usage : test - - foo < one > < two > .. .
2022-05-06 18:33:17 +00:00
2022-08-26 14:40:23 +00:00
Options :
2022-09-07 20:29:15 +00:00
- - foo < one > < two > .. .
2023-01-03 16:49:43 +00:00
- h , - - help Print help
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " test --help " , expected , false ) ;
2022-05-06 18:33:17 +00:00
}
2022-05-06 18:53:59 +00:00
#[ test ]
2022-08-04 14:08:43 +00:00
#[ should_panic = " Argument foo: Too many value names (2) compared to `num_args` (1) " ]
2022-05-06 18:53:59 +00:00
fn too_many_value_names_panics ( ) {
Command ::new ( " test " )
. arg (
Arg ::new ( " foo " )
. long ( " foo " )
. required ( true )
2022-07-26 00:17:01 +00:00
. action ( ArgAction ::Set )
2022-08-03 16:20:07 +00:00
. num_args ( 1 )
2022-08-15 18:21:05 +00:00
. value_names ( [ " one " , " two " ] ) ,
2022-05-06 18:53:59 +00:00
)
2024-05-04 19:59:40 +00:00
. debug_assert ( ) ;
2022-05-06 18:53:59 +00:00
}
2021-09-04 20:10:24 +00:00
#[ test ]
fn disabled_help_flag ( ) {
2022-02-12 03:48:29 +00:00
let res = Command ::new ( " foo " )
. subcommand ( Command ::new ( " sub " ) )
2022-02-10 17:51:40 +00:00
. disable_help_flag ( true )
2021-11-17 20:23:22 +00:00
. try_get_matches_from ( " foo a " . split ( ' ' ) ) ;
2021-10-08 17:05:40 +00:00
assert! ( res . is_err ( ) ) ;
let err = res . unwrap_err ( ) ;
2022-07-22 17:12:35 +00:00
assert_eq! ( err . kind ( ) , ErrorKind ::InvalidSubcommand ) ;
2021-09-04 20:10:24 +00:00
}
#[ test ]
fn disabled_help_flag_and_subcommand ( ) {
2022-02-12 03:48:29 +00:00
let res = Command ::new ( " foo " )
. subcommand ( Command ::new ( " sub " ) )
2022-02-10 17:51:40 +00:00
. disable_help_flag ( true )
. disable_help_subcommand ( true )
2021-11-17 20:23:22 +00:00
. try_get_matches_from ( " foo help " . split ( ' ' ) ) ;
2021-10-08 17:05:40 +00:00
assert! ( res . is_err ( ) ) ;
let err = res . unwrap_err ( ) ;
2022-07-22 17:12:35 +00:00
assert_eq! ( err . kind ( ) , ErrorKind ::InvalidSubcommand ) ;
2021-12-13 19:09:46 +00:00
assert! (
err . to_string ( ) . ends_with ( '\n' ) ,
" Errors should have a trailing newline, got {:?} " ,
err . to_string ( )
) ;
2021-09-04 20:10:24 +00:00
}
2021-10-04 14:01:09 +00:00
#[ test ]
fn override_help_subcommand ( ) {
2022-02-14 21:47:20 +00:00
let cmd = Command ::new ( " bar " )
2022-07-26 00:17:01 +00:00
. subcommand ( Command ::new ( " help " ) . arg ( Arg ::new ( " arg " ) . action ( ArgAction ::Set ) ) )
. subcommand ( Command ::new ( " not_help " ) . arg ( Arg ::new ( " arg " ) . action ( ArgAction ::Set ) ) )
2022-02-10 17:51:40 +00:00
. disable_help_subcommand ( true ) ;
2022-11-24 13:54:25 +00:00
let matches = cmd . try_get_matches_from ( [ " bar " , " help " , " foo " ] ) . unwrap ( ) ;
2021-10-04 14:01:09 +00:00
assert_eq! (
2022-05-24 15:16:50 +00:00
matches
. subcommand_matches ( " help " )
. unwrap ( )
. get_one ::< String > ( " arg " )
. map ( | v | v . as_str ( ) ) ,
2021-10-04 14:01:09 +00:00
Some ( " foo " )
) ;
}
#[ test ]
fn override_help_flag_using_long ( ) {
2022-02-14 21:47:20 +00:00
let cmd = Command ::new ( " foo " )
2022-02-12 03:48:29 +00:00
. subcommand ( Command ::new ( " help " ) . long_flag ( " help " ) )
2022-08-08 21:08:47 +00:00
. disable_help_flag ( true )
. disable_help_subcommand ( true ) ;
2022-11-24 13:54:25 +00:00
let matches = cmd . try_get_matches_from ( [ " foo " , " --help " ] ) . unwrap ( ) ;
2021-10-04 14:01:09 +00:00
assert! ( matches . subcommand_matches ( " help " ) . is_some ( ) ) ;
}
#[ test ]
fn override_help_flag_using_short ( ) {
2022-02-14 21:47:20 +00:00
let cmd = Command ::new ( " foo " )
2022-02-10 17:51:40 +00:00
. disable_help_flag ( true )
2022-08-08 21:08:47 +00:00
. disable_help_subcommand ( true )
2022-02-12 03:48:29 +00:00
. subcommand ( Command ::new ( " help " ) . short_flag ( 'h' ) ) ;
2022-11-24 13:54:25 +00:00
let matches = cmd . try_get_matches_from ( [ " foo " , " -h " ] ) . unwrap ( ) ;
2021-10-04 14:01:09 +00:00
assert! ( matches . subcommand_matches ( " help " ) . is_some ( ) ) ;
}
2021-12-13 21:59:12 +00:00
#[ test ]
fn subcommand_help_doesnt_have_useless_help_flag ( ) {
// The main care-about is that the docs and behavior match. Since the `help` subcommand
// currently ignores the `--help` flag, the output shouldn't have it.
2022-05-05 01:46:42 +00:00
let cmd = Command ::new ( " example " ) . subcommand ( Command ::new ( " test " ) . about ( " Subcommand " ) ) ;
2021-12-13 21:59:12 +00:00
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2021-12-13 21:59:12 +00:00
Print this message or the help of the given subcommand ( s )
2022-09-07 16:03:55 +00:00
Usage : example help [ COMMAND ] .. .
2021-12-13 21:59:12 +00:00
2022-08-26 14:40:23 +00:00
Arguments :
2022-11-08 05:04:02 +00:00
[ COMMAND ] .. . Print help for the subcommand ( s )
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " example help help " , expected , false ) ;
2021-12-13 21:59:12 +00:00
}
#[ test ]
fn disable_help_flag_affects_help_subcommand ( ) {
2022-02-14 21:47:20 +00:00
let mut cmd = Command ::new ( " test_app " )
2022-02-10 17:51:40 +00:00
. disable_help_flag ( true )
2022-02-12 03:48:29 +00:00
. subcommand ( Command ::new ( " test " ) . about ( " Subcommand " ) ) ;
2022-04-19 15:11:27 +00:00
cmd . build ( ) ;
2021-12-13 21:59:12 +00:00
2022-02-14 21:47:20 +00:00
let args = cmd
2021-12-13 21:59:12 +00:00
. find_subcommand ( " help " )
. unwrap ( )
. get_arguments ( )
2022-08-11 20:33:23 +00:00
. map ( | a | a . get_id ( ) . as_str ( ) )
2021-12-13 21:59:12 +00:00
. collect ::< Vec < _ > > ( ) ;
assert! (
! args . contains ( & " help " ) ,
2023-05-04 01:40:21 +00:00
" `help` should not be present: {args:?} "
2021-12-13 21:59:12 +00:00
) ;
}
2022-01-18 20:36:48 +00:00
#[ test ]
fn dont_propagate_version_to_help_subcommand ( ) {
2024-05-04 19:59:40 +00:00
let cmd = Command ::new ( " example " )
2022-01-18 20:36:48 +00:00
. version ( " 1.0 " )
2022-02-10 17:51:40 +00:00
. propagate_version ( true )
2024-05-04 19:59:40 +00:00
. subcommand ( Command ::new ( " subcommand " ) ) ;
2022-01-18 20:36:48 +00:00
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2022-01-18 20:36:48 +00:00
Print this message or the help of the given subcommand ( s )
2022-09-07 16:03:55 +00:00
Usage : example help [ COMMAND ] .. .
2022-01-18 20:36:48 +00:00
2022-08-26 14:40:23 +00:00
Arguments :
2022-11-08 05:04:02 +00:00
[ COMMAND ] .. . Print help for the subcommand ( s )
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd . clone ( ) , " example help help " , expected , false ) ;
2022-01-18 20:36:48 +00:00
2022-02-14 21:47:20 +00:00
cmd . debug_assert ( ) ;
2022-01-18 20:36:48 +00:00
}
2022-02-09 00:51:44 +00:00
#[ test ]
fn help_without_short ( ) {
2024-05-04 19:59:40 +00:00
let mut cmd = Command ::new ( " test " )
2022-09-12 21:59:57 +00:00
. arg ( arg! ( - h - - hex < NUM > ) . required ( true ) )
2022-08-10 20:13:44 +00:00
. arg ( arg! ( - - help ) . action ( ArgAction ::Help ) )
2022-08-08 21:08:47 +00:00
. disable_help_flag ( true ) ;
2022-02-09 00:51:44 +00:00
2022-04-19 15:11:27 +00:00
cmd . build ( ) ;
2022-02-14 21:47:20 +00:00
let help = cmd . get_arguments ( ) . find ( | a | a . get_id ( ) = = " help " ) . unwrap ( ) ;
2022-02-09 00:51:44 +00:00
assert_eq! ( help . get_short ( ) , None ) ;
2022-02-14 21:47:20 +00:00
let m = cmd . try_get_matches_from ( [ " test " , " -h " , " 0x100 " ] ) . unwrap ( ) ;
2022-05-24 15:16:50 +00:00
assert_eq! (
m . get_one ::< String > ( " hex " ) . map ( | v | v . as_str ( ) ) ,
Some ( " 0x100 " )
) ;
2022-02-09 00:51:44 +00:00
}
2022-04-29 20:39:17 +00:00
#[ test ]
fn parent_cmd_req_in_usage_with_help_flag ( ) {
let cmd = Command ::new ( " parent " )
. version ( " 0.1 " )
. arg ( Arg ::new ( " TARGET " ) . required ( true ) . help ( " some " ) )
. arg (
Arg ::new ( " ARGS " )
2022-07-26 00:17:01 +00:00
. action ( ArgAction ::Set )
2022-04-29 20:39:17 +00:00
. required ( true )
. help ( " some " ) ,
)
. subcommand ( Command ::new ( " test " ) . about ( " some " ) ) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2022-04-29 20:39:17 +00:00
some
2022-09-07 16:03:55 +00:00
Usage : parent < TARGET > < ARGS > test
2022-04-29 20:39:17 +00:00
2022-08-26 14:40:23 +00:00
Options :
2023-01-03 16:49:43 +00:00
- h , - - help Print help
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " parent test --help " , expected , false ) ;
}
#[ test ]
fn parent_cmd_req_in_usage_with_help_subcommand ( ) {
2022-04-29 20:39:17 +00:00
let cmd = Command ::new ( " parent " )
. version ( " 0.1 " )
. arg ( Arg ::new ( " TARGET " ) . required ( true ) . help ( " some " ) )
. arg (
Arg ::new ( " ARGS " )
2022-07-26 00:17:01 +00:00
. action ( ArgAction ::Set )
2022-04-29 20:39:17 +00:00
. required ( true )
. help ( " some " ) ,
)
. subcommand ( Command ::new ( " test " ) . about ( " some " ) ) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
some
Usage : parent < TARGET > < ARGS > test
Options :
- h , - - help Print help
" #]];
utils ::assert_output ( cmd , " parent help test " , expected , false ) ;
2022-04-29 20:39:17 +00:00
}
2022-04-29 21:41:00 +00:00
#[ test ]
fn parent_cmd_req_in_usage_with_render_help ( ) {
let mut cmd = Command ::new ( " parent " )
. version ( " 0.1 " )
. arg ( Arg ::new ( " TARGET " ) . required ( true ) . help ( " some " ) )
. arg (
Arg ::new ( " ARGS " )
2022-07-26 00:17:01 +00:00
. action ( ArgAction ::Set )
2022-04-29 21:41:00 +00:00
. required ( true )
. help ( " some " ) ,
)
. subcommand ( Command ::new ( " test " ) . about ( " some " ) ) ;
cmd . build ( ) ;
let subcmd = cmd . find_subcommand_mut ( " test " ) . unwrap ( ) ;
2022-09-22 14:39:24 +00:00
let help = subcmd . render_help ( ) . to_string ( ) ;
2024-07-31 20:58:24 +00:00
assert_data_eq! (
help ,
str ! [ [ r #"
2024-05-24 15:13:50 +00:00
some
Usage : parent < TARGET > < ARGS > test
Options :
- h , - - help Print help
2024-07-31 20:58:24 +00:00
" #]]
) ;
2022-04-29 21:41:00 +00:00
}
2022-08-30 18:43:22 +00:00
#[ test ]
fn parent_cmd_req_ignored_when_negates_reqs ( ) {
let cmd = Command ::new ( " ctest " )
. arg ( arg! ( < input > ) )
. subcommand_negates_reqs ( true )
. subcommand ( Command ::new ( " subcmd " ) ) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2022-09-07 16:03:55 +00:00
Usage : ctest subcmd
2022-08-30 18:43:22 +00:00
Options :
2023-01-03 16:49:43 +00:00
- h , - - help Print help
2022-08-30 18:43:22 +00:00
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " ctest subcmd --help " , expected , false ) ;
}
#[ test ]
fn parent_cmd_req_ignored_when_conflicts ( ) {
2022-08-30 18:43:22 +00:00
let cmd = Command ::new ( " ctest " )
. arg ( arg! ( < input > ) )
. args_conflicts_with_subcommands ( true )
. subcommand ( Command ::new ( " subcmd " ) ) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
Usage : ctest subcmd
Options :
- h , - - help Print help
" #]];
utils ::assert_output ( cmd , " ctest subcmd --help " , expected , false ) ;
2022-08-30 18:43:22 +00:00
}
#[ test ]
fn no_wrap_help ( ) {
2024-07-31 20:58:24 +00:00
static MULTI_SC_HELP : & str = " \
tests subcommands
Usage : ctest subcmd multi [ OPTIONS ]
Options :
- f , - - flag tests flags
- o , - - option < scoption > .. . tests options
- h , - - help Print help
- V , - - version Print version
" ;
2022-08-30 18:43:22 +00:00
let cmd = Command ::new ( " ctest " )
. term_width ( 0 )
. override_help ( MULTI_SC_HELP ) ;
2024-07-31 20:58:24 +00:00
2022-08-31 14:35:33 +00:00
utils ::assert_output ( cmd , " ctest --help " , MULTI_SC_HELP , false ) ;
2022-08-30 18:43:22 +00:00
}
2022-05-02 21:52:55 +00:00
#[ test ]
fn display_name_default ( ) {
let mut cmd = Command ::new ( " app " ) . bin_name ( " app.exe " ) ;
cmd . build ( ) ;
assert_eq! ( cmd . get_display_name ( ) , None ) ;
}
#[ test ]
fn display_name_explicit ( ) {
let mut cmd = Command ::new ( " app " )
. bin_name ( " app.exe " )
. display_name ( " app.display " ) ;
cmd . build ( ) ;
2022-08-22 18:48:39 +00:00
assert_eq! ( cmd . get_display_name ( ) , Some ( " app.display " ) ) ;
2022-05-02 21:52:55 +00:00
}
#[ test ]
fn display_name_subcommand_default ( ) {
let mut cmd = Command ::new ( " parent " ) . subcommand ( Command ::new ( " child " ) . bin_name ( " child.exe " ) ) ;
cmd . build ( ) ;
assert_eq! (
2022-08-22 18:48:39 +00:00
cmd . find_subcommand ( " child " ) . unwrap ( ) . get_display_name ( ) ,
2022-05-02 21:52:55 +00:00
Some ( " parent-child " )
) ;
}
#[ test ]
fn display_name_subcommand_explicit ( ) {
let mut cmd = Command ::new ( " parent " ) . subcommand (
Command ::new ( " child " )
. bin_name ( " child.exe " )
. display_name ( " child.display " ) ,
) ;
cmd . build ( ) ;
assert_eq! (
2022-08-22 18:48:39 +00:00
cmd . find_subcommand ( " child " ) . unwrap ( ) . get_display_name ( ) ,
2022-05-02 21:52:55 +00:00
Some ( " child.display " )
) ;
}
2023-11-09 19:31:11 +00:00
#[ test ]
fn flatten_basic ( ) {
2024-07-31 20:58:24 +00:00
let cmd = Command ::new ( " parent " )
. flatten_help ( true )
. about ( " parent command " )
. arg ( Arg ::new ( " parent " ) . long ( " parent " ) )
. subcommand (
Command ::new ( " test " )
. about ( " test command " )
. arg ( Arg ::new ( " child " ) . long ( " child " ) ) ,
) ;
let expected = str ! [ [ r #"
2023-11-27 15:23:38 +00:00
parent command
2023-11-09 18:46:16 +00:00
Usage : parent [ OPTIONS ]
parent test [ OPTIONS ]
parent help [ COMMAND ] .. .
2023-11-09 19:31:11 +00:00
Options :
- - parent < parent >
- h , - - help Print help
2023-11-09 19:22:08 +00:00
parent test :
2023-11-27 15:28:30 +00:00
test command
2023-11-09 19:22:08 +00:00
- - child < child >
- h , - - help Print help
parent help :
2023-11-27 15:28:30 +00:00
Print this message or the help of the given subcommand ( s )
2023-11-09 19:22:08 +00:00
[ COMMAND ] .. . Print help for the subcommand ( s )
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " parent -h " , expected , false ) ;
}
#[ test ]
fn flatten_short_help ( ) {
2023-11-09 19:31:11 +00:00
let cmd = Command ::new ( " parent " )
. flatten_help ( true )
2023-11-27 15:23:38 +00:00
. about ( " parent command " )
2024-07-31 20:58:24 +00:00
. arg (
Arg ::new ( " parent " )
. long ( " parent " )
. help ( " foo " )
. long_help ( " bar " ) ,
)
2023-11-09 19:31:11 +00:00
. subcommand (
Command ::new ( " test " )
2023-11-27 15:23:38 +00:00
. about ( " test command " )
2024-07-31 20:58:24 +00:00
. long_about ( " long some " )
. arg ( Arg ::new ( " child " ) . long ( " child " ) . help ( " foo " ) . long_help ( " bar " ) ) ,
2023-11-09 19:31:11 +00:00
) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2023-11-27 15:23:38 +00:00
parent command
2023-11-09 18:46:16 +00:00
Usage : parent [ OPTIONS ]
parent test [ OPTIONS ]
parent help [ COMMAND ] .. .
2023-11-09 19:31:11 +00:00
Options :
- - parent < parent > foo
- h , - - help Print help ( see more with ' - - help ' )
2023-11-09 19:22:08 +00:00
parent test :
2023-11-27 15:28:30 +00:00
test command
2023-11-09 19:22:08 +00:00
- - child < child > foo
- h , - - help Print help ( see more with ' - - help ' )
parent help :
2023-11-27 15:28:30 +00:00
Print this message or the help of the given subcommand ( s )
2023-11-09 19:22:08 +00:00
[ COMMAND ] .. . Print help for the subcommand ( s )
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " parent -h " , expected , false ) ;
}
#[ test ]
fn flatten_long_help ( ) {
2023-11-09 19:31:11 +00:00
let cmd = Command ::new ( " parent " )
. flatten_help ( true )
2023-11-27 15:23:38 +00:00
. about ( " parent command " )
2023-11-09 19:31:11 +00:00
. arg (
Arg ::new ( " parent " )
. long ( " parent " )
. help ( " foo " )
. long_help ( " bar " ) ,
)
. subcommand (
Command ::new ( " test " )
2023-11-27 15:23:38 +00:00
. about ( " test command " )
2023-11-09 19:31:11 +00:00
. long_about ( " long some " )
. arg ( Arg ::new ( " child " ) . long ( " child " ) . help ( " foo " ) . long_help ( " bar " ) ) ,
) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2023-11-27 15:23:38 +00:00
parent command
2023-11-09 18:46:16 +00:00
Usage : parent [ OPTIONS ]
parent test [ OPTIONS ]
parent help [ COMMAND ] .. .
2023-11-09 19:31:11 +00:00
Options :
- - parent < parent >
bar
- h , - - help
Print help ( see a summary with ' - h ' )
2023-11-09 19:22:08 +00:00
parent test :
2023-11-27 15:28:30 +00:00
test command
2023-11-09 20:31:52 +00:00
- - child < child >
bar
- h , - - help
Print help ( see a summary with ' - h ' )
2023-11-09 19:22:08 +00:00
parent help :
2023-11-27 15:28:30 +00:00
Print this message or the help of the given subcommand ( s )
2023-11-09 20:31:52 +00:00
[ COMMAND ] .. .
Print help for the subcommand ( s )
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " parent --help " , expected , false ) ;
}
#[ test ]
fn flatten_help_cmd ( ) {
2023-11-09 19:31:11 +00:00
let cmd = Command ::new ( " parent " )
. flatten_help ( true )
2023-11-27 15:23:38 +00:00
. about ( " parent command " )
2023-11-09 19:31:11 +00:00
. arg (
Arg ::new ( " parent " )
. long ( " parent " )
. help ( " foo " )
. long_help ( " bar " ) ,
)
. subcommand (
Command ::new ( " test " )
2023-11-27 15:23:38 +00:00
. about ( " test command " )
2023-11-09 19:31:11 +00:00
. long_about ( " long some " )
. arg ( Arg ::new ( " child " ) . long ( " child " ) . help ( " foo " ) . long_help ( " bar " ) ) ,
) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2023-11-27 15:23:38 +00:00
parent command
2023-11-09 18:46:16 +00:00
Usage : parent [ OPTIONS ]
parent test [ OPTIONS ]
parent help [ COMMAND ] .. .
2023-11-09 19:31:11 +00:00
Options :
- - parent < parent >
bar
- h , - - help
Print help ( see a summary with ' - h ' )
2023-11-09 19:22:08 +00:00
parent test :
2023-11-27 15:28:30 +00:00
test command
2023-11-09 20:31:52 +00:00
- - child < child >
bar
- h , - - help
Print help ( see a summary with ' - h ' )
2023-11-09 19:22:08 +00:00
parent help :
2023-11-27 15:28:30 +00:00
Print this message or the help of the given subcommand ( s )
2023-11-09 20:31:52 +00:00
[ COMMAND ] .. .
Print help for the subcommand ( s )
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " parent help " , expected , false ) ;
}
#[ test ]
fn flatten_with_global ( ) {
2023-11-09 19:31:11 +00:00
let cmd = Command ::new ( " parent " )
. flatten_help ( true )
2023-11-27 15:23:38 +00:00
. about ( " parent command " )
2024-07-31 20:58:24 +00:00
. arg ( Arg ::new ( " parent " ) . long ( " parent " ) . global ( true ) )
2023-11-09 19:31:11 +00:00
. subcommand (
Command ::new ( " test " )
2023-11-27 15:23:38 +00:00
. about ( " test command " )
2024-07-31 20:58:24 +00:00
. arg ( Arg ::new ( " child " ) . long ( " child " ) ) ,
2023-11-09 19:31:11 +00:00
) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2023-11-27 15:23:38 +00:00
parent command
2023-11-09 18:46:16 +00:00
Usage : parent [ OPTIONS ]
parent test [ OPTIONS ]
parent help [ COMMAND ] .. .
2023-11-09 19:31:11 +00:00
Options :
- - parent < parent >
- h , - - help Print help
2023-11-09 19:22:08 +00:00
parent test :
2023-11-27 15:28:30 +00:00
test command
2023-11-09 20:37:09 +00:00
- - child < child >
- h , - - help Print help
2023-11-09 19:22:08 +00:00
parent help :
2023-11-27 15:28:30 +00:00
Print this message or the help of the given subcommand ( s )
2023-11-09 19:22:08 +00:00
[ COMMAND ] .. . Print help for the subcommand ( s )
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " parent -h " , expected , false ) ;
}
#[ test ]
fn flatten_arg_required ( ) {
2023-11-09 19:31:11 +00:00
let cmd = Command ::new ( " parent " )
. flatten_help ( true )
2023-11-27 15:23:38 +00:00
. about ( " parent command " )
2024-07-31 20:58:24 +00:00
. arg ( Arg ::new ( " parent " ) . long ( " parent " ) . required ( true ) )
2023-11-09 19:31:11 +00:00
. subcommand (
Command ::new ( " test " )
2023-11-27 15:23:38 +00:00
. about ( " test command " )
2024-07-31 20:58:24 +00:00
. arg ( Arg ::new ( " child " ) . long ( " child " ) . required ( true ) ) ,
2023-11-09 19:31:11 +00:00
) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2023-11-27 15:23:38 +00:00
parent command
2023-11-09 18:46:16 +00:00
Usage : parent - - parent < parent >
parent - - parent < parent > test - - child < child >
parent - - parent < parent > help [ COMMAND ] .. .
2023-11-09 19:31:11 +00:00
Options :
- - parent < parent >
- h , - - help Print help
2023-11-09 19:22:08 +00:00
parent - - parent < parent > test :
2023-11-27 15:28:30 +00:00
test command
2023-11-09 19:22:08 +00:00
- - child < child >
- h , - - help Print help
parent - - parent < parent > help :
2023-11-27 15:28:30 +00:00
Print this message or the help of the given subcommand ( s )
2023-11-09 19:22:08 +00:00
[ COMMAND ] .. . Print help for the subcommand ( s )
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " parent -h " , expected , false ) ;
}
#[ test ]
fn flatten_with_external_subcommand ( ) {
2023-11-09 19:31:11 +00:00
let cmd = Command ::new ( " parent " )
. flatten_help ( true )
2023-11-27 15:23:38 +00:00
. about ( " parent command " )
2024-07-31 20:58:24 +00:00
. allow_external_subcommands ( true )
. arg ( Arg ::new ( " parent " ) . long ( " parent " ) )
2023-11-09 19:31:11 +00:00
. subcommand (
Command ::new ( " test " )
2023-11-27 15:23:38 +00:00
. about ( " test command " )
2024-07-31 20:58:24 +00:00
. arg ( Arg ::new ( " child " ) . long ( " child " ) ) ,
2023-11-09 19:31:11 +00:00
) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2023-11-27 15:23:38 +00:00
parent command
2023-11-09 18:46:16 +00:00
Usage : parent [ OPTIONS ]
parent test [ OPTIONS ]
parent help [ COMMAND ] .. .
2023-11-09 19:31:11 +00:00
Options :
- - parent < parent >
- h , - - help Print help
2023-11-09 19:22:08 +00:00
parent test :
2023-11-27 15:28:30 +00:00
test command
2023-11-09 19:22:08 +00:00
- - child < child >
- h , - - help Print help
parent help :
2023-11-27 15:28:30 +00:00
Print this message or the help of the given subcommand ( s )
2023-11-09 19:22:08 +00:00
[ COMMAND ] .. . Print help for the subcommand ( s )
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " parent -h " , expected , false ) ;
2023-11-09 19:31:11 +00:00
}
#[ test ]
fn flatten_without_subcommands ( ) {
2024-07-31 20:58:24 +00:00
let cmd = Command ::new ( " parent " )
. flatten_help ( true )
. about ( " parent command " )
. arg ( Arg ::new ( " parent " ) . long ( " parent " ) ) ;
let expected = str ! [ [ r #"
2023-11-27 15:23:38 +00:00
parent command
2023-11-09 19:31:11 +00:00
Usage : parent [ OPTIONS ]
Options :
- - parent < parent >
- h , - - help Print help
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " parent -h " , expected , false ) ;
2023-11-09 19:31:11 +00:00
}
#[ test ]
fn flatten_with_subcommand_required ( ) {
2024-07-31 20:58:24 +00:00
let cmd = Command ::new ( " parent " )
. flatten_help ( true )
. about ( " parent command " )
. subcommand_required ( true )
. arg ( Arg ::new ( " parent " ) . long ( " parent " ) )
. subcommand (
Command ::new ( " test " )
. about ( " test command " )
. arg ( Arg ::new ( " child " ) . long ( " child " ) ) ,
) ;
let expected = str ! [ [ r #"
2023-11-27 15:23:38 +00:00
parent command
2023-11-09 18:46:16 +00:00
Usage : parent test [ OPTIONS ]
parent help [ COMMAND ] .. .
2023-11-09 19:31:11 +00:00
Options :
- - parent < parent >
- h , - - help Print help
2023-11-09 19:22:08 +00:00
parent test :
2023-11-27 15:28:30 +00:00
test command
2023-11-09 19:22:08 +00:00
- - child < child >
- h , - - help Print help
parent help :
2023-11-27 15:28:30 +00:00
Print this message or the help of the given subcommand ( s )
2023-11-09 19:22:08 +00:00
[ COMMAND ] .. . Print help for the subcommand ( s )
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " parent -h " , expected , false ) ;
}
#[ test ]
fn flatten_with_args_conflicts_with_subcommands ( ) {
2023-11-09 19:31:11 +00:00
let cmd = Command ::new ( " parent " )
. flatten_help ( true )
2023-11-27 15:23:38 +00:00
. about ( " parent command " )
2023-11-09 19:31:11 +00:00
. subcommand_required ( true )
2024-07-31 20:58:24 +00:00
. args_conflicts_with_subcommands ( true )
2023-11-09 19:31:11 +00:00
. arg ( Arg ::new ( " parent " ) . long ( " parent " ) )
. subcommand (
Command ::new ( " test " )
2023-11-27 15:23:38 +00:00
. about ( " test command " )
2023-11-09 19:31:11 +00:00
. arg ( Arg ::new ( " child " ) . long ( " child " ) ) ,
) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2023-11-27 15:23:38 +00:00
parent command
2023-11-09 19:31:11 +00:00
Usage : parent [ OPTIONS ]
2023-11-09 18:46:16 +00:00
parent test [ OPTIONS ]
parent help [ COMMAND ] .. .
2023-11-09 19:31:11 +00:00
Options :
- - parent < parent >
- h , - - help Print help
2023-11-09 19:22:08 +00:00
parent test :
2023-11-27 15:28:30 +00:00
test command
2023-11-09 19:22:08 +00:00
- - child < child >
- h , - - help Print help
parent help :
2023-11-27 15:28:30 +00:00
Print this message or the help of the given subcommand ( s )
2023-11-09 19:22:08 +00:00
[ COMMAND ] .. . Print help for the subcommand ( s )
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " parent -h " , expected , false ) ;
2023-11-09 19:31:11 +00:00
}
2023-11-27 16:38:05 +00:00
#[ test ]
fn flatten_single_hidden_command ( ) {
let cmd = Command ::new ( " parent " )
. flatten_help ( true )
. about ( " parent command " )
. arg ( Arg ::new ( " parent " ) . long ( " parent " ) )
. subcommand (
Command ::new ( " child1 " )
. hide ( true )
. about ( " child1 command " )
. arg ( Arg ::new ( " child " ) . long ( " child1 " ) ) ,
) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2023-11-27 16:38:05 +00:00
parent command
Usage : parent [ OPTIONS ]
Options :
- - parent < parent >
- h , - - help Print help
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " parent -h " , expected , false ) ;
}
2023-11-27 16:38:05 +00:00
2024-07-31 20:58:24 +00:00
#[ test ]
fn flatten_hidden_command ( ) {
2023-11-27 16:38:05 +00:00
let cmd = Command ::new ( " parent " )
. flatten_help ( true )
. about ( " parent command " )
. arg ( Arg ::new ( " parent " ) . long ( " parent " ) )
. subcommand (
Command ::new ( " child1 " )
. about ( " child1 command " )
. arg ( Arg ::new ( " child " ) . long ( " child1 " ) ) ,
)
. subcommand (
Command ::new ( " child2 " )
. about ( " child2 command " )
. arg ( Arg ::new ( " child " ) . long ( " child2 " ) ) ,
)
. subcommand (
Command ::new ( " child3 " )
. hide ( true )
. about ( " child3 command " )
. arg ( Arg ::new ( " child " ) . long ( " child3 " ) ) ,
) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2023-11-27 15:23:38 +00:00
parent command
2023-11-09 18:46:16 +00:00
Usage : parent [ OPTIONS ]
parent child1 [ OPTIONS ]
parent child2 [ OPTIONS ]
parent help [ COMMAND ] .. .
2023-11-09 19:31:11 +00:00
Options :
- - parent < parent >
- h , - - help Print help
2023-11-09 19:22:08 +00:00
parent child1 :
2023-11-27 15:28:30 +00:00
child1 command
2023-11-09 19:22:08 +00:00
- - child1 < child >
- h , - - help Print help
parent child2 :
2023-11-27 15:28:30 +00:00
child2 command
2023-11-09 19:22:08 +00:00
- - child2 < child >
- h , - - help Print help
parent help :
2023-11-27 15:28:30 +00:00
Print this message or the help of the given subcommand ( s )
2023-11-09 19:22:08 +00:00
[ COMMAND ] .. . Print help for the subcommand ( s )
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " parent -h " , expected , false ) ;
}
#[ test ]
fn flatten_recursive ( ) {
2023-11-09 19:31:11 +00:00
let cmd = Command ::new ( " parent " )
. flatten_help ( true )
2023-11-27 15:23:38 +00:00
. about ( " parent command " )
2023-11-09 19:31:11 +00:00
. arg ( Arg ::new ( " parent " ) . long ( " parent " ) )
. subcommand (
Command ::new ( " child1 " )
. flatten_help ( true )
2023-11-27 15:23:38 +00:00
. about ( " child1 command " )
2023-11-09 19:31:11 +00:00
. arg ( Arg ::new ( " child " ) . long ( " child1 " ) )
. subcommand (
Command ::new ( " grandchild1 " )
. flatten_help ( true )
2023-11-27 15:23:38 +00:00
. about ( " grandchild1 command " )
2023-11-09 19:31:11 +00:00
. arg ( Arg ::new ( " grandchild " ) . long ( " grandchild1 " ) )
. subcommand (
Command ::new ( " greatgrandchild1 " )
2023-11-27 15:23:38 +00:00
. about ( " greatgrandchild1 command " )
2023-11-09 19:31:11 +00:00
. arg ( Arg ::new ( " greatgrandchild " ) . long ( " greatgrandchild1 " ) ) ,
)
. subcommand (
Command ::new ( " greatgrandchild2 " )
2023-11-27 15:23:38 +00:00
. about ( " greatgrandchild2 command " )
2023-11-09 19:31:11 +00:00
. arg ( Arg ::new ( " greatgrandchild " ) . long ( " greatgrandchild2 " ) ) ,
)
. subcommand (
Command ::new ( " greatgrandchild3 " )
2023-11-27 15:23:38 +00:00
. about ( " greatgrandchild3 command " )
2023-11-09 19:31:11 +00:00
. arg ( Arg ::new ( " greatgrandchild " ) . long ( " greatgrandchild3 " ) ) ,
) ,
)
. subcommand (
Command ::new ( " grandchild2 " )
2023-11-27 15:23:38 +00:00
. about ( " grandchild2 command " )
2023-11-09 19:31:11 +00:00
. arg ( Arg ::new ( " grandchild " ) . long ( " grandchild2 " ) ) ,
)
. subcommand (
Command ::new ( " grandchild3 " )
2023-11-27 15:23:38 +00:00
. about ( " grandchild3 command " )
2023-11-09 19:31:11 +00:00
. arg ( Arg ::new ( " grandchild " ) . long ( " grandchild3 " ) ) ,
) ,
)
. subcommand (
Command ::new ( " child2 " )
2023-11-27 15:23:38 +00:00
. about ( " child2 command " )
2023-11-09 19:31:11 +00:00
. arg ( Arg ::new ( " child " ) . long ( " child2 " ) ) ,
)
. subcommand (
Command ::new ( " child3 " )
2023-11-27 16:38:05 +00:00
. hide ( true )
2023-11-27 15:23:38 +00:00
. about ( " child3 command " )
2023-11-27 16:38:05 +00:00
. arg ( Arg ::new ( " child " ) . long ( " child3 " ) )
. subcommand (
Command ::new ( " grandchild1 " )
. flatten_help ( true )
. about ( " grandchild1 command " )
. arg ( Arg ::new ( " grandchild " ) . long ( " grandchild1 " ) )
. subcommand (
Command ::new ( " greatgrandchild1 " )
. about ( " greatgrandchild1 command " )
. arg ( Arg ::new ( " greatgrandchild " ) . long ( " greatgrandchild1 " ) ) ,
)
. subcommand (
Command ::new ( " greatgrandchild2 " )
. about ( " greatgrandchild2 command " )
. arg ( Arg ::new ( " greatgrandchild " ) . long ( " greatgrandchild2 " ) ) ,
)
. subcommand (
Command ::new ( " greatgrandchild3 " )
. about ( " greatgrandchild3 command " )
. arg ( Arg ::new ( " greatgrandchild " ) . long ( " greatgrandchild3 " ) ) ,
) ,
)
. subcommand (
Command ::new ( " grandchild2 " )
. about ( " grandchild2 command " )
. arg ( Arg ::new ( " grandchild " ) . long ( " grandchild2 " ) ) ,
)
. subcommand (
Command ::new ( " grandchild3 " )
. about ( " grandchild3 command " )
. arg ( Arg ::new ( " grandchild " ) . long ( " grandchild3 " ) ) ,
) ,
2023-11-09 19:31:11 +00:00
) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
2023-11-27 15:23:38 +00:00
parent command
2023-11-09 18:46:16 +00:00
Usage : parent [ OPTIONS ]
2024-07-31 20:58:24 +00:00
parent child1 [ OPTIONS ]
parent child1 grandchild1 [ OPTIONS ]
parent child1 grandchild1 greatgrandchild1 [ OPTIONS ]
parent child1 grandchild1 greatgrandchild2 [ OPTIONS ]
parent child1 grandchild1 greatgrandchild3 [ OPTIONS ]
parent child1 grandchild1 help [ COMMAND ]
parent child1 grandchild2 [ OPTIONS ]
parent child1 grandchild3 [ OPTIONS ]
parent child1 help [ COMMAND ]
2023-11-09 18:46:16 +00:00
parent child2 [ OPTIONS ]
parent help [ COMMAND ] .. .
2023-11-09 19:31:11 +00:00
Options :
- - parent < parent >
- h , - - help Print help
2023-11-09 19:22:08 +00:00
parent child1 :
2023-11-27 15:28:30 +00:00
child1 command
2023-11-09 19:22:08 +00:00
- - child1 < child >
- h , - - help Print help
2024-07-31 20:58:24 +00:00
parent child1 grandchild1 :
grandchild1 command
- - grandchild1 < grandchild >
- h , - - help Print help
parent child1 grandchild1 greatgrandchild1 :
greatgrandchild1 command
- - greatgrandchild1 < greatgrandchild >
- h , - - help Print help
parent child1 grandchild1 greatgrandchild2 :
greatgrandchild2 command
- - greatgrandchild2 < greatgrandchild >
- h , - - help Print help
parent child1 grandchild1 greatgrandchild3 :
greatgrandchild3 command
- - greatgrandchild3 < greatgrandchild >
- h , - - help Print help
parent child1 grandchild1 help :
Print this message or the help of the given subcommand ( s )
parent child1 grandchild2 :
grandchild2 command
- - grandchild2 < grandchild >
- h , - - help Print help
parent child1 grandchild3 :
grandchild3 command
- - grandchild3 < grandchild >
- h , - - help Print help
parent child1 help :
Print this message or the help of the given subcommand ( s )
2023-11-09 19:22:08 +00:00
parent child2 :
2023-11-27 15:28:30 +00:00
child2 command
2023-11-09 19:22:08 +00:00
- - child2 < child >
- h , - - help Print help
parent help :
2023-11-27 15:28:30 +00:00
Print this message or the help of the given subcommand ( s )
2023-11-09 19:22:08 +00:00
[ COMMAND ] .. . Print help for the subcommand ( s )
2024-07-31 20:58:24 +00:00
" #]];
utils ::assert_output ( cmd , " parent -h " , expected , false ) ;
}
#[ test ]
fn flatten_not_recursive ( ) {
2023-11-09 19:31:11 +00:00
let cmd = Command ::new ( " parent " )
. flatten_help ( true )
2023-11-27 15:23:38 +00:00
. about ( " parent command " )
2023-11-09 19:31:11 +00:00
. arg ( Arg ::new ( " parent " ) . long ( " parent " ) )
. subcommand (
Command ::new ( " child1 " )
2023-11-27 15:23:38 +00:00
. about ( " child1 command " )
2023-11-09 19:31:11 +00:00
. arg ( Arg ::new ( " child " ) . long ( " child1 " ) )
. subcommand (
Command ::new ( " grandchild1 " )
2023-11-27 15:23:38 +00:00
. about ( " grandchild1 command " )
2023-11-09 19:31:11 +00:00
. arg ( Arg ::new ( " grandchild " ) . long ( " grandchild1 " ) ) ,
)
. subcommand (
Command ::new ( " grandchild2 " )
2023-11-27 15:23:38 +00:00
. about ( " grandchild2 command " )
2023-11-09 19:31:11 +00:00
. arg ( Arg ::new ( " grandchild " ) . long ( " grandchild2 " ) ) ,
)
. subcommand (
Command ::new ( " grandchild3 " )
2023-11-27 15:23:38 +00:00
. about ( " grandchild3 command " )
2023-11-09 19:31:11 +00:00
. arg ( Arg ::new ( " grandchild " ) . long ( " grandchild3 " ) ) ,
) ,
)
. subcommand (
Command ::new ( " child2 " )
2023-11-27 15:23:38 +00:00
. about ( " child2 command " )
2023-11-09 19:31:11 +00:00
. arg ( Arg ::new ( " child " ) . long ( " child2 " ) ) ,
)
. subcommand (
Command ::new ( " child3 " )
2023-11-27 15:23:38 +00:00
. about ( " child3 command " )
2023-11-09 19:31:11 +00:00
. arg ( Arg ::new ( " child " ) . long ( " child3 " ) ) ,
) ;
2024-07-31 20:58:24 +00:00
let expected = str ! [ [ r #"
parent command
Usage : parent [ OPTIONS ]
parent child1 [ OPTIONS ] [ COMMAND ]
parent child2 [ OPTIONS ]
parent child3 [ OPTIONS ]
parent help [ COMMAND ] .. .
Options :
- - parent < parent >
- h , - - help Print help
parent child1 :
child1 command
- - child1 < child >
- h , - - help Print help
parent child2 :
child2 command
- - child2 < child >
- h , - - help Print help
parent child3 :
child3 command
- - child3 < child >
- h , - - help Print help
parent help :
Print this message or the help of the given subcommand ( s )
[ COMMAND ] .. . Print help for the subcommand ( s )
" #]];
utils ::assert_output ( cmd , " parent -h " , expected , false ) ;
2023-11-09 19:31:11 +00:00
}