bottom/tests/arg_tests.rs

179 lines
4.1 KiB
Rust
Raw Normal View History

//! These tests are mostly here just to ensure that invalid results will be caught when passing arguments.
2019-09-17 02:39:57 +00:00
use assert_cmd::prelude::*;
2019-09-15 02:29:40 +00:00
use predicates::prelude::*;
mod util;
use util::*;
2019-09-15 02:29:40 +00:00
#[test]
fn test_small_rate() {
btm_command()
.arg("-C")
.arg("./tests/empty_config.toml")
2020-02-29 22:07:47 +00:00
.arg("-r")
.arg("249")
.assert()
.failure()
.stderr(predicate::str::contains(
"set your update rate to be at least 250 milliseconds.",
));
2019-09-15 02:29:40 +00:00
}
#[test]
fn test_large_default_time() {
btm_command()
.arg("-C")
.arg("./tests/empty_config.toml")
.arg("-t")
.arg("18446744073709551616")
.assert()
.failure()
.stderr(predicate::str::contains("could not parse"));
}
#[test]
fn test_small_default_time() {
btm_command()
.arg("-C")
.arg("./tests/empty_config.toml")
.arg("-t")
.arg("900")
.assert()
.failure()
.stderr(predicate::str::contains(
"set your default value to be at least",
));
}
#[test]
fn test_large_delta_time() {
btm_command()
.arg("-C")
.arg("./tests/empty_config.toml")
.arg("-d")
.arg("18446744073709551616")
.assert()
.failure()
.stderr(predicate::str::contains("could not parse"));
}
#[test]
fn test_small_delta_time() {
btm_command()
.arg("-C")
.arg("./tests/empty_config.toml")
.arg("-d")
.arg("900")
.assert()
.failure()
.stderr(predicate::str::contains(
"set your time delta to be at least",
));
}
#[test]
fn test_large_rate() {
btm_command()
.arg("-C")
.arg("./tests/empty_config.toml")
2020-02-29 22:07:47 +00:00
.arg("-r")
.arg("18446744073709551616")
.assert()
.failure()
.stderr(predicate::str::contains("could not parse"));
}
2019-09-15 02:29:40 +00:00
#[test]
fn test_negative_rate() {
2020-02-29 22:07:47 +00:00
// This test should auto fail due to how clap works
btm_command()
.arg("-C")
.arg("./tests/empty_config.toml")
2020-02-29 22:07:47 +00:00
.arg("-r")
.arg("-1000")
.assert()
.failure()
.stderr(predicate::str::contains(
"wasn't expected, or isn't valid in this context",
));
2019-09-15 02:29:40 +00:00
}
#[test]
fn test_invalid_rate() {
btm_command()
.arg("-C")
.arg("./tests/empty_config.toml")
2020-02-29 22:07:47 +00:00
.arg("-r")
.arg("100-1000")
.assert()
.failure()
.stderr(predicate::str::contains("could not parse"));
2019-09-15 02:29:40 +00:00
}
2020-03-03 06:02:54 +00:00
#[test]
fn test_conflicting_temps() {
btm_command()
.arg("-C")
.arg("./tests/empty_config.toml")
2020-03-03 06:02:54 +00:00
.arg("-c")
.arg("-f")
.assert()
.failure()
.stderr(predicate::str::contains("cannot be used with"));
2020-03-03 06:02:54 +00:00
}
#[test]
fn test_invalid_default_widget_1() {
btm_command()
.arg("-C")
.arg("./tests/empty_config.toml")
.arg("--default_widget_type")
.arg("fake_widget")
.assert()
.failure()
.stderr(predicate::str::contains("invalid widget name"));
}
#[test]
fn test_invalid_default_widget_2() {
btm_command()
.arg("-C")
.arg("./tests/empty_config.toml")
.arg("--default_widget_type")
.arg("cpu")
.arg("--default_widget_count")
.arg("18446744073709551616")
2020-03-03 06:02:54 +00:00
.assert()
.failure()
.stderr(predicate::str::contains(
"set your widget count to be at most unsigned INT_MAX",
2020-03-03 06:02:54 +00:00
));
}
#[test]
fn test_missing_default_widget_type() {
btm_command()
.arg("-C")
.arg("./tests/empty_config.toml")
.arg("--default_widget_count")
.arg("3")
.assert()
.failure()
.stderr(predicate::str::contains(
"The following required arguments were not provided",
));
}
#[test]
fn test_battery_flag() {
if !cfg!(feature = "battery") {
btm_command()
.arg("--battery")
.assert()
.failure()
.stderr(predicate::str::contains(
"'--battery' which wasn't expected",
));
}
}