mirror of
https://github.com/wavetermdev/waveterm.git
synced 2025-01-05 19:08:59 +01:00
49 lines
1.4 KiB
Go
49 lines
1.4 KiB
Go
package shparse
|
|
|
|
import (
|
|
"fmt"
|
|
"testing"
|
|
)
|
|
|
|
// $(ls f[*]); ./x
|
|
// ls f => raw["ls f"] -> lit["ls f"] -> lit["ls"] lit["f"]
|
|
// w; ls foo; => raw["w; ls foo;"]
|
|
// ls&"ls" => raw["ls&ls"] => lit["ls&"] dq["ls"] => lit["ls"] key["&"] dq["ls"]
|
|
// ls $x; echo `ls f => raw["ls $x; echo `ls f"]
|
|
// > echo $foo{x,y}
|
|
|
|
func testParse(t *testing.T, s string) {
|
|
words := Tokenize(s)
|
|
|
|
fmt.Printf("%s\n", s)
|
|
dumpWords(words, " ")
|
|
fmt.Printf("\n")
|
|
|
|
outStr := wordsToStr(words)
|
|
if outStr != s {
|
|
t.Errorf("tokenization output does not match input: %q => %q", s, outStr)
|
|
}
|
|
}
|
|
|
|
func Test1(t *testing.T) {
|
|
testParse(t, "ls")
|
|
testParse(t, "ls 'foo'")
|
|
testParse(t, `ls "hello" $'\''`)
|
|
testParse(t, `ls "foo`)
|
|
testParse(t, `echo $11 $xyz $ `)
|
|
testParse(t, `echo $(ls ${x:"hello"} foo`)
|
|
testParse(t, `ls ${x:"hello"} $[2+2] $((5 * 10)) $(ls; ls&)`)
|
|
testParse(t, `ls;ls&./foo > out 2> "out2"`)
|
|
testParse(t, `(( x = 5)); ls& cd ~/work/"hello again"`)
|
|
testParse(t, `echo "hello"abc$(ls)$x${y:foo}`)
|
|
testParse(t, `echo $(ls; ./x "foo")`)
|
|
testParse(t, `echo $(ls; (cd foo; ls); (cd bar; ls))xyz`)
|
|
testParse(t, `echo "$x ${y:-foo}"`)
|
|
testParse(t, `command="$(echo "$input" | sed -e "s/^[ \t]*\([^ \t]*\)[ \t]*.*$/\1/g")"`)
|
|
testParse(t, `echo $(ls $)`)
|
|
testParse(t, `echo ${x:-hello\}"}"} 2nd`)
|
|
testParse(t, `echo "$(ls "foo") more $x"`)
|
|
testParse(t, "echo `ls $x \"hello $x\" \\`ls\\`; ./foo`")
|
|
testParse(t, `echo $"hello $x $(ls)"`)
|
|
}
|