mirror of
https://github.com/ipfs/kubo.git
synced 2025-10-24 15:12:55 +08:00
158 lines
3.2 KiB
Go
158 lines
3.2 KiB
Go
package commands
|
|
|
|
import "testing"
|
|
|
|
func noop(req Request, res Response) {
|
|
return
|
|
}
|
|
|
|
func TestOptionValidation(t *testing.T) {
|
|
cmd := Command{
|
|
Options: []Option{
|
|
IntOption("b", "beep", "enables beeper"),
|
|
StringOption("B", "boop", "password for booper"),
|
|
},
|
|
Run: noop,
|
|
}
|
|
|
|
opts, _ := cmd.GetOptions(nil)
|
|
|
|
req, _ := NewRequest(nil, 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, 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, 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, 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, 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, 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, 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, &cmd, opts)
|
|
req.SetOption("b", ":)")
|
|
res = cmd.Call(req)
|
|
if res.Error() == nil {
|
|
t.Error("Should have failed (string value not convertible to int)")
|
|
}
|
|
|
|
err := req.SetOptions(map[string]interface{}{
|
|
"b": 100,
|
|
})
|
|
if err != nil {
|
|
t.Error("Should have passed")
|
|
}
|
|
|
|
err = req.SetOptions(map[string]interface{}{
|
|
"b": ":)",
|
|
})
|
|
if err == nil {
|
|
t.Error("Should have failed (string value not convertible to int)")
|
|
}
|
|
}
|
|
|
|
func TestRegistration(t *testing.T) {
|
|
cmdA := &Command{
|
|
Options: []Option{
|
|
IntOption("beep", "number of beeps"),
|
|
},
|
|
Run: noop,
|
|
}
|
|
|
|
cmdB := &Command{
|
|
Options: []Option{
|
|
IntOption("beep", "number of beeps"),
|
|
},
|
|
Run: noop,
|
|
Subcommands: map[string]*Command{
|
|
"a": cmdA,
|
|
},
|
|
}
|
|
|
|
cmdC := &Command{
|
|
Options: []Option{
|
|
StringOption("encoding", "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)
|
|
}
|
|
}
|