mirror of
https://github.com/ipfs/kubo.git
synced 2025-08-06 19:44:01 +08:00
144 lines
3.0 KiB
Go
144 lines
3.0 KiB
Go
package commands
|
|
|
|
import "testing"
|
|
|
|
func noop(req Request) (interface{}, error) {
|
|
return nil, nil
|
|
}
|
|
|
|
func TestOptionValidation(t *testing.T) {
|
|
cmd := Command{
|
|
Options: []Option{
|
|
Option{[]string{"b", "beep"}, Int, "enables beeper"},
|
|
Option{[]string{"B", "boop"}, String, "password for booper"},
|
|
},
|
|
Run: noop,
|
|
}
|
|
|
|
opts, _ := cmd.GetOptions(nil)
|
|
|
|
req, _ := NewRequest(nil, nil, nil, nil, opts)
|
|
req.SetOption("beep", true)
|
|
res := cmd.Call(req)
|
|
if res.Error() == nil {
|
|
t.Error("Should have failed (incorrect type)")
|
|
}
|
|
|
|
req, _ = NewRequest(nil, nil, nil, nil, opts)
|
|
req.SetOption("beep", 5)
|
|
res = cmd.Call(req)
|
|
if res.Error() != nil {
|
|
t.Error(res.Error(), "Should have passed")
|
|
}
|
|
|
|
req, _ = NewRequest(nil, nil, nil, nil, opts)
|
|
req.SetOption("beep", 5)
|
|
req.SetOption("boop", "test")
|
|
res = cmd.Call(req)
|
|
if res.Error() != nil {
|
|
t.Error("Should have passed")
|
|
}
|
|
|
|
req, _ = NewRequest(nil, nil, nil, nil, opts)
|
|
req.SetOption("b", 5)
|
|
req.SetOption("B", "test")
|
|
res = cmd.Call(req)
|
|
if res.Error() != nil {
|
|
t.Error("Should have passed")
|
|
}
|
|
|
|
req, _ = NewRequest(nil, nil, nil, nil, opts)
|
|
req.SetOption("foo", 5)
|
|
res = cmd.Call(req)
|
|
if res.Error() != nil {
|
|
t.Error("Should have passed")
|
|
}
|
|
|
|
req, _ = NewRequest(nil, nil, nil, nil, opts)
|
|
req.SetOption(EncShort, "json")
|
|
res = cmd.Call(req)
|
|
if res.Error() != nil {
|
|
t.Error("Should have passed")
|
|
}
|
|
|
|
req, _ = NewRequest(nil, nil, nil, nil, opts)
|
|
req.SetOption("b", "100")
|
|
res = cmd.Call(req)
|
|
if res.Error() != nil {
|
|
t.Error("Should have passed")
|
|
}
|
|
|
|
req, _ = NewRequest(nil, nil, nil, nil, opts)
|
|
req.SetOption("b", ":)")
|
|
res = cmd.Call(req)
|
|
if res.Error() == nil {
|
|
t.Error("Should have failed (string value not convertible to int)")
|
|
}
|
|
}
|
|
|
|
func TestRegistration(t *testing.T) {
|
|
cmdA := &Command{
|
|
Options: []Option{
|
|
Option{[]string{"beep"}, Int, "number of beeps"},
|
|
},
|
|
Run: noop,
|
|
}
|
|
|
|
cmdB := &Command{
|
|
Options: []Option{
|
|
Option{[]string{"beep"}, Int, "number of beeps"},
|
|
},
|
|
Run: noop,
|
|
Subcommands: map[string]*Command{
|
|
"a": cmdA,
|
|
},
|
|
}
|
|
|
|
cmdC := &Command{
|
|
Options: []Option{
|
|
Option{[]string{"encoding"}, String, "data encoding type"},
|
|
},
|
|
Run: noop,
|
|
}
|
|
|
|
path := []string{"a"}
|
|
_, err := cmdB.GetOptions(path)
|
|
if err == nil {
|
|
t.Error("Should have failed (option name collision)")
|
|
}
|
|
|
|
_, err = cmdC.GetOptions(nil)
|
|
if err == nil {
|
|
t.Error("Should have failed (option name collision with global options)")
|
|
}
|
|
}
|
|
|
|
func TestResolving(t *testing.T) {
|
|
cmdC := &Command{}
|
|
cmdB := &Command{
|
|
Subcommands: map[string]*Command{
|
|
"c": cmdC,
|
|
},
|
|
}
|
|
cmdB2 := &Command{}
|
|
cmdA := &Command{
|
|
Subcommands: map[string]*Command{
|
|
"b": cmdB,
|
|
"B": cmdB2,
|
|
},
|
|
}
|
|
cmd := &Command{
|
|
Subcommands: map[string]*Command{
|
|
"a": cmdA,
|
|
},
|
|
}
|
|
|
|
cmds, err := cmd.Resolve([]string{"a", "b", "c"})
|
|
if err != nil {
|
|
t.Error(err)
|
|
}
|
|
if len(cmds) != 4 || cmds[0] != cmd || cmds[1] != cmdA || cmds[2] != cmdB || cmds[3] != cmdC {
|
|
t.Error("Returned command path is different than expected", cmds)
|
|
}
|
|
}
|