2023-08-31 22:08:27 +00:00
|
|
|
use nu_test_support::nu;
|
2023-06-16 16:40:03 +00:00
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_ansi_shows_error_on_escape() {
|
2023-10-19 20:04:33 +00:00
|
|
|
let actual = nu!(r"ansi --escape \");
|
2023-06-16 16:40:03 +00:00
|
|
|
|
|
|
|
assert!(actual.err.contains("no need for escape characters"))
|
|
|
|
}
|
2023-07-26 21:39:24 +00:00
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_ansi_list_outputs_table() {
|
2023-08-31 22:08:27 +00:00
|
|
|
let actual = nu!("ansi --list | length");
|
2023-07-26 21:39:24 +00:00
|
|
|
|
2024-10-29 12:01:32 +00:00
|
|
|
assert_eq!(actual.out, "425");
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_ansi_codes() {
|
|
|
|
let actual = nu!("$'(ansi clear_scrollback_buffer)'");
|
|
|
|
assert_eq!(actual.out, "\x1b[3J");
|
|
|
|
|
|
|
|
// Currently, bg is placed before fg in the results
|
|
|
|
// It's okay if something internally changes this, but
|
|
|
|
// if so, the test case will need to be updated to:
|
|
|
|
// assert_eq!(actual.out, "\x1b[31;48;2;0;255;0mHello\x1b[0m");
|
|
|
|
|
|
|
|
let actual = nu!("$'(ansi { fg: red, bg: \"#00ff00\" })Hello(ansi reset)'");
|
|
|
|
assert_eq!(actual.out, "\x1b[48;2;0;255;0;31mHello\x1b[0m");
|
2023-07-26 21:39:24 +00:00
|
|
|
}
|