e135a72bda
Includes test cases.
72 lines
1.8 KiB
Go
72 lines
1.8 KiB
Go
package main
|
|
|
|
import (
|
|
"reflect"
|
|
"testing"
|
|
)
|
|
|
|
type testcase struct {
|
|
// i is the input
|
|
i []string
|
|
// o is the expected output
|
|
o []string
|
|
}
|
|
|
|
// TestPrefixOArgs checks that the "-o x,y,z" parsing works correctly.
|
|
func TestPrefixOArgs(t *testing.T) {
|
|
testcases := []testcase{
|
|
{
|
|
i: nil,
|
|
o: nil,
|
|
},
|
|
{
|
|
i: []string{"gocryptfs"},
|
|
o: []string{"gocryptfs"},
|
|
},
|
|
{
|
|
i: []string{"gocryptfs", "-v"},
|
|
o: []string{"gocryptfs", "-v"},
|
|
},
|
|
{
|
|
i: []string{"gocryptfs", "foo", "bar", "-v"},
|
|
o: []string{"gocryptfs", "foo", "bar", "-v"},
|
|
},
|
|
{
|
|
i: []string{"gocryptfs", "foo", "bar", "-o", "a"},
|
|
o: []string{"gocryptfs", "-a", "foo", "bar"},
|
|
},
|
|
{
|
|
i: []string{"gocryptfs", "foo", "bar", "-o", "a,b,xxxxx"},
|
|
o: []string{"gocryptfs", "-a", "-b", "-xxxxx", "foo", "bar"},
|
|
},
|
|
{
|
|
i: []string{"gocryptfs", "foo", "bar", "-d", "-o=a,b,xxxxx"},
|
|
o: []string{"gocryptfs", "-a", "-b", "-xxxxx", "foo", "bar", "-d"},
|
|
},
|
|
{
|
|
i: []string{"gocryptfs", "foo", "bar", "-oooo", "a,b,xxxxx"},
|
|
o: []string{"gocryptfs", "foo", "bar", "-oooo", "a,b,xxxxx"},
|
|
},
|
|
// https://github.com/mhogomchungu/sirikali/blob/a36d91d3e39f0c1eb9a79680ed6c28ddb6568fa8/src/siritask.cpp#L192
|
|
{
|
|
i: []string{"gocryptfs", "-o", "rw", "--config", "fff", "ccc", "mmm"},
|
|
o: []string{"gocryptfs", "-rw", "--config", "fff", "ccc", "mmm"},
|
|
},
|
|
// "--" should also block "-o" parsing.
|
|
{
|
|
i: []string{"gocryptfs", "foo", "bar", "--", "-o", "a"},
|
|
o: []string{"gocryptfs", "foo", "bar", "--", "-o", "a"},
|
|
},
|
|
{
|
|
i: []string{"gocryptfs", "--", "-o", "a"},
|
|
o: []string{"gocryptfs", "--", "-o", "a"},
|
|
},
|
|
}
|
|
for _, tc := range testcases {
|
|
o := prefixOArgs(tc.i)
|
|
if !reflect.DeepEqual(o, tc.o) {
|
|
t.Errorf("\n in=%q\nwant=%q\n got=%q", tc.i, tc.o, o)
|
|
}
|
|
}
|
|
}
|