Add ability to create character sequences as Input
This commit is contained in:
@@ -1,7 +1,7 @@
|
||||
import gleam/list
|
||||
import gleeunit
|
||||
|
||||
import input/key.{type Key, Char, csi, esc}
|
||||
import input/key.{type Key, Char, csi, esc, input_introducer as ii}
|
||||
|
||||
pub fn main() -> Nil {
|
||||
gleeunit.main()
|
||||
@@ -12,18 +12,31 @@ type TestCase {
|
||||
}
|
||||
|
||||
pub fn key_from_list_test() {
|
||||
let test_cases = [
|
||||
TestCase(["c"], Char("c")),
|
||||
let base_tests = [TestCase([], key.Continue([]))]
|
||||
|
||||
let char_tests = [TestCase(["c"], Char("c"))]
|
||||
|
||||
let escape_tests = [
|
||||
TestCase([esc, csi], key.Continue([esc, csi])),
|
||||
TestCase([esc], key.Continue([esc])),
|
||||
|
||||
TestCase([esc, csi, "D"], key.Left),
|
||||
TestCase([esc, csi, "C"], key.Right),
|
||||
TestCase([esc, csi, "A"], key.Up),
|
||||
TestCase([esc, csi, "B"], key.Down),
|
||||
TestCase([esc, csi], key.Continue),
|
||||
TestCase([esc], key.Continue),
|
||||
TestCase([], key.Continue),
|
||||
]
|
||||
|
||||
list.each(test_cases, fn(tc) {
|
||||
let input_tests = [
|
||||
TestCase([ii], key.Continue([ii])),
|
||||
TestCase([ii, "a"], key.Continue([ii, "a"])),
|
||||
TestCase([ii, "a", "b"], key.Continue([ii, "ab"])),
|
||||
TestCase([ii, "ab", "\u{007F}"], key.Continue([ii, "a"])),
|
||||
TestCase([ii, "ab", "\r"], key.Input("ab")),
|
||||
]
|
||||
|
||||
let test_cases = [base_tests, char_tests, escape_tests, input_tests]
|
||||
|
||||
list.each(list.flatten(test_cases), fn(tc) {
|
||||
assert tc.expected == key.from_list(tc.input)
|
||||
})
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user