mirror of
https://git.sr.ht/~rjarry/aerc
synced 2025-07-13 04:30:22 +02:00

Make the completion filtering for paths use the standard FilterList function. This leads to fuzzy filtering if configured, as per other completions. Changelog-changed: Path completion now uses the normal filtering mechanism, respecting case sensitivity and the fuzzy completion option. Signed-off-by: Andrew Jeffery <dev@jeffas.net> Acked-by: Robin Jarry <robin@jarry.cc>
88 lines
1.6 KiB
Go
88 lines
1.6 KiB
Go
package commands
|
|
|
|
import (
|
|
"os"
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
func TestCompletePath(t *testing.T) {
|
|
os.Chdir("testdata")
|
|
defer os.Chdir("..")
|
|
|
|
vectors := []struct {
|
|
arg string
|
|
onlyDirs bool
|
|
fuzzyComplete bool
|
|
expected []string
|
|
}{
|
|
{
|
|
arg: "",
|
|
expected: []string{"Foobar", "baz/", "foo.ini", "foo/"},
|
|
},
|
|
{
|
|
arg: "",
|
|
onlyDirs: true,
|
|
expected: []string{"baz/", "foo/"},
|
|
},
|
|
{
|
|
arg: ".",
|
|
expected: []string{".hidden/", ".keep-me"},
|
|
},
|
|
{
|
|
arg: "fo",
|
|
expected: []string{"Foobar", "foo.ini", "foo/"},
|
|
},
|
|
{
|
|
arg: "Fo",
|
|
expected: []string{"Foobar"},
|
|
},
|
|
{
|
|
arg: "..",
|
|
expected: []string{"../"},
|
|
},
|
|
{
|
|
arg: "../..",
|
|
expected: []string{"../../"},
|
|
},
|
|
{
|
|
arg: "../testdata/",
|
|
expected: []string{
|
|
"../testdata/Foobar",
|
|
"../testdata/baz/",
|
|
"../testdata/foo.ini",
|
|
"../testdata/foo/",
|
|
},
|
|
},
|
|
{
|
|
arg: "../testdata/f",
|
|
onlyDirs: true,
|
|
expected: []string{"../testdata/foo/"},
|
|
},
|
|
{
|
|
arg: "oo",
|
|
expected: []string{},
|
|
},
|
|
{
|
|
arg: "oo",
|
|
fuzzyComplete: true,
|
|
expected: []string{"Foobar", "foo.ini", "foo/"},
|
|
},
|
|
{
|
|
arg: "../testdata/oo",
|
|
expected: []string{},
|
|
},
|
|
{
|
|
arg: "../testdata/oo",
|
|
fuzzyComplete: true,
|
|
expected: []string{"../testdata/Foobar", "../testdata/foo.ini", "../testdata/foo/"},
|
|
},
|
|
}
|
|
for _, vec := range vectors {
|
|
t.Run(vec.arg, func(t *testing.T) {
|
|
res := completePath(vec.arg, vec.onlyDirs, vec.fuzzyComplete)
|
|
assert.Equal(t, vec.expected, res)
|
|
})
|
|
}
|
|
}
|