mirror of https://github.com/lightninglabs/loop
loopd: add missing zero case to validateConfTarget
Update validate function to return default target for zero value confirmation targets, as indicated by the comment. This change introduces a behaviour change for direct rpc calls to loopd (ie, those not made by the loop cli tool). Previously, these calls would fail and indicate that the conf target must be > 2, now they will succeed with the default conf target. The loop cli tool is unaffected because we already set the default value. When clients upgrade from a previous version of loopd which did not have this check, preexisting loops will be unaffected, because loop ins had the default of 6 confirmations set, and loop outs with <2 conf target would not have been created.pull/179/head
parent
1f5aeff45f
commit
f726fc2bc8
@ -0,0 +1,72 @@
|
|||||||
|
package loopd
|
||||||
|
|
||||||
|
import "testing"
|
||||||
|
|
||||||
|
// TestValidateConfTarget tests all failure and success cases for our conf
|
||||||
|
// target validation function, including the case where we replace a zero
|
||||||
|
// target with the default provided.
|
||||||
|
func TestValidateConfTarget(t *testing.T) {
|
||||||
|
const (
|
||||||
|
// Various input confirmation values for tests.
|
||||||
|
zeroConf int32 = 0
|
||||||
|
oneConf int32 = 1
|
||||||
|
twoConf int32 = 2
|
||||||
|
fiveConf int32 = 5
|
||||||
|
|
||||||
|
// defaultConf is the default confirmation target we use for
|
||||||
|
// all tests.
|
||||||
|
defaultConf = 6
|
||||||
|
)
|
||||||
|
|
||||||
|
tests := []struct {
|
||||||
|
name string
|
||||||
|
confTarget int32
|
||||||
|
expectedTarget int32
|
||||||
|
expectErr bool
|
||||||
|
}{
|
||||||
|
{
|
||||||
|
name: "zero conf, get default",
|
||||||
|
confTarget: zeroConf,
|
||||||
|
expectedTarget: defaultConf,
|
||||||
|
expectErr: false,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "one conf, get error",
|
||||||
|
confTarget: oneConf,
|
||||||
|
expectErr: true,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "two conf, ok",
|
||||||
|
confTarget: twoConf,
|
||||||
|
expectedTarget: twoConf,
|
||||||
|
expectErr: false,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "five conf, ok",
|
||||||
|
confTarget: fiveConf,
|
||||||
|
expectedTarget: fiveConf,
|
||||||
|
expectErr: false,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, test := range tests {
|
||||||
|
test := test
|
||||||
|
|
||||||
|
t.Run(test.name, func(t *testing.T) {
|
||||||
|
target, err := validateConfTarget(
|
||||||
|
test.confTarget, defaultConf,
|
||||||
|
)
|
||||||
|
|
||||||
|
haveErr := err != nil
|
||||||
|
if haveErr != test.expectErr {
|
||||||
|
t.Fatalf("expected err: %v, got: %v",
|
||||||
|
test.expectErr, err)
|
||||||
|
}
|
||||||
|
|
||||||
|
if target != test.expectedTarget {
|
||||||
|
t.Fatalf("expected: %v, got: %v",
|
||||||
|
test.expectedTarget, target)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue