aboutsummaryrefslogtreecommitdiffstats
path: root/tests/scroll.rs
diff options
context:
space:
mode:
authorJesse Luehrs <doy@tozt.net>2021-12-03 13:54:23 -0500
committerJesse Luehrs <doy@tozt.net>2021-12-03 13:55:17 -0500
commit732589c4f0a5dbecc33f8ec4f7626a1cc93a03a8 (patch)
tree4e8a57f61d207665b923621a8a2fea7ade6e31b3 /tests/scroll.rs
parent222c3c4aa13508920a626dd427b1a2aca3c9f2a6 (diff)
downloadvt100-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.rs68
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)]