123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178 |
- package termutil
- import (
- "bytes"
- "io/ioutil"
- "os"
- "testing"
- "devt.de/krotik/common/termutil/getch"
- )
- func TestHistoryConsoleLineTerminal(t *testing.T) {
- var out bytes.Buffer
- DefaultHistoryBufferSize = 3
-
- getchStart = func() error { return nil }
- var getchbuffer []*getch.KeyEvent
- addTestKeyEvent := func(kc getch.KeyCode, r rune) {
- getchbuffer = append(getchbuffer, &getch.KeyEvent{
- Code: kc,
- Rune: r,
- })
- }
- getchGetch = func() (*getch.KeyEvent, error) {
- e := getchbuffer[0]
- getchbuffer = getchbuffer[1:]
- return e, nil
- }
- ct, err := NewConsoleLineTerminal(&out)
- if err != nil {
- t.Error(err)
- return
- }
-
- ct, err = AddHistoryMixin(ct, "testhistory", func(l string) bool {
- return l == "exit"
- })
- if err != nil {
- t.Error(err)
- return
- }
- defer os.Remove("testhistory")
- addTestKeyEvent(getch.KeyT, 't')
- addTestKeyEvent(getch.KeyE, 'e')
- addTestKeyEvent(getch.KeyS, 's')
- addTestKeyEvent(getch.KeyT, 't')
- addTestKeyEvent(getch.KeyEnter, 0x00)
- if line, err := ct.NextLine(); err != nil || line != "test" {
- t.Error("Unexpected result:", "#"+line+"#", err)
- return
- }
-
- addTestKeyEvent(getch.KeyArrowUp, 0x00)
- addTestKeyEvent(getch.KeyEnter, 0x00)
- if line, err := ct.NextLine(); err != nil || line != "test" {
- t.Error("Unexpected result:", "#"+line+"#", err)
- return
- }
- addTestKeyEvent(getch.Key1, '1')
- addTestKeyEvent(getch.KeyEnter, 0x00)
- ct.NextLine()
- addTestKeyEvent(getch.Key1, '2')
- addTestKeyEvent(getch.KeyEnter, 0x00)
- ct.NextLine()
-
- addTestKeyEvent(getch.KeyT, 'e')
- addTestKeyEvent(getch.KeyE, 'x')
- addTestKeyEvent(getch.KeyS, 'i')
- addTestKeyEvent(getch.KeyT, 't')
- addTestKeyEvent(getch.KeyEnter, 0x00)
- if line, err := ct.NextLine(); err != nil || line != "exit" {
- t.Error("Unexpected result:", "#"+line+"#", err)
- return
- }
- addTestKeyEvent(getch.Key1, '3')
- addTestKeyEvent(getch.KeyEnter, 0x00)
- ct.NextLine()
-
- if res, _ := ioutil.ReadFile("testhistory"); string(res) != `1
- 2
- 3` {
- t.Error("Unexpected history:", string(res))
- return
- }
- ct.StopTerm()
-
- ct, err = NewConsoleLineTerminal(&out)
- if err != nil {
- t.Error(err)
- return
- }
-
- ct, err = AddHistoryMixin(ct, "testhistory", func(l string) bool {
- return l == "exit"
- })
- if err != nil {
- t.Error(err)
- return
- }
-
- addTestKeyEvent(getch.KeyArrowUp, 0x00)
- addTestKeyEvent(getch.KeyArrowUp, 0x00)
- addTestKeyEvent(getch.KeyArrowUp, 0x00)
- addTestKeyEvent(getch.KeyArrowDown, 0x00)
- addTestKeyEvent(getch.KeyEnter, 0x00)
- if line, err := ct.NextLine(); err != nil || line != "2" {
- t.Error("Unexpected result:", "#"+line+"#", err)
- return
- }
- addTestKeyEvent(getch.KeyArrowUp, 0x00)
- addTestKeyEvent(getch.KeyArrowUp, 0x00)
- addTestKeyEvent(getch.KeyEnter, 0x00)
- if line, err := ct.NextLine(); err != nil || line != "3" {
- t.Error("Unexpected result:", "#"+line+"#", err)
- return
- }
- addTestKeyEvent(getch.KeyT, 't')
- addTestKeyEvent(getch.KeyE, 'e')
- addTestKeyEvent(getch.KeyArrowUp, 0x00)
- addTestKeyEvent(getch.KeyArrowUp, 0x00)
- addTestKeyEvent(getch.KeyArrowDown, 0x00)
- addTestKeyEvent(getch.KeyArrowDown, 0x00)
- addTestKeyEvent(getch.KeyEnter, 0x00)
- if line, err := ct.NextLine(); err != nil || line != "te" {
- t.Error("Unexpected result:", "#"+line+"#", err)
- return
- }
- ct.StopTerm()
- }
|