2022-09-13 12:15:56 +00:00
|
|
|
use clap::Args;
|
2021-07-13 17:50:55 +00:00
|
|
|
use clap::Parser;
|
2020-01-07 10:17:23 +00:00
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_standalone_long_generates_kebab_case() {
|
2021-07-13 17:50:55 +00:00
|
|
|
#[derive(Parser, Debug, PartialEq)]
|
2020-01-07 10:17:23 +00:00
|
|
|
#[allow(non_snake_case)]
|
|
|
|
struct Opt {
|
2022-09-02 20:37:23 +00:00
|
|
|
#[arg(long)]
|
2020-01-07 10:17:23 +00:00
|
|
|
FOO_OPTION: bool,
|
|
|
|
}
|
|
|
|
|
|
|
|
assert_eq!(
|
|
|
|
Opt { FOO_OPTION: true },
|
2022-11-24 13:54:25 +00:00
|
|
|
Opt::try_parse_from(["test", "--foo-option"]).unwrap()
|
2020-01-07 10:17:23 +00:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_custom_long_overwrites_default_name() {
|
2021-07-13 17:50:55 +00:00
|
|
|
#[derive(Parser, Debug, PartialEq)]
|
2020-01-07 10:17:23 +00:00
|
|
|
struct Opt {
|
2022-09-02 20:37:23 +00:00
|
|
|
#[arg(long = "foo")]
|
2020-01-07 10:17:23 +00:00
|
|
|
foo_option: bool,
|
|
|
|
}
|
|
|
|
|
|
|
|
assert_eq!(
|
|
|
|
Opt { foo_option: true },
|
2022-11-24 13:54:25 +00:00
|
|
|
Opt::try_parse_from(["test", "--foo"]).unwrap()
|
2020-01-07 10:17:23 +00:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_standalone_long_uses_previous_defined_custom_name() {
|
2021-07-13 17:50:55 +00:00
|
|
|
#[derive(Parser, Debug, PartialEq)]
|
2020-01-07 10:17:23 +00:00
|
|
|
struct Opt {
|
2022-09-03 00:57:37 +00:00
|
|
|
#[arg(id = "foo", long)]
|
2020-01-07 10:17:23 +00:00
|
|
|
foo_option: bool,
|
|
|
|
}
|
|
|
|
|
|
|
|
assert_eq!(
|
|
|
|
Opt { foo_option: true },
|
2022-11-24 13:54:25 +00:00
|
|
|
Opt::try_parse_from(["test", "--foo"]).unwrap()
|
2020-01-07 10:17:23 +00:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_standalone_long_ignores_afterwards_defined_custom_name() {
|
2021-07-13 17:50:55 +00:00
|
|
|
#[derive(Parser, Debug, PartialEq)]
|
2020-01-07 10:17:23 +00:00
|
|
|
struct Opt {
|
2022-09-03 00:57:37 +00:00
|
|
|
#[arg(long, id = "foo")]
|
2020-01-07 10:17:23 +00:00
|
|
|
foo_option: bool,
|
|
|
|
}
|
|
|
|
|
|
|
|
assert_eq!(
|
|
|
|
Opt { foo_option: true },
|
2022-11-24 13:54:25 +00:00
|
|
|
Opt::try_parse_from(["test", "--foo-option"]).unwrap()
|
2020-01-07 10:17:23 +00:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2022-07-31 00:07:15 +00:00
|
|
|
#[test]
|
|
|
|
fn test_standalone_long_uses_previous_defined_custom_id() {
|
|
|
|
#[derive(Parser, Debug, PartialEq)]
|
|
|
|
struct Opt {
|
2022-09-02 20:37:23 +00:00
|
|
|
#[arg(id = "foo", long)]
|
2022-07-31 00:07:15 +00:00
|
|
|
foo_option: bool,
|
|
|
|
}
|
|
|
|
|
|
|
|
assert_eq!(
|
|
|
|
Opt { foo_option: true },
|
2022-11-24 13:54:25 +00:00
|
|
|
Opt::try_parse_from(["test", "--foo"]).unwrap()
|
2022-07-31 00:07:15 +00:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_standalone_long_ignores_afterwards_defined_custom_id() {
|
|
|
|
#[derive(Parser, Debug, PartialEq)]
|
|
|
|
struct Opt {
|
2022-09-02 20:37:23 +00:00
|
|
|
#[arg(long, id = "foo")]
|
2022-07-31 00:07:15 +00:00
|
|
|
foo_option: bool,
|
|
|
|
}
|
|
|
|
|
|
|
|
assert_eq!(
|
|
|
|
Opt { foo_option: true },
|
2022-11-24 13:54:25 +00:00
|
|
|
Opt::try_parse_from(["test", "--foo-option"]).unwrap()
|
2022-07-31 00:07:15 +00:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2020-01-07 10:17:23 +00:00
|
|
|
#[test]
|
|
|
|
fn test_standalone_short_generates_kebab_case() {
|
2021-07-13 17:50:55 +00:00
|
|
|
#[derive(Parser, Debug, PartialEq)]
|
2020-01-07 10:17:23 +00:00
|
|
|
#[allow(non_snake_case)]
|
|
|
|
struct Opt {
|
2022-09-02 20:37:23 +00:00
|
|
|
#[arg(short)]
|
2020-01-07 10:17:23 +00:00
|
|
|
FOO_OPTION: bool,
|
|
|
|
}
|
|
|
|
|
test(derive): Provide better error info
`Parser::parse_from` will call `exit` on failure and we don't just lose
backtrace information but we don't even know which of the tests running
in parallel panicked. I ran into this when experimenting with
`clap_derive` and I couldn't tell what actually failed.
So let's switch to `Parse::try_parse_from`.
Errors went from:
```
test option_option ... ok
error: Found argument 'bar' which wasn't expected, or isn't valid in this context
USAGE:
clap_derive [OPTIONS]
For more information try --help
error: test failed, to rerun pass '--test arg_enum'
```
To:
```
test option_option ... ok
test variant_with_defined_casing ... ok
test skip_variant ... ok
test default_value ... ok
test vector ... FAILED
test option_vector ... ok
failures:
---- vector stdout ----
thread 'vector' panicked at 'called `Result::unwrap()` on an `Err` value: Error { message: Formatted(Colorizer { use_stderr: true, color_when: Auto
, pieces: [("error:", Some(Red)), (" ", None), ("Found argument '", None), ("bar", Some(Yellow)), ("' which wasn't expected, or isn't valid in this
context", None), ("\n\n", None), ("USAGE:\n clap_derive [OPTIONS]", None), ("\n\nFor more information try ", None), ("--help", Some(Green)), ("
\n", None)] }), kind: UnknownArgument, info: ["bar"], source: None, backtrace: Backtrace }', clap_derive/tests/arg_enum.rs:388:56
note: run with `RUST_BACKTRACE=1` environment variable to display a backtrace
failures:
vector
test result: FAILED. 15 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
error: test failed, to rerun pass '--test arg_enum'
```
2021-10-30 14:55:50 +00:00
|
|
|
assert_eq!(
|
|
|
|
Opt { FOO_OPTION: true },
|
2022-11-24 13:54:25 +00:00
|
|
|
Opt::try_parse_from(["test", "-f"]).unwrap()
|
test(derive): Provide better error info
`Parser::parse_from` will call `exit` on failure and we don't just lose
backtrace information but we don't even know which of the tests running
in parallel panicked. I ran into this when experimenting with
`clap_derive` and I couldn't tell what actually failed.
So let's switch to `Parse::try_parse_from`.
Errors went from:
```
test option_option ... ok
error: Found argument 'bar' which wasn't expected, or isn't valid in this context
USAGE:
clap_derive [OPTIONS]
For more information try --help
error: test failed, to rerun pass '--test arg_enum'
```
To:
```
test option_option ... ok
test variant_with_defined_casing ... ok
test skip_variant ... ok
test default_value ... ok
test vector ... FAILED
test option_vector ... ok
failures:
---- vector stdout ----
thread 'vector' panicked at 'called `Result::unwrap()` on an `Err` value: Error { message: Formatted(Colorizer { use_stderr: true, color_when: Auto
, pieces: [("error:", Some(Red)), (" ", None), ("Found argument '", None), ("bar", Some(Yellow)), ("' which wasn't expected, or isn't valid in this
context", None), ("\n\n", None), ("USAGE:\n clap_derive [OPTIONS]", None), ("\n\nFor more information try ", None), ("--help", Some(Green)), ("
\n", None)] }), kind: UnknownArgument, info: ["bar"], source: None, backtrace: Backtrace }', clap_derive/tests/arg_enum.rs:388:56
note: run with `RUST_BACKTRACE=1` environment variable to display a backtrace
failures:
vector
test result: FAILED. 15 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
error: test failed, to rerun pass '--test arg_enum'
```
2021-10-30 14:55:50 +00:00
|
|
|
);
|
2020-01-07 10:17:23 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_custom_short_overwrites_default_name() {
|
2021-07-13 17:50:55 +00:00
|
|
|
#[derive(Parser, Debug, PartialEq)]
|
2020-01-07 10:17:23 +00:00
|
|
|
struct Opt {
|
2022-09-02 20:37:23 +00:00
|
|
|
#[arg(short = 'o')]
|
2020-01-07 10:17:23 +00:00
|
|
|
foo_option: bool,
|
|
|
|
}
|
|
|
|
|
test(derive): Provide better error info
`Parser::parse_from` will call `exit` on failure and we don't just lose
backtrace information but we don't even know which of the tests running
in parallel panicked. I ran into this when experimenting with
`clap_derive` and I couldn't tell what actually failed.
So let's switch to `Parse::try_parse_from`.
Errors went from:
```
test option_option ... ok
error: Found argument 'bar' which wasn't expected, or isn't valid in this context
USAGE:
clap_derive [OPTIONS]
For more information try --help
error: test failed, to rerun pass '--test arg_enum'
```
To:
```
test option_option ... ok
test variant_with_defined_casing ... ok
test skip_variant ... ok
test default_value ... ok
test vector ... FAILED
test option_vector ... ok
failures:
---- vector stdout ----
thread 'vector' panicked at 'called `Result::unwrap()` on an `Err` value: Error { message: Formatted(Colorizer { use_stderr: true, color_when: Auto
, pieces: [("error:", Some(Red)), (" ", None), ("Found argument '", None), ("bar", Some(Yellow)), ("' which wasn't expected, or isn't valid in this
context", None), ("\n\n", None), ("USAGE:\n clap_derive [OPTIONS]", None), ("\n\nFor more information try ", None), ("--help", Some(Green)), ("
\n", None)] }), kind: UnknownArgument, info: ["bar"], source: None, backtrace: Backtrace }', clap_derive/tests/arg_enum.rs:388:56
note: run with `RUST_BACKTRACE=1` environment variable to display a backtrace
failures:
vector
test result: FAILED. 15 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
error: test failed, to rerun pass '--test arg_enum'
```
2021-10-30 14:55:50 +00:00
|
|
|
assert_eq!(
|
|
|
|
Opt { foo_option: true },
|
2022-11-24 13:54:25 +00:00
|
|
|
Opt::try_parse_from(["test", "-o"]).unwrap()
|
test(derive): Provide better error info
`Parser::parse_from` will call `exit` on failure and we don't just lose
backtrace information but we don't even know which of the tests running
in parallel panicked. I ran into this when experimenting with
`clap_derive` and I couldn't tell what actually failed.
So let's switch to `Parse::try_parse_from`.
Errors went from:
```
test option_option ... ok
error: Found argument 'bar' which wasn't expected, or isn't valid in this context
USAGE:
clap_derive [OPTIONS]
For more information try --help
error: test failed, to rerun pass '--test arg_enum'
```
To:
```
test option_option ... ok
test variant_with_defined_casing ... ok
test skip_variant ... ok
test default_value ... ok
test vector ... FAILED
test option_vector ... ok
failures:
---- vector stdout ----
thread 'vector' panicked at 'called `Result::unwrap()` on an `Err` value: Error { message: Formatted(Colorizer { use_stderr: true, color_when: Auto
, pieces: [("error:", Some(Red)), (" ", None), ("Found argument '", None), ("bar", Some(Yellow)), ("' which wasn't expected, or isn't valid in this
context", None), ("\n\n", None), ("USAGE:\n clap_derive [OPTIONS]", None), ("\n\nFor more information try ", None), ("--help", Some(Green)), ("
\n", None)] }), kind: UnknownArgument, info: ["bar"], source: None, backtrace: Backtrace }', clap_derive/tests/arg_enum.rs:388:56
note: run with `RUST_BACKTRACE=1` environment variable to display a backtrace
failures:
vector
test result: FAILED. 15 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
error: test failed, to rerun pass '--test arg_enum'
```
2021-10-30 14:55:50 +00:00
|
|
|
);
|
2020-01-07 10:17:23 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_standalone_short_uses_previous_defined_custom_name() {
|
2021-07-13 17:50:55 +00:00
|
|
|
#[derive(Parser, Debug, PartialEq)]
|
2020-01-07 10:17:23 +00:00
|
|
|
struct Opt {
|
2022-09-03 00:57:37 +00:00
|
|
|
#[arg(id = "option", short)]
|
2020-01-07 10:17:23 +00:00
|
|
|
foo_option: bool,
|
|
|
|
}
|
|
|
|
|
test(derive): Provide better error info
`Parser::parse_from` will call `exit` on failure and we don't just lose
backtrace information but we don't even know which of the tests running
in parallel panicked. I ran into this when experimenting with
`clap_derive` and I couldn't tell what actually failed.
So let's switch to `Parse::try_parse_from`.
Errors went from:
```
test option_option ... ok
error: Found argument 'bar' which wasn't expected, or isn't valid in this context
USAGE:
clap_derive [OPTIONS]
For more information try --help
error: test failed, to rerun pass '--test arg_enum'
```
To:
```
test option_option ... ok
test variant_with_defined_casing ... ok
test skip_variant ... ok
test default_value ... ok
test vector ... FAILED
test option_vector ... ok
failures:
---- vector stdout ----
thread 'vector' panicked at 'called `Result::unwrap()` on an `Err` value: Error { message: Formatted(Colorizer { use_stderr: true, color_when: Auto
, pieces: [("error:", Some(Red)), (" ", None), ("Found argument '", None), ("bar", Some(Yellow)), ("' which wasn't expected, or isn't valid in this
context", None), ("\n\n", None), ("USAGE:\n clap_derive [OPTIONS]", None), ("\n\nFor more information try ", None), ("--help", Some(Green)), ("
\n", None)] }), kind: UnknownArgument, info: ["bar"], source: None, backtrace: Backtrace }', clap_derive/tests/arg_enum.rs:388:56
note: run with `RUST_BACKTRACE=1` environment variable to display a backtrace
failures:
vector
test result: FAILED. 15 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
error: test failed, to rerun pass '--test arg_enum'
```
2021-10-30 14:55:50 +00:00
|
|
|
assert_eq!(
|
|
|
|
Opt { foo_option: true },
|
2022-11-24 13:54:25 +00:00
|
|
|
Opt::try_parse_from(["test", "-o"]).unwrap()
|
test(derive): Provide better error info
`Parser::parse_from` will call `exit` on failure and we don't just lose
backtrace information but we don't even know which of the tests running
in parallel panicked. I ran into this when experimenting with
`clap_derive` and I couldn't tell what actually failed.
So let's switch to `Parse::try_parse_from`.
Errors went from:
```
test option_option ... ok
error: Found argument 'bar' which wasn't expected, or isn't valid in this context
USAGE:
clap_derive [OPTIONS]
For more information try --help
error: test failed, to rerun pass '--test arg_enum'
```
To:
```
test option_option ... ok
test variant_with_defined_casing ... ok
test skip_variant ... ok
test default_value ... ok
test vector ... FAILED
test option_vector ... ok
failures:
---- vector stdout ----
thread 'vector' panicked at 'called `Result::unwrap()` on an `Err` value: Error { message: Formatted(Colorizer { use_stderr: true, color_when: Auto
, pieces: [("error:", Some(Red)), (" ", None), ("Found argument '", None), ("bar", Some(Yellow)), ("' which wasn't expected, or isn't valid in this
context", None), ("\n\n", None), ("USAGE:\n clap_derive [OPTIONS]", None), ("\n\nFor more information try ", None), ("--help", Some(Green)), ("
\n", None)] }), kind: UnknownArgument, info: ["bar"], source: None, backtrace: Backtrace }', clap_derive/tests/arg_enum.rs:388:56
note: run with `RUST_BACKTRACE=1` environment variable to display a backtrace
failures:
vector
test result: FAILED. 15 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
error: test failed, to rerun pass '--test arg_enum'
```
2021-10-30 14:55:50 +00:00
|
|
|
);
|
2020-01-07 10:17:23 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_standalone_short_ignores_afterwards_defined_custom_name() {
|
2021-07-13 17:50:55 +00:00
|
|
|
#[derive(Parser, Debug, PartialEq)]
|
2020-01-07 10:17:23 +00:00
|
|
|
struct Opt {
|
2022-09-03 00:57:37 +00:00
|
|
|
#[arg(short, id = "option")]
|
2020-01-07 10:17:23 +00:00
|
|
|
foo_option: bool,
|
|
|
|
}
|
|
|
|
|
test(derive): Provide better error info
`Parser::parse_from` will call `exit` on failure and we don't just lose
backtrace information but we don't even know which of the tests running
in parallel panicked. I ran into this when experimenting with
`clap_derive` and I couldn't tell what actually failed.
So let's switch to `Parse::try_parse_from`.
Errors went from:
```
test option_option ... ok
error: Found argument 'bar' which wasn't expected, or isn't valid in this context
USAGE:
clap_derive [OPTIONS]
For more information try --help
error: test failed, to rerun pass '--test arg_enum'
```
To:
```
test option_option ... ok
test variant_with_defined_casing ... ok
test skip_variant ... ok
test default_value ... ok
test vector ... FAILED
test option_vector ... ok
failures:
---- vector stdout ----
thread 'vector' panicked at 'called `Result::unwrap()` on an `Err` value: Error { message: Formatted(Colorizer { use_stderr: true, color_when: Auto
, pieces: [("error:", Some(Red)), (" ", None), ("Found argument '", None), ("bar", Some(Yellow)), ("' which wasn't expected, or isn't valid in this
context", None), ("\n\n", None), ("USAGE:\n clap_derive [OPTIONS]", None), ("\n\nFor more information try ", None), ("--help", Some(Green)), ("
\n", None)] }), kind: UnknownArgument, info: ["bar"], source: None, backtrace: Backtrace }', clap_derive/tests/arg_enum.rs:388:56
note: run with `RUST_BACKTRACE=1` environment variable to display a backtrace
failures:
vector
test result: FAILED. 15 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
error: test failed, to rerun pass '--test arg_enum'
```
2021-10-30 14:55:50 +00:00
|
|
|
assert_eq!(
|
|
|
|
Opt { foo_option: true },
|
2022-11-24 13:54:25 +00:00
|
|
|
Opt::try_parse_from(["test", "-f"]).unwrap()
|
test(derive): Provide better error info
`Parser::parse_from` will call `exit` on failure and we don't just lose
backtrace information but we don't even know which of the tests running
in parallel panicked. I ran into this when experimenting with
`clap_derive` and I couldn't tell what actually failed.
So let's switch to `Parse::try_parse_from`.
Errors went from:
```
test option_option ... ok
error: Found argument 'bar' which wasn't expected, or isn't valid in this context
USAGE:
clap_derive [OPTIONS]
For more information try --help
error: test failed, to rerun pass '--test arg_enum'
```
To:
```
test option_option ... ok
test variant_with_defined_casing ... ok
test skip_variant ... ok
test default_value ... ok
test vector ... FAILED
test option_vector ... ok
failures:
---- vector stdout ----
thread 'vector' panicked at 'called `Result::unwrap()` on an `Err` value: Error { message: Formatted(Colorizer { use_stderr: true, color_when: Auto
, pieces: [("error:", Some(Red)), (" ", None), ("Found argument '", None), ("bar", Some(Yellow)), ("' which wasn't expected, or isn't valid in this
context", None), ("\n\n", None), ("USAGE:\n clap_derive [OPTIONS]", None), ("\n\nFor more information try ", None), ("--help", Some(Green)), ("
\n", None)] }), kind: UnknownArgument, info: ["bar"], source: None, backtrace: Backtrace }', clap_derive/tests/arg_enum.rs:388:56
note: run with `RUST_BACKTRACE=1` environment variable to display a backtrace
failures:
vector
test result: FAILED. 15 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
error: test failed, to rerun pass '--test arg_enum'
```
2021-10-30 14:55:50 +00:00
|
|
|
);
|
2020-01-07 10:17:23 +00:00
|
|
|
}
|
|
|
|
|
2022-07-31 00:07:15 +00:00
|
|
|
#[test]
|
|
|
|
fn test_standalone_short_uses_previous_defined_custom_id() {
|
|
|
|
#[derive(Parser, Debug, PartialEq)]
|
|
|
|
struct Opt {
|
2022-09-02 20:37:23 +00:00
|
|
|
#[arg(id = "option", short)]
|
2022-07-31 00:07:15 +00:00
|
|
|
foo_option: bool,
|
|
|
|
}
|
|
|
|
|
|
|
|
assert_eq!(
|
|
|
|
Opt { foo_option: true },
|
2022-11-24 13:54:25 +00:00
|
|
|
Opt::try_parse_from(["test", "-o"]).unwrap()
|
2022-07-31 00:07:15 +00:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_standalone_short_ignores_afterwards_defined_custom_id() {
|
|
|
|
#[derive(Parser, Debug, PartialEq)]
|
|
|
|
struct Opt {
|
2022-09-02 20:37:23 +00:00
|
|
|
#[arg(short, id = "option")]
|
2022-07-31 00:07:15 +00:00
|
|
|
foo_option: bool,
|
|
|
|
}
|
|
|
|
|
|
|
|
assert_eq!(
|
|
|
|
Opt { foo_option: true },
|
2022-11-24 13:54:25 +00:00
|
|
|
Opt::try_parse_from(["test", "-f"]).unwrap()
|
2022-07-31 00:07:15 +00:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2020-01-07 10:17:23 +00:00
|
|
|
#[test]
|
|
|
|
fn test_standalone_long_uses_previous_defined_casing() {
|
2021-07-13 17:50:55 +00:00
|
|
|
#[derive(Parser, Debug, PartialEq)]
|
2020-01-07 10:17:23 +00:00
|
|
|
struct Opt {
|
2022-09-02 20:37:23 +00:00
|
|
|
#[arg(rename_all = "screaming_snake", long)]
|
2020-01-07 10:17:23 +00:00
|
|
|
foo_option: bool,
|
|
|
|
}
|
|
|
|
|
|
|
|
assert_eq!(
|
|
|
|
Opt { foo_option: true },
|
2022-11-24 13:54:25 +00:00
|
|
|
Opt::try_parse_from(["test", "--FOO_OPTION"]).unwrap()
|
2020-01-07 10:17:23 +00:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_standalone_short_uses_previous_defined_casing() {
|
2021-07-13 17:50:55 +00:00
|
|
|
#[derive(Parser, Debug, PartialEq)]
|
2020-01-07 10:17:23 +00:00
|
|
|
struct Opt {
|
2022-09-02 20:37:23 +00:00
|
|
|
#[arg(rename_all = "screaming_snake", short)]
|
2020-01-07 10:17:23 +00:00
|
|
|
foo_option: bool,
|
|
|
|
}
|
|
|
|
|
test(derive): Provide better error info
`Parser::parse_from` will call `exit` on failure and we don't just lose
backtrace information but we don't even know which of the tests running
in parallel panicked. I ran into this when experimenting with
`clap_derive` and I couldn't tell what actually failed.
So let's switch to `Parse::try_parse_from`.
Errors went from:
```
test option_option ... ok
error: Found argument 'bar' which wasn't expected, or isn't valid in this context
USAGE:
clap_derive [OPTIONS]
For more information try --help
error: test failed, to rerun pass '--test arg_enum'
```
To:
```
test option_option ... ok
test variant_with_defined_casing ... ok
test skip_variant ... ok
test default_value ... ok
test vector ... FAILED
test option_vector ... ok
failures:
---- vector stdout ----
thread 'vector' panicked at 'called `Result::unwrap()` on an `Err` value: Error { message: Formatted(Colorizer { use_stderr: true, color_when: Auto
, pieces: [("error:", Some(Red)), (" ", None), ("Found argument '", None), ("bar", Some(Yellow)), ("' which wasn't expected, or isn't valid in this
context", None), ("\n\n", None), ("USAGE:\n clap_derive [OPTIONS]", None), ("\n\nFor more information try ", None), ("--help", Some(Green)), ("
\n", None)] }), kind: UnknownArgument, info: ["bar"], source: None, backtrace: Backtrace }', clap_derive/tests/arg_enum.rs:388:56
note: run with `RUST_BACKTRACE=1` environment variable to display a backtrace
failures:
vector
test result: FAILED. 15 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
error: test failed, to rerun pass '--test arg_enum'
```
2021-10-30 14:55:50 +00:00
|
|
|
assert_eq!(
|
|
|
|
Opt { foo_option: true },
|
2022-11-24 13:54:25 +00:00
|
|
|
Opt::try_parse_from(["test", "-F"]).unwrap()
|
test(derive): Provide better error info
`Parser::parse_from` will call `exit` on failure and we don't just lose
backtrace information but we don't even know which of the tests running
in parallel panicked. I ran into this when experimenting with
`clap_derive` and I couldn't tell what actually failed.
So let's switch to `Parse::try_parse_from`.
Errors went from:
```
test option_option ... ok
error: Found argument 'bar' which wasn't expected, or isn't valid in this context
USAGE:
clap_derive [OPTIONS]
For more information try --help
error: test failed, to rerun pass '--test arg_enum'
```
To:
```
test option_option ... ok
test variant_with_defined_casing ... ok
test skip_variant ... ok
test default_value ... ok
test vector ... FAILED
test option_vector ... ok
failures:
---- vector stdout ----
thread 'vector' panicked at 'called `Result::unwrap()` on an `Err` value: Error { message: Formatted(Colorizer { use_stderr: true, color_when: Auto
, pieces: [("error:", Some(Red)), (" ", None), ("Found argument '", None), ("bar", Some(Yellow)), ("' which wasn't expected, or isn't valid in this
context", None), ("\n\n", None), ("USAGE:\n clap_derive [OPTIONS]", None), ("\n\nFor more information try ", None), ("--help", Some(Green)), ("
\n", None)] }), kind: UnknownArgument, info: ["bar"], source: None, backtrace: Backtrace }', clap_derive/tests/arg_enum.rs:388:56
note: run with `RUST_BACKTRACE=1` environment variable to display a backtrace
failures:
vector
test result: FAILED. 15 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
error: test failed, to rerun pass '--test arg_enum'
```
2021-10-30 14:55:50 +00:00
|
|
|
);
|
2020-01-07 10:17:23 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_standalone_long_works_with_verbatim_casing() {
|
2021-07-13 17:50:55 +00:00
|
|
|
#[derive(Parser, Debug, PartialEq)]
|
2020-01-07 10:17:23 +00:00
|
|
|
#[allow(non_snake_case)]
|
|
|
|
struct Opt {
|
2022-09-02 20:37:23 +00:00
|
|
|
#[arg(rename_all = "verbatim", long)]
|
2020-01-07 10:17:23 +00:00
|
|
|
_fOO_oPtiON: bool,
|
|
|
|
}
|
|
|
|
|
|
|
|
assert_eq!(
|
|
|
|
Opt { _fOO_oPtiON: true },
|
2022-11-24 13:54:25 +00:00
|
|
|
Opt::try_parse_from(["test", "--_fOO_oPtiON"]).unwrap()
|
2020-01-07 10:17:23 +00:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_standalone_short_works_with_verbatim_casing() {
|
2021-07-13 17:50:55 +00:00
|
|
|
#[derive(Parser, Debug, PartialEq)]
|
2020-01-07 10:17:23 +00:00
|
|
|
struct Opt {
|
2022-09-02 20:37:23 +00:00
|
|
|
#[arg(rename_all = "verbatim", short)]
|
2020-01-07 10:17:23 +00:00
|
|
|
_foo: bool,
|
|
|
|
}
|
|
|
|
|
test(derive): Provide better error info
`Parser::parse_from` will call `exit` on failure and we don't just lose
backtrace information but we don't even know which of the tests running
in parallel panicked. I ran into this when experimenting with
`clap_derive` and I couldn't tell what actually failed.
So let's switch to `Parse::try_parse_from`.
Errors went from:
```
test option_option ... ok
error: Found argument 'bar' which wasn't expected, or isn't valid in this context
USAGE:
clap_derive [OPTIONS]
For more information try --help
error: test failed, to rerun pass '--test arg_enum'
```
To:
```
test option_option ... ok
test variant_with_defined_casing ... ok
test skip_variant ... ok
test default_value ... ok
test vector ... FAILED
test option_vector ... ok
failures:
---- vector stdout ----
thread 'vector' panicked at 'called `Result::unwrap()` on an `Err` value: Error { message: Formatted(Colorizer { use_stderr: true, color_when: Auto
, pieces: [("error:", Some(Red)), (" ", None), ("Found argument '", None), ("bar", Some(Yellow)), ("' which wasn't expected, or isn't valid in this
context", None), ("\n\n", None), ("USAGE:\n clap_derive [OPTIONS]", None), ("\n\nFor more information try ", None), ("--help", Some(Green)), ("
\n", None)] }), kind: UnknownArgument, info: ["bar"], source: None, backtrace: Backtrace }', clap_derive/tests/arg_enum.rs:388:56
note: run with `RUST_BACKTRACE=1` environment variable to display a backtrace
failures:
vector
test result: FAILED. 15 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
error: test failed, to rerun pass '--test arg_enum'
```
2021-10-30 14:55:50 +00:00
|
|
|
assert_eq!(
|
|
|
|
Opt { _foo: true },
|
2022-11-24 13:54:25 +00:00
|
|
|
Opt::try_parse_from(["test", "-_"]).unwrap()
|
test(derive): Provide better error info
`Parser::parse_from` will call `exit` on failure and we don't just lose
backtrace information but we don't even know which of the tests running
in parallel panicked. I ran into this when experimenting with
`clap_derive` and I couldn't tell what actually failed.
So let's switch to `Parse::try_parse_from`.
Errors went from:
```
test option_option ... ok
error: Found argument 'bar' which wasn't expected, or isn't valid in this context
USAGE:
clap_derive [OPTIONS]
For more information try --help
error: test failed, to rerun pass '--test arg_enum'
```
To:
```
test option_option ... ok
test variant_with_defined_casing ... ok
test skip_variant ... ok
test default_value ... ok
test vector ... FAILED
test option_vector ... ok
failures:
---- vector stdout ----
thread 'vector' panicked at 'called `Result::unwrap()` on an `Err` value: Error { message: Formatted(Colorizer { use_stderr: true, color_when: Auto
, pieces: [("error:", Some(Red)), (" ", None), ("Found argument '", None), ("bar", Some(Yellow)), ("' which wasn't expected, or isn't valid in this
context", None), ("\n\n", None), ("USAGE:\n clap_derive [OPTIONS]", None), ("\n\nFor more information try ", None), ("--help", Some(Green)), ("
\n", None)] }), kind: UnknownArgument, info: ["bar"], source: None, backtrace: Backtrace }', clap_derive/tests/arg_enum.rs:388:56
note: run with `RUST_BACKTRACE=1` environment variable to display a backtrace
failures:
vector
test result: FAILED. 15 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
error: test failed, to rerun pass '--test arg_enum'
```
2021-10-30 14:55:50 +00:00
|
|
|
);
|
2020-01-07 10:17:23 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_rename_all_is_propagated_from_struct_to_fields() {
|
2021-07-13 17:50:55 +00:00
|
|
|
#[derive(Parser, Debug, PartialEq)]
|
2022-09-02 20:37:23 +00:00
|
|
|
#[command(rename_all = "screaming_snake")]
|
2020-01-07 10:17:23 +00:00
|
|
|
struct Opt {
|
2022-09-02 20:37:23 +00:00
|
|
|
#[arg(long)]
|
2020-01-07 10:17:23 +00:00
|
|
|
foo: bool,
|
|
|
|
}
|
|
|
|
|
test(derive): Provide better error info
`Parser::parse_from` will call `exit` on failure and we don't just lose
backtrace information but we don't even know which of the tests running
in parallel panicked. I ran into this when experimenting with
`clap_derive` and I couldn't tell what actually failed.
So let's switch to `Parse::try_parse_from`.
Errors went from:
```
test option_option ... ok
error: Found argument 'bar' which wasn't expected, or isn't valid in this context
USAGE:
clap_derive [OPTIONS]
For more information try --help
error: test failed, to rerun pass '--test arg_enum'
```
To:
```
test option_option ... ok
test variant_with_defined_casing ... ok
test skip_variant ... ok
test default_value ... ok
test vector ... FAILED
test option_vector ... ok
failures:
---- vector stdout ----
thread 'vector' panicked at 'called `Result::unwrap()` on an `Err` value: Error { message: Formatted(Colorizer { use_stderr: true, color_when: Auto
, pieces: [("error:", Some(Red)), (" ", None), ("Found argument '", None), ("bar", Some(Yellow)), ("' which wasn't expected, or isn't valid in this
context", None), ("\n\n", None), ("USAGE:\n clap_derive [OPTIONS]", None), ("\n\nFor more information try ", None), ("--help", Some(Green)), ("
\n", None)] }), kind: UnknownArgument, info: ["bar"], source: None, backtrace: Backtrace }', clap_derive/tests/arg_enum.rs:388:56
note: run with `RUST_BACKTRACE=1` environment variable to display a backtrace
failures:
vector
test result: FAILED. 15 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
error: test failed, to rerun pass '--test arg_enum'
```
2021-10-30 14:55:50 +00:00
|
|
|
assert_eq!(
|
|
|
|
Opt { foo: true },
|
2022-11-24 13:54:25 +00:00
|
|
|
Opt::try_parse_from(["test", "--FOO"]).unwrap()
|
test(derive): Provide better error info
`Parser::parse_from` will call `exit` on failure and we don't just lose
backtrace information but we don't even know which of the tests running
in parallel panicked. I ran into this when experimenting with
`clap_derive` and I couldn't tell what actually failed.
So let's switch to `Parse::try_parse_from`.
Errors went from:
```
test option_option ... ok
error: Found argument 'bar' which wasn't expected, or isn't valid in this context
USAGE:
clap_derive [OPTIONS]
For more information try --help
error: test failed, to rerun pass '--test arg_enum'
```
To:
```
test option_option ... ok
test variant_with_defined_casing ... ok
test skip_variant ... ok
test default_value ... ok
test vector ... FAILED
test option_vector ... ok
failures:
---- vector stdout ----
thread 'vector' panicked at 'called `Result::unwrap()` on an `Err` value: Error { message: Formatted(Colorizer { use_stderr: true, color_when: Auto
, pieces: [("error:", Some(Red)), (" ", None), ("Found argument '", None), ("bar", Some(Yellow)), ("' which wasn't expected, or isn't valid in this
context", None), ("\n\n", None), ("USAGE:\n clap_derive [OPTIONS]", None), ("\n\nFor more information try ", None), ("--help", Some(Green)), ("
\n", None)] }), kind: UnknownArgument, info: ["bar"], source: None, backtrace: Backtrace }', clap_derive/tests/arg_enum.rs:388:56
note: run with `RUST_BACKTRACE=1` environment variable to display a backtrace
failures:
vector
test result: FAILED. 15 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
error: test failed, to rerun pass '--test arg_enum'
```
2021-10-30 14:55:50 +00:00
|
|
|
);
|
2020-01-07 10:17:23 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_rename_all_is_not_propagated_from_struct_into_flattened() {
|
2021-07-13 17:50:55 +00:00
|
|
|
#[derive(Parser, Debug, PartialEq)]
|
2022-09-02 20:37:23 +00:00
|
|
|
#[command(rename_all = "screaming_snake")]
|
2020-01-07 10:17:23 +00:00
|
|
|
struct Opt {
|
2022-09-02 20:37:23 +00:00
|
|
|
#[command(flatten)]
|
2020-01-07 10:17:23 +00:00
|
|
|
foo: Foo,
|
|
|
|
}
|
|
|
|
|
2022-09-13 12:15:56 +00:00
|
|
|
#[derive(Args, Debug, PartialEq)]
|
2020-01-07 10:17:23 +00:00
|
|
|
struct Foo {
|
2022-09-02 20:37:23 +00:00
|
|
|
#[arg(long)]
|
2020-01-07 10:17:23 +00:00
|
|
|
foo: bool,
|
|
|
|
}
|
|
|
|
|
|
|
|
assert_eq!(
|
|
|
|
Opt {
|
|
|
|
foo: Foo { foo: true }
|
|
|
|
},
|
2022-11-24 13:54:25 +00:00
|
|
|
Opt::try_parse_from(["test", "--foo"]).unwrap()
|
2020-01-07 10:17:23 +00:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2022-05-06 21:43:23 +00:00
|
|
|
#[test]
|
|
|
|
fn test_lower_is_renamed() {
|
|
|
|
#[derive(Parser, Debug, PartialEq)]
|
|
|
|
struct Opt {
|
2022-09-02 20:37:23 +00:00
|
|
|
#[arg(rename_all = "lower", long)]
|
2022-05-06 21:43:23 +00:00
|
|
|
foo_option: bool,
|
|
|
|
}
|
|
|
|
|
|
|
|
assert_eq!(
|
|
|
|
Opt { foo_option: true },
|
2022-11-24 13:54:25 +00:00
|
|
|
Opt::try_parse_from(["test", "--foooption"]).unwrap()
|
2022-05-06 21:43:23 +00:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_upper_is_renamed() {
|
|
|
|
#[derive(Parser, Debug, PartialEq)]
|
|
|
|
struct Opt {
|
2022-09-02 20:37:23 +00:00
|
|
|
#[arg(rename_all = "upper", long)]
|
2022-05-06 21:43:23 +00:00
|
|
|
foo_option: bool,
|
|
|
|
}
|
|
|
|
|
|
|
|
assert_eq!(
|
|
|
|
Opt { foo_option: true },
|
2022-11-24 13:54:25 +00:00
|
|
|
Opt::try_parse_from(["test", "--FOOOPTION"]).unwrap()
|
2022-05-06 21:43:23 +00:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_single_word_enum_variant_is_default_renamed_into_kebab_case() {
|
|
|
|
#[derive(Parser, Debug, PartialEq)]
|
|
|
|
enum Opt {
|
2022-07-22 14:19:14 +00:00
|
|
|
Command { foo: u32 },
|
2022-05-06 21:43:23 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
assert_eq!(
|
|
|
|
Opt::Command { foo: 0 },
|
2022-11-24 13:54:25 +00:00
|
|
|
Opt::try_parse_from(["test", "command", "0"]).unwrap()
|
2022-05-06 21:43:23 +00:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_multi_word_enum_variant_is_renamed() {
|
|
|
|
#[derive(Parser, Debug, PartialEq)]
|
|
|
|
enum Opt {
|
2022-07-22 14:19:14 +00:00
|
|
|
FirstCommand { foo: u32 },
|
2022-05-06 21:43:23 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
assert_eq!(
|
|
|
|
Opt::FirstCommand { foo: 0 },
|
2022-11-24 13:54:25 +00:00
|
|
|
Opt::try_parse_from(["test", "first-command", "0"]).unwrap()
|
2022-05-06 21:43:23 +00:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2020-01-07 10:17:23 +00:00
|
|
|
#[test]
|
|
|
|
fn test_rename_all_is_not_propagated_from_struct_into_subcommand() {
|
2021-07-13 17:50:55 +00:00
|
|
|
#[derive(Parser, Debug, PartialEq)]
|
2022-09-02 20:37:23 +00:00
|
|
|
#[command(rename_all = "screaming_snake")]
|
2020-01-07 10:17:23 +00:00
|
|
|
struct Opt {
|
2022-09-02 20:37:23 +00:00
|
|
|
#[command(subcommand)]
|
2020-01-07 10:17:23 +00:00
|
|
|
foo: Foo,
|
|
|
|
}
|
|
|
|
|
2021-07-13 17:50:55 +00:00
|
|
|
#[derive(Parser, Debug, PartialEq)]
|
2020-01-07 10:17:23 +00:00
|
|
|
enum Foo {
|
|
|
|
Command {
|
2022-09-02 20:37:23 +00:00
|
|
|
#[arg(long)]
|
2020-01-07 10:17:23 +00:00
|
|
|
foo: bool,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
assert_eq!(
|
|
|
|
Opt {
|
|
|
|
foo: Foo::Command { foo: true }
|
|
|
|
},
|
2022-11-24 13:54:25 +00:00
|
|
|
Opt::try_parse_from(["test", "command", "--foo"]).unwrap()
|
2020-01-07 10:17:23 +00:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2022-05-06 21:47:52 +00:00
|
|
|
fn test_rename_all_is_propagated_from_enum_to_variants() {
|
2021-07-13 17:50:55 +00:00
|
|
|
#[derive(Parser, Debug, PartialEq)]
|
2022-09-02 20:37:23 +00:00
|
|
|
#[command(rename_all = "screaming_snake")]
|
2020-01-07 10:17:23 +00:00
|
|
|
enum Opt {
|
|
|
|
FirstVariant,
|
|
|
|
SecondVariant {
|
2022-09-02 20:37:23 +00:00
|
|
|
#[arg(long)]
|
2022-05-09 15:35:52 +00:00
|
|
|
foo: String,
|
2020-01-07 10:17:23 +00:00
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
assert_eq!(
|
|
|
|
Opt::FirstVariant,
|
2022-11-24 13:54:25 +00:00
|
|
|
Opt::try_parse_from(["test", "FIRST_VARIANT"]).unwrap()
|
2020-01-07 10:17:23 +00:00
|
|
|
);
|
2022-05-06 21:47:52 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_rename_all_is_propagated_from_enum_to_variant_fields() {
|
|
|
|
#[derive(Parser, Debug, PartialEq)]
|
2022-09-02 20:37:23 +00:00
|
|
|
#[command(rename_all = "screaming_snake")]
|
2022-05-06 21:47:52 +00:00
|
|
|
enum Opt {
|
|
|
|
FirstVariant,
|
|
|
|
SecondVariant {
|
2022-09-02 20:37:23 +00:00
|
|
|
#[arg(long)]
|
2022-05-09 15:35:52 +00:00
|
|
|
foo: String,
|
2022-05-06 21:47:52 +00:00
|
|
|
},
|
|
|
|
}
|
2020-01-07 10:17:23 +00:00
|
|
|
|
|
|
|
assert_eq!(
|
2022-05-09 15:35:52 +00:00
|
|
|
Opt::SecondVariant {
|
|
|
|
foo: "value".into()
|
|
|
|
},
|
2022-11-24 13:54:25 +00:00
|
|
|
Opt::try_parse_from(["test", "SECOND_VARIANT", "--FOO", "value"]).unwrap()
|
2020-01-07 10:17:23 +00:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_rename_all_is_propagation_can_be_overridden() {
|
2021-07-13 17:50:55 +00:00
|
|
|
#[derive(Parser, Debug, PartialEq)]
|
2022-09-02 20:37:23 +00:00
|
|
|
#[command(rename_all = "screaming_snake")]
|
2020-01-07 10:17:23 +00:00
|
|
|
enum Opt {
|
2022-09-02 20:37:23 +00:00
|
|
|
#[command(rename_all = "kebab_case")]
|
2020-01-07 10:17:23 +00:00
|
|
|
FirstVariant {
|
2022-09-02 20:37:23 +00:00
|
|
|
#[arg(long)]
|
2020-01-07 10:17:23 +00:00
|
|
|
foo_option: bool,
|
|
|
|
},
|
|
|
|
SecondVariant {
|
2022-09-02 20:37:23 +00:00
|
|
|
#[arg(rename_all = "kebab_case", long)]
|
2020-01-07 10:17:23 +00:00
|
|
|
foo_option: bool,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
assert_eq!(
|
|
|
|
Opt::FirstVariant { foo_option: true },
|
2022-11-24 13:54:25 +00:00
|
|
|
Opt::try_parse_from(["test", "first-variant", "--foo-option"]).unwrap()
|
2020-01-07 10:17:23 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
assert_eq!(
|
|
|
|
Opt::SecondVariant { foo_option: true },
|
2022-11-24 13:54:25 +00:00
|
|
|
Opt::try_parse_from(["test", "SECOND_VARIANT", "--foo-option"]).unwrap()
|
2020-01-07 10:17:23 +00:00
|
|
|
);
|
|
|
|
}
|