diff options
author | Jesse Luehrs <doy@tozt.net> | 2021-12-03 13:54:23 -0500 |
---|---|---|
committer | Jesse Luehrs <doy@tozt.net> | 2021-12-03 13:55:17 -0500 |
commit | 732589c4f0a5dbecc33f8ec4f7626a1cc93a03a8 (patch) | |
tree | 4e8a57f61d207665b923621a8a2fea7ade6e31b3 /tests/scroll.rs | |
parent | 222c3c4aa13508920a626dd427b1a2aca3c9f2a6 (diff) | |
download | vt100-rust-732589c4f0a5dbecc33f8ec4f7626a1cc93a03a8.tar.gz vt100-rust-732589c4f0a5dbecc33f8ec4f7626a1cc93a03a8.zip |
handle scrolling outside of a scroll region
it shouldn't scroll the scroll region if you wrap off the end of the
whole terminal outside of the scroll region. also, that kind of non-wrap
shouldn't set the wrap flag
Diffstat (limited to 'tests/scroll.rs')
-rw-r--r-- | tests/scroll.rs | 68 |
1 files changed, 4 insertions, 64 deletions
diff --git a/tests/scroll.rs b/tests/scroll.rs index 03f4fa7..94eb5bc 100644 --- a/tests/scroll.rs +++ b/tests/scroll.rs @@ -1,73 +1,13 @@ +mod helpers; + #[test] fn scroll_regions() { - let mut parser = vt100::Parser::default(); - parser.process(b"\x1b[m\x1b[2J\x1b[H1\r\n2\r\n3\r\n4\r\n5\r\n6\r\n7\r\n8\r\n9\r\n10\r\n11\r\n12\r\n13\r\n14\r\n15\r\n16\r\n17\r\n18\r\n19\r\n20\r\n21\r\n22\r\n23\r\n24"); - assert_eq!(parser.screen().contents(), "1\n2\n3\n4\n5\n6\n7\n8\n9\n10\n11\n12\n13\n14\n15\n16\n17\n18\n19\n20\n21\n22\n23\n24"); - - parser.process(b"\x1b[24;50H\n"); - assert_eq!(parser.screen().contents(), "2\n3\n4\n5\n6\n7\n8\n9\n10\n11\n12\n13\n14\n15\n16\n17\n18\n19\n20\n21\n22\n23\n24"); - - parser.process(b"\x1b[m\x1b[2J\x1b[H1\r\n2\r\n3\r\n4\r\n5\r\n6\r\n7\r\n8\r\n9\r\n10\r\n11\r\n12\r\n13\r\n14\r\n15\r\n16\r\n17\r\n18\r\n19\r\n20\r\n21\r\n22\r\n23\r\n24"); - - parser.process(b"\x1b[10;20r"); - assert_eq!(parser.screen().cursor_position(), (9, 0)); - - parser.process(b"\x1b[20;50H"); - assert_eq!(parser.screen().cursor_position(), (19, 49)); - - parser.process(b"\n"); - assert_eq!(parser.screen().contents(), "1\n2\n3\n4\n5\n6\n7\n8\n9\n11\n12\n13\n14\n15\n16\n17\n18\n19\n20\n\n21\n22\n23\n24"); - assert_eq!(parser.screen().cursor_position(), (19, 49)); - - parser.process(b"\x1b[B"); - assert_eq!(parser.screen().cursor_position(), (19, 49)); - - parser.process(b"\x1b[20A"); - assert_eq!(parser.screen().cursor_position(), (9, 49)); - parser.process(b"\x1b[1;24r\x1b[m\x1b[2J\x1b[H1\r\n2\r\n3\r\n4\r\n5\r\n6\r\n7\r\n8\r\n9\r\n10\r\n11\r\n12\r\n13\r\n14\r\n15\r\n16\r\n17\r\n18\r\n19\r\n20\r\n21\r\n22\r\n23\r\n24"); - parser.process(b"\x1b[10;20r\x1b[15;50H\x1b[2L"); - assert_eq!(parser.screen().contents(), "1\n2\n3\n4\n5\n6\n7\n8\n9\n10\n11\n12\n13\n14\n\n\n15\n16\n17\n18\n21\n22\n23\n24"); - parser.process(b"\x1b[10;50H\x1bM"); - assert_eq!(parser.screen().contents(), "1\n2\n3\n4\n5\n6\n7\n8\n9\n\n10\n11\n12\n13\n14\n\n\n15\n16\n17\n21\n22\n23\n24"); - - assert_eq!(parser.screen().cursor_position(), (9, 49)); - parser.process(b"\x1b[23d"); - assert_eq!(parser.screen().cursor_position(), (22, 49)); - parser.process(b"\n"); - assert_eq!(parser.screen().cursor_position(), (23, 49)); - assert_eq!(parser.screen().contents(), "1\n2\n3\n4\n5\n6\n7\n8\n9\n\n10\n11\n12\n13\n14\n\n\n15\n16\n17\n21\n22\n23\n24"); + helpers::fixture("decstbm"); } #[test] fn origin_mode() { - let mut parser = vt100::Parser::default(); - - parser.process(b"\x1b[5;15r"); - assert_eq!(parser.screen().cursor_position(), (4, 0)); - - parser.process(b"\x1b[10;50H"); - assert_eq!(parser.screen().cursor_position(), (9, 49)); - - parser.process(b"\x1b[?6h"); - assert_eq!(parser.screen().cursor_position(), (4, 0)); - - parser.process(b"\x1b[10;50H"); - assert_eq!(parser.screen().cursor_position(), (13, 49)); - - parser.process(b"\x1b[?6l"); - assert_eq!(parser.screen().cursor_position(), (0, 0)); - - parser.process(b"\x1b[10;50H"); - assert_eq!(parser.screen().cursor_position(), (9, 49)); - - parser.process(b"\x1b[?6h\x1b[?47h\x1b[6;16r\x1b[H"); - assert_eq!(parser.screen().cursor_position(), (0, 0)); - - parser.process(b"\x1b[?6h"); - assert_eq!(parser.screen().cursor_position(), (5, 0)); - - parser.process(b"\x1b[?47l\x1b[H"); - assert_eq!(parser.screen().cursor_position(), (4, 0)); + helpers::fixture("origin_mode"); } #[allow(clippy::cognitive_complexity)] |