use super::*;
use std::env;
#[test]
fn exists_false() {
let output = exists("TEST_EXISTS_FALSE");
assert!(!output);
}
#[test]
fn exists_true() {
env::set_var("TEST_EXISTS_TRUE", "EXISTS");
let output = exists("TEST_EXISTS_TRUE");
assert!(output);
}
#[test]
fn remove_exists() {
env::set_var("TEST_REMOVE_EXISTS", "EXISTS");
remove("TEST_REMOVE_EXISTS");
let output = exists("TEST_REMOVE_EXISTS");
assert!(!output);
}
#[test]
fn remove_not_exists() {
remove("TEST_REMOVE_NOT_EXISTS");
}
#[test]
fn get_remove_not_exists() {
let output = get_remove("TEST_GET_REMOVE_NOT_EXISTS");
assert!(output.is_none());
}
#[test]
fn get_remove_exists() {
env::set_var("TEST_GET_REMOVE_EXISTS", "OLD");
let output = get_remove("TEST_GET_REMOVE_EXISTS");
assert_eq!(output.unwrap(), "OLD");
}
#[test]
fn get_or_exists() {
env::set_var("TEST_GET_OR_EXISTS", "EXISTS");
let output = get_or("TEST_GET_OR_EXISTS", "bad");
assert_eq!(output, "EXISTS");
}
#[test]
fn get_or_not_exists() {
let output = get_or("TEST_GET_OR_NOT_EXISTS", "good");
assert_eq!(output, "good");
}
#[test]
fn get_or_empty() {
env::set_var("TEST_GET_OR_EMPTY", "");
let output = get_or("TEST_GET_OR_EMPTY", "bad");
assert_eq!(output, "");
}
#[test]
fn get_or_panic_exists() {
env::set_var("TEST_GET_OR_PANIC_EXISTS", "EXISTS");
let output = get_or_panic("TEST_GET_OR_PANIC_EXISTS");
assert_eq!(output, "EXISTS");
}
#[test]
#[should_panic]
fn get_or_panic_not_exists() {
get_or_panic("TEST_GET_OR_PANIC_NOT_EXISTS");
}
#[test]
fn get_or_panic_empty() {
env::set_var("TEST_GET_OR_PANIC_EMPTY", "");
let output = get_or_panic("TEST_GET_OR_PANIC_EMPTY");
assert_eq!(output, "");
}
#[test]
fn get_any_exists() {
env::set_var("TEST_GET_ANY_EXISTS2", "EXISTS2");
let output = get_any(
&vec!["TEST_GET_ANY_EXISTS1", "TEST_GET_ANY_EXISTS2"],
"not found",
);
assert_eq!(output, "EXISTS2");
}
#[test]
fn get_any_not_exists() {
let output = get_any(
&vec!["TEST_GET_ANY_NOT_EXISTS1", "TEST_GET_ANY_NOT_EXISTS2"],
"not found",
);
assert_eq!(output, "not found");
}
#[test]
fn is_or_false() {
env::set_var("TEST_IS_OR_BOOL_FALSE", "false");
let output = is_or("TEST_IS_OR_BOOL_FALSE", true);
assert!(!output);
}
#[test]
fn is_or_false_uppercase() {
env::set_var("TEST_IS_OR_BOOL_FALSE_UPPER", "FALSE");
let output = is_or("TEST_IS_OR_BOOL_FALSE_UPPER", true);
assert!(!output);
}
#[test]
fn is_or_no() {
env::set_var("TEST_IS_OR_BOOL_NO", "no");
let output = is_or("TEST_IS_OR_BOOL_NO", true);
assert!(!output);
}
#[test]
fn is_or_no_uppercase() {
env::set_var("TEST_IS_OR_BOOL_NO_UPPER", "NO");
let output = is_or("TEST_IS_OR_BOOL_NO_UPPER", true);
assert!(!output);
}
#[test]
fn is_or_zero() {
env::set_var("TEST_IS_OR_BOOL_ZERO", "0");
let output = is_or("TEST_IS_OR_BOOL_ZERO", true);
assert!(!output);
}
#[test]
fn is_or_empty() {
env::set_var("TEST_IS_OR_BOOL_EMPTY", "");
let output = is_or("TEST_IS_OR_BOOL_EMPTY", false);
assert!(!output);
}
#[test]
fn is_or_true() {
env::set_var("TEST_IS_OR_BOOL_TRUE", "true");
let output = is_or("TEST_IS_OR_BOOL_TRUE", false);
assert!(output);
}
#[test]
fn is_or_default_true() {
let output = is_or("TEST_IS_OR_BOOL_NO_EXISTS_TRUE", true);
assert!(output);
}
#[test]
fn is_or_default_false() {
let output = is_or("TEST_IS_OR_BOOL_NO_EXISTS_FALSE", false);
assert!(!output);
}
#[test]
fn is_false() {
env::set_var("TEST_IS_BOOL_FALSE", "false");
let output = is("TEST_IS_BOOL_FALSE");
assert!(!output);
}
#[test]
fn is_empty() {
env::set_var("TEST_IS_BOOL_EMPTY", "");
let output = is("TEST_IS_BOOL_EMPTY");
assert!(!output);
}
#[test]
fn is_true() {
env::set_var("TEST_IS_BOOL_TRUE", "true");
let output = is("TEST_IS_BOOL_TRUE");
assert!(output);
}
#[test]
fn is_undefined() {
let output = is("TEST_IS_BOOL_UNDEFINED");
assert!(!output);
}
#[test]
fn set_value() {
set("TEST_SET_VALUE", "SIMPLE");
assert_eq!(env::var("TEST_SET_VALUE").unwrap(), "SIMPLE");
}
#[test]
fn set_value_multi_line() {
set(
"TEST_SET_VALUE_MULTI_LINE",
r#"
line 1
line 2
"#,
);
assert_eq!(
env::var("TEST_SET_VALUE_MULTI_LINE").unwrap(),
"\nline 1\nline 2\n"
);
assert_eq!(
env::var("TEST_SET_VALUE_MULTI_LINE").unwrap(),
r#"
line 1
line 2
"#
);
}
#[test]
fn set_bool_false() {
set_bool("TEST_SET_BOOL_FALSE", false);
assert_eq!(env::var("TEST_SET_BOOL_FALSE").unwrap(), "false");
}
#[test]
fn set_bool_true() {
set_bool("TEST_SET_BOOL_TRUE", true);
assert_eq!(env::var("TEST_SET_BOOL_TRUE").unwrap(), "true");
}
#[test]
fn set_optional_none() {
let output = set_optional::<&str, &str>("TEST_SET_OPTIONAL_NONE", &None);
assert!(!output);
}
#[test]
fn set_optional_some() {
let output = set_optional("TEST_SET_OPTIONAL_SOME", &Some("OPTIONAL VALUE"));
assert!(output);
assert_eq!(
env::var("TEST_SET_OPTIONAL_SOME").unwrap(),
"OPTIONAL VALUE"
);
}
#[test]
fn set_or_remove_none() {
let output = set_or_remove::<&str, &str>("TEST_SET_OR_REMOVE_NONE", &None);
assert!(!output);
}
#[test]
fn set_or_remove_some() {
let mut output = set_or_remove("TEST_SET_OR_REMOVE_SOME", &Some("OPTIONAL VALUE"));
assert!(output);
assert_eq!(
env::var("TEST_SET_OR_REMOVE_SOME").unwrap(),
"OPTIONAL VALUE"
);
output = set_or_remove::<&str, &str>("TEST_SET_OR_REMOVE_SOME", &None);
assert!(!output);
assert!(!exists("TEST_SET_OR_REMOVE_SOME"));
}
#[test]
fn get_set_exists() {
env::set_var("TEST_GET_SET_EXISTS", "OLD");
let output = get_set("TEST_GET_SET_EXISTS", "NEW");
assert_eq!(output.unwrap(), "OLD");
assert_eq!(env::var("TEST_GET_SET_EXISTS").unwrap(), "NEW");
}
#[test]
fn get_set_not_exists() {
let output = get_set("TEST_GET_SET_NOT_EXISTS", "NEW");
assert!(output.is_none());
assert_eq!(env::var("TEST_GET_SET_NOT_EXISTS").unwrap(), "NEW");
}
#[test]
fn vars_valid() {
let output = vars();
assert!(output.len() > 0);
for (key, value) in output {
if !key.starts_with("TEST") {
assert!(is_equal(&key, &value));
}
}
}
#[test]
fn is_equal_not_exists() {
let output = is_equal("TEST_IS_EQUAL_NOT_EXISTS", "VALUE");
assert!(!output);
}
#[test]
fn is_equal_same() {
env::set_var("TEST_IS_EQUAL_SAME", "VALUE");
let output = is_equal("TEST_IS_EQUAL_SAME", "VALUE");
assert!(output);
}
#[test]
fn is_equal_not_same() {
env::set_var("TEST_IS_EQUAL_NOT_SAME", "1");
let output = is_equal("TEST_IS_EQUAL_NOT_SAME", "2");
assert!(!output);
}
#[test]
fn contains_not_exists() {
let output = contains("TEST_CONTAINS_NOT_EXISTS", "VALUE");
assert!(!output);
}
#[test]
fn contains_same() {
env::set_var("TEST_CONTAINS_SAME", "VALUE");
let output = contains("TEST_CONTAINS_SAME", "VAL");
assert!(output);
}
#[test]
fn contains_not_same() {
env::set_var("TEST_CONTAINS_NOT_SAME", "VALUE");
let output = contains("TEST_CONTAINS_NOT_SAME", "val");
assert!(!output);
}
#[test]
fn contains_ignore_case_not_exists() {
let output = contains_ignore_case("TEST_CONTAINS_IGNORE_CASE_NOT_EXISTS", "VALUE");
assert!(!output);
}
#[test]
fn contains_ignore_case_same() {
env::set_var("TEST_CONTAINS_IGNORE_CASE_SAME", "VALUE");
let output = contains_ignore_case("TEST_CONTAINS_IGNORE_CASE_SAME", "VAL");
assert!(output);
}
#[test]
fn contains_ignore_case_same_value_different_case() {
env::set_var("TEST_CONTAINS_IGNORE_CASE_SAME_DIFFERENT_CASE", "VALUE");
let output = contains_ignore_case("TEST_CONTAINS_IGNORE_CASE_SAME_DIFFERENT_CASE", "val");
assert!(output);
}
#[test]
fn contains_ignore_case_not_same() {
env::set_var("TEST_CONTAINS_IGNORE_CASE_NOT_SAME", "1");
let output = contains_ignore_case("TEST_CONTAINS_IGNORE_CASE_NOT_SAME", "2");
assert!(!output);
}
#[test]
fn set_list_empty() {
set_list("TEST_SET_LIST_EMPTY", &vec![]);
let output = get_or_panic("TEST_SET_LIST_EMPTY");
assert_eq!(output, "");
}
#[test]
fn set_list_single_empty() {
set_list("TEST_SET_LIST_SINGLE_EMPTY", &vec!["".to_string()]);
let output = is_equal("TEST_SET_LIST_SINGLE_EMPTY", "");
assert!(output);
}
#[test]
fn set_list_single() {
set_list("TEST_SET_LIST_SINGLE", &vec!["1".to_string()]);
let output = is_equal("TEST_SET_LIST_SINGLE", "1");
assert!(output);
}
#[test]
fn set_list_multiple() {
set_list(
"TEST_SET_LIST_MULTIPLE",
&vec!["1".to_string(), "2".to_string(), "3".to_string()],
);
let output = is_equal("TEST_SET_LIST_MULTIPLE", "1;2;3");
assert!(output);
}
#[test]
fn get_list_none() {
let output = get_list("TEST_GET_LIST_NONE").is_none();
assert!(output);
}
#[test]
fn get_list_empty() {
set_list("TEST_GET_LIST_EMPTY", &vec![]);
let output = get_list("TEST_GET_LIST_EMPTY").unwrap();
assert!(output.is_empty());
}
#[test]
fn get_list_single() {
set_list("TEST_GET_LIST_SINGLE", &vec!["1".to_string()]);
let output = get_list("TEST_GET_LIST_SINGLE").unwrap();
assert_eq!(output.len(), 1);
assert_eq!(output, vec!["1"]);
}
#[test]
fn get_list_multiple() {
set_list(
"TEST_GET_LIST_MULTIPLE",
&vec!["1".to_string(), "2".to_string(), "3".to_string()],
);
let output = get_list("TEST_GET_LIST_MULTIPLE").unwrap();
assert_eq!(output.len(), 3);
assert_eq!(output, vec!["1", "2", "3"]);
}
#[test]
fn set_list_with_options_empty() {
let mut options = ListOptions::new();
options.separator = Some(",".to_string());
set_list_with_options("TEST_SET_LIST_WITH_OPTIONS_EMPTY", &vec![], &options);
let output = get_or_panic("TEST_SET_LIST_WITH_OPTIONS_EMPTY");
assert_eq!(output, "");
}
#[test]
fn set_list_with_options_single_empty() {
let options = ListOptions::new();
set_list_with_options(
"TEST_SET_LIST_WITH_OPTIONS_SINGLE_EMPTY",
&vec!["".to_string()],
&options,
);
let output = is_equal("TEST_SET_LIST_WITH_OPTIONS_SINGLE_EMPTY", "");
assert!(output);
}
#[test]
fn set_list_with_options_single() {
let mut options = ListOptions::new();
options.separator = Some(",".to_string());
set_list_with_options(
"TEST_SET_LIST_WITH_OPTIONS_SINGLE",
&vec!["1".to_string()],
&options,
);
let output = is_equal("TEST_SET_LIST_WITH_OPTIONS_SINGLE", "1");
assert!(output);
}
#[test]
fn set_list_with_options_multiple() {
let mut options = ListOptions::new();
options.separator = Some(",".to_string());
set_list_with_options(
"TEST_SET_LIST_WITH_OPTIONS_MULTIPLE",
&vec!["1".to_string(), "2".to_string(), "3".to_string()],
&options,
);
let output = is_equal("TEST_SET_LIST_WITH_OPTIONS_MULTIPLE", "1,2,3");
assert!(output);
}
#[test]
fn get_list_with_options_none() {
let mut options = ListOptions::new();
options.separator = Some(",".to_string());
let output = get_list_with_options("TEST_GET_LIST_WITH_OPTIONS_NONE", &options).is_none();
assert!(output);
}
#[test]
fn get_list_with_options_empty() {
let mut options = ListOptions::new();
options.separator = Some(",".to_string());
set_list_with_options("TEST_GET_LIST_WITH_OPTIONS_EMPTY", &vec![], &options);
let output = get_list_with_options("TEST_GET_LIST_WITH_OPTIONS_EMPTY", &options).unwrap();
assert!(output.is_empty());
}
#[test]
fn get_list_with_options_single_empty_ignore() {
let mut options = ListOptions::new();
options.ignore_empty = true;
set("TEST_GET_LIST_WITH_OPTIONS_SINGLE_EMPTY_IGNORE", "test");
let mut exists_value = exists("TEST_GET_LIST_WITH_OPTIONS_SINGLE_EMPTY_IGNORE");
assert!(exists_value);
set_list_with_options(
"TEST_GET_LIST_WITH_OPTIONS_SINGLE_EMPTY_IGNORE",
&vec![],
&options,
);
exists_value = exists("TEST_GET_LIST_WITH_OPTIONS_SINGLE_EMPTY_IGNORE");
assert!(!exists_value);
options.ignore_empty = false;
set_list_with_options(
"TEST_GET_LIST_WITH_OPTIONS_SINGLE_EMPTY_IGNORE",
&vec![],
&options,
);
options.ignore_empty = true;
let output =
get_list_with_options("TEST_GET_LIST_WITH_OPTIONS_SINGLE_EMPTY_IGNORE", &options).unwrap();
assert_eq!(output.len(), 1);
assert_eq!(output, vec![""]);
}
#[test]
fn get_list_with_options_single_empty_no_ignore() {
let mut options = ListOptions::new();
options.ignore_empty = false;
set_list_with_options(
"TEST_GET_LIST_WITH_OPTIONS_SINGLE_EMPTY_NO_IGNORE",
&vec![],
&options,
);
let output = get_list_with_options(
"TEST_GET_LIST_WITH_OPTIONS_SINGLE_EMPTY_NO_IGNORE",
&options,
)
.unwrap();
assert_eq!(output.len(), 0);
}
#[test]
fn get_list_with_options_single() {
let mut options = ListOptions::new();
options.separator = Some(",".to_string());
set_list_with_options(
"TEST_GET_LIST_WITH_OPTIONS_SINGLE",
&vec!["1".to_string()],
&options,
);
let output = get_list_with_options("TEST_GET_LIST_WITH_OPTIONS_SINGLE", &options).unwrap();
assert_eq!(output.len(), 1);
assert_eq!(output, vec!["1"]);
}
#[test]
fn get_list_with_options_multiple() {
let mut options = ListOptions::new();
options.separator = Some(",".to_string());
set_list_with_options(
"TEST_GET_LIST_WITH_OPTIONS_MULTIPLE",
&vec!["1".to_string(), "2".to_string(), "3".to_string()],
&options,
);
let output = get_list_with_options("TEST_GET_LIST_WITH_OPTIONS_MULTIPLE", &options).unwrap();
assert_eq!(output.len(), 3);
assert_eq!(output, vec!["1", "2", "3"]);
}
#[test]
fn expand_empty_string() {
let output = expand("", None);
assert_eq!(output.len(), 0);
}
#[test]
fn expand_unix_prefix_none() {
let mut options = ExpandOptions::new();
options.default_to_empty = false;
options.expansion_type = Some(ExpansionType::UnixPrefix);
let output = expand("some text here", Some(options));
assert_eq!("some text here", output);
}
#[test]
fn expand_unix_prefix_with_values() {
set("TEST_EXPAND_UNIX_PREFIX_WITH_VALUES1", "test1");
set("TEST_EXPAND_UNIX_PREFIX_WITH_VALUES2", "test2");
set("TEST_EXPAND_UNIX_PREFIX_WITH_VALUES3", "test3");
set("TEST_EXPAND_UNIX_PREFIX_WITH_VALUES4", "test4");
set("TEST_EXPAND_UNIX_PREFIX_WITH_VALUES5", "test5");
let mut options = ExpandOptions::new();
options.default_to_empty = false;
options.expansion_type = Some(ExpansionType::UnixPrefix);
let output = expand(
r#"
value1: $TEST_EXPAND_UNIX_PREFIX_WITH_VALUES1
value2: $TEST_EXPAND_UNIX_PREFIX_WITH_VALUES2
value3: ${TEST_EXPAND_UNIX_PREFIX_WITH_VALUES3}
value4: %TEST_EXPAND_UNIX_PREFIX_WITH_VALUES4%
value5: $TEST_EXPAND_UNIX_PREFIX_WITH_VALUES5"#,
Some(options),
);
assert_eq!(
r#"
value1: test1
value2: test2
value3: ${TEST_EXPAND_UNIX_PREFIX_WITH_VALUES3}
value4: %TEST_EXPAND_UNIX_PREFIX_WITH_VALUES4%
value5: test5"#,
output
);
}
#[test]
fn expand_unix_brackets_none() {
let mut options = ExpandOptions::new();
options.default_to_empty = false;
options.expansion_type = Some(ExpansionType::UnixBrackets);
let output = expand("some text here", Some(options));
assert_eq!("some text here", output);
}
#[test]
fn expand_unix_brackets_with_values() {
set("TEST_EXPAND_UNIX_BRACKETS_WITH_VALUES1", "test1");
set("TEST_EXPAND_UNIX_BRACKETS_WITH_VALUES2", "test2");
set("TEST_EXPAND_UNIX_BRACKETS_WITH_VALUES3", "test3");
set("TEST_EXPAND_UNIX_BRACKETS_WITH_VALUES4", "test4");
set("TEST_EXPAND_UNIX_BRACKETS_WITH_VALUES5", "test5");
let mut options = ExpandOptions::new();
options.default_to_empty = false;
options.expansion_type = Some(ExpansionType::UnixBrackets);
let output = expand(
r#"
value1: ${TEST_EXPAND_UNIX_BRACKETS_WITH_VALUES1}
value2: ${TEST_EXPAND_UNIX_BRACKETS_WITH_VALUES2}
value3: $TEST_EXPAND_UNIX_BRACKETS_WITH_VALUES3
value4: %TEST_EXPAND_UNIX_BRACKETS_WITH_VALUES4%
value5: ${TEST_EXPAND_UNIX_BRACKETS_WITH_VALUES5
"#,
Some(options),
);
assert_eq!(
r#"
value1: test1
value2: test2
value3: $TEST_EXPAND_UNIX_BRACKETS_WITH_VALUES3
value4: %TEST_EXPAND_UNIX_BRACKETS_WITH_VALUES4%
value5: ${TEST_EXPAND_UNIX_BRACKETS_WITH_VALUES5
"#,
output
);
}
#[test]
fn expand_unix_with_values() {
set("TEST_EXPAND_UNIX_WITH_VALUES1", "test1");
set("TEST_EXPAND_UNIX_WITH_VALUES2", "test2");
set("TEST_EXPAND_UNIX_WITH_VALUES3", "test3");
set("TEST_EXPAND_UNIX_WITH_VALUES4", "test4");
set("TEST_EXPAND_UNIX_WITH_VALUES5", "test5");
let mut options = ExpandOptions::new();
options.default_to_empty = false;
options.expansion_type = Some(ExpansionType::Unix);
let output = expand(
r#"
value1: $TEST_EXPAND_UNIX_WITH_VALUES1
value2: ${TEST_EXPAND_UNIX_WITH_VALUES2}
value3: ${TEST_EXPAND_UNIX_WITH_VALUES3}
value4: %TEST_EXPAND_UNIX_WITH_VALUES4%
value5: $TEST_EXPAND_UNIX_WITH_VALUES5"#,
Some(options),
);
assert_eq!(
r#"
value1: test1
value2: test2
value3: test3
value4: %TEST_EXPAND_UNIX_WITH_VALUES4%
value5: test5"#,
output
);
}
#[test]
fn expand_windows_none() {
let mut options = ExpandOptions::new();
options.default_to_empty = false;
options.expansion_type = Some(ExpansionType::Windows);
let output = expand("some text here", Some(options));
assert_eq!("some text here", output);
}
#[test]
fn expand_windows_with_values() {
set("TEST_EXPAND_WINDOWS_WITH_VALUES1", "test1");
set("TEST_EXPAND_WINDOWS_WITH_VALUES2", "test2");
set("TEST_EXPAND_WINDOWS_WITH_VALUES3", "test3");
set("TEST_EXPAND_WINDOWS_WITH_VALUES4", "test4");
set("TEST_EXPAND_WINDOWS_WITH_VALUES5", "test5");
let mut options = ExpandOptions::new();
options.default_to_empty = false;
options.expansion_type = Some(ExpansionType::Windows);
let output = expand(
r#"
value1: %TEST_EXPAND_WINDOWS_WITH_VALUES1%
value2: %TEST_EXPAND_WINDOWS_WITH_VALUES2%
value3: $TEST_EXPAND_WINDOWS_WITH_VALUES3
value4: ${TEST_EXPAND_WINDOWS_WITH_VALUES4}
value5: %TEST_EXPAND_WINDOWS_WITH_VALUES5
"#,
Some(options),
);
assert_eq!(
r#"
value1: test1
value2: test2
value3: $TEST_EXPAND_WINDOWS_WITH_VALUES3
value4: ${TEST_EXPAND_WINDOWS_WITH_VALUES4}
value5: %TEST_EXPAND_WINDOWS_WITH_VALUES5
"#,
output
);
}
#[test]
#[cfg(not(target_os = "windows"))]
fn expand_os_with_values() {
set("TEST_EXPAND_OS_WITH_VALUES1", "test1");
set("TEST_EXPAND_OS_WITH_VALUES2", "test2");
set("TEST_EXPAND_OS_WITH_VALUES3", "test3");
set("TEST_EXPAND_OS_WITH_VALUES4", "test4");
set("TEST_EXPAND_OS_WITH_VALUES5", "test5");
let mut options = ExpandOptions::new();
options.default_to_empty = false;
options.expansion_type = Some(ExpansionType::OS);
let output = expand(
r#"
value1: $TEST_EXPAND_OS_WITH_VALUES1
value2: ${TEST_EXPAND_OS_WITH_VALUES2}
value3: ${TEST_EXPAND_OS_WITH_VALUES3}
value4: %TEST_EXPAND_OS_WITH_VALUES4%
value5: $TEST_EXPAND_OS_WITH_VALUES5"#,
Some(options),
);
assert_eq!(
r#"
value1: test1
value2: test2
value3: test3
value4: %TEST_EXPAND_OS_WITH_VALUES4%
value5: test5"#,
output
);
}
#[test]
fn expand_all_with_values() {
set("TEST_EXPAND_ALL_WITH_VALUES1", "test1");
set("TEST_EXPAND_ALL_WITH_VALUES2", "test2");
set("TEST_EXPAND_ALL_WITH_VALUES3", "test3");
set("TEST_EXPAND_ALL_WITH_VALUES4", "test4");
set("TEST_EXPAND_ALL_WITH_VALUES5", "test5");
let mut options = ExpandOptions::new();
options.default_to_empty = false;
options.expansion_type = Some(ExpansionType::All);
let output = expand(
r#"
value1: $TEST_EXPAND_ALL_WITH_VALUES1
value2: ${TEST_EXPAND_ALL_WITH_VALUES2}
value3: ${TEST_EXPAND_ALL_WITH_VALUES3}
value4: %TEST_EXPAND_ALL_WITH_VALUES4%
value5: $TEST_EXPAND_ALL_WITH_VALUES5"#,
Some(options),
);
assert_eq!(
r#"
value1: test1
value2: test2
value3: test3
value4: test4
value5: test5"#,
output
);
}
#[test]
fn expand_with_values_and_embedded_defaults() {
set("TEST_EXPAND_WITH_VALUES_AND_EMBEDDED_DEFAULTS1", "test1");
set("TEST_EXPAND_WITH_VALUES_AND_EMBEDDED_DEFAULTS4", "test4");
set("TEST_EXPAND_WITH_VALUES_AND_EMBEDDED_DEFAULTS5", "test5");
let mut options = ExpandOptions::new();
options.default_to_empty = true;
options.expansion_type = Some(ExpansionType::UnixBracketsWithDefaults);
let output = expand(
r#"
value1: ${TEST_EXPAND_WITH_VALUES_AND_EMBEDDED_DEFAULTS1}
value2: ${TEST_EXPAND_WITH_VALUES_AND_EMBEDDED_DEFAULTS2:}none
value3: ${TEST_EXPAND_WITH_VALUES_AND_EMBEDDED_DEFAULTS3:default 3 value}
value4: ${TEST_EXPAND_WITH_VALUES_AND_EMBEDDED_DEFAULTS4}
value5: $TEST_EXPAND_WITH_VALUES_AND_EMBEDDED_DEFAULTS5"#,
Some(options),
);
assert_eq!(
r#"
value1: test1
value2: none
value3: default 3 value
value4: test4
value5: $TEST_EXPAND_WITH_VALUES_AND_EMBEDDED_DEFAULTS5"#,
output
);
}
#[test]
#[cfg(not(target_os = "windows"))]
fn expand_none_options() {
set("TEST_EXPAND_NONE_OPTIONS1", "test1");
set("TEST_EXPAND_NONE_OPTIONS2", "test2");
set("TEST_EXPAND_NONE_OPTIONS3", "test3");
set("TEST_EXPAND_NONE_OPTIONS4", "test4");
set("TEST_EXPAND_NONE_OPTIONS5", "test5");
let output = expand(
r#"
value1:$TEST_EXPAND_NONE_OPTIONS1
value2:${TEST_EXPAND_NONE_OPTIONS2}
value3:${TEST_EXPAND_NONE_OPTIONS3}
value4:%TEST_EXPAND_NONE_OPTIONS4%
value5:$TEST_EXPAND_NONE_OPTIONS5
value6:${TEST_EXPAND_NONE_OPTIONS6}"#,
None,
);
assert_eq!(
r#"
value1:test1
value2:test2
value3:test3
value4:%TEST_EXPAND_NONE_OPTIONS4%
value5:test5
value6:"#,
output
);
}
#[test]
#[cfg(not(target_os = "windows"))]
fn expand_none_expansion_type() {
set("TEST_EXPAND_NONE_EXPANSION_TYPE1", "test1");
set("TEST_EXPAND_NONE_EXPANSION_TYPE2", "test2");
set("TEST_EXPAND_NONE_EXPANSION_TYPE3", "test3");
set("TEST_EXPAND_NONE_EXPANSION_TYPE4", "test4");
set("TEST_EXPAND_NONE_EXPANSION_TYPE5", "test5");
let mut options = ExpandOptions::new();
options.default_to_empty = false;
let output = expand(
r#"
value1: $TEST_EXPAND_NONE_EXPANSION_TYPE1
value2: ${TEST_EXPAND_NONE_EXPANSION_TYPE2}
value3: ${TEST_EXPAND_NONE_EXPANSION_TYPE3}
value4: %TEST_EXPAND_NONE_EXPANSION_TYPE4%
value5: $TEST_EXPAND_NONE_EXPANSION_TYPE5"#,
Some(options),
);
assert_eq!(
r#"
value1: test1
value2: test2
value3: test3
value4: %TEST_EXPAND_NONE_EXPANSION_TYPE4%
value5: test5"#,
output
);
}