2016-01-23 04:11:22 +01:00
|
|
|
// Copyright (c) 2016 The btcsuite developers
|
|
|
|
// Use of this source code is governed by an ISC
|
|
|
|
// license that can be found in the LICENSE file.
|
|
|
|
|
2016-05-12 11:06:07 +02:00
|
|
|
package connmgr
|
2016-01-23 04:11:22 +01:00
|
|
|
|
|
|
|
import (
|
|
|
|
"math"
|
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
)
|
|
|
|
|
|
|
|
// TestDynamicBanScoreDecay tests the exponential decay implemented in
|
2016-05-12 11:06:07 +02:00
|
|
|
// DynamicBanScore.
|
2016-01-23 04:11:22 +01:00
|
|
|
func TestDynamicBanScoreDecay(t *testing.T) {
|
2016-05-12 11:06:07 +02:00
|
|
|
var bs DynamicBanScore
|
2016-01-23 04:11:22 +01:00
|
|
|
base := time.Now()
|
|
|
|
|
|
|
|
r := bs.increase(100, 50, base)
|
|
|
|
if r != 150 {
|
|
|
|
t.Errorf("Unexpected result %d after ban score increase.", r)
|
|
|
|
}
|
|
|
|
|
|
|
|
r = bs.int(base.Add(time.Minute))
|
|
|
|
if r != 125 {
|
|
|
|
t.Errorf("Halflife check failed - %d instead of 125", r)
|
|
|
|
}
|
|
|
|
|
|
|
|
r = bs.int(base.Add(7 * time.Minute))
|
|
|
|
if r != 100 {
|
|
|
|
t.Errorf("Decay after 7m - %d instead of 100", r)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-05-12 11:06:07 +02:00
|
|
|
// TestDynamicBanScoreLifetime tests that DynamicBanScore properly yields zero
|
2016-01-23 04:11:22 +01:00
|
|
|
// once the maximum age is reached.
|
|
|
|
func TestDynamicBanScoreLifetime(t *testing.T) {
|
2016-05-12 11:06:07 +02:00
|
|
|
var bs DynamicBanScore
|
2016-01-23 04:11:22 +01:00
|
|
|
base := time.Now()
|
|
|
|
|
|
|
|
r := bs.increase(0, math.MaxUint32, base)
|
|
|
|
r = bs.int(base.Add(Lifetime * time.Second))
|
|
|
|
if r != 3 { // 3, not 4 due to precision loss and truncating 3.999...
|
|
|
|
t.Errorf("Pre max age check with MaxUint32 failed - %d", r)
|
|
|
|
}
|
|
|
|
r = bs.int(base.Add((Lifetime + 1) * time.Second))
|
|
|
|
if r != 0 {
|
|
|
|
t.Errorf("Zero after max age check failed - %d instead of 0", r)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-05-12 11:06:07 +02:00
|
|
|
// TestDynamicBanScore tests exported functions of DynamicBanScore. Exponential
|
2016-01-23 04:11:22 +01:00
|
|
|
// decay or other time based behavior is tested by other functions.
|
|
|
|
func TestDynamicBanScoreReset(t *testing.T) {
|
2016-05-12 11:06:07 +02:00
|
|
|
var bs DynamicBanScore
|
2016-01-23 04:11:22 +01:00
|
|
|
if bs.Int() != 0 {
|
|
|
|
t.Errorf("Initial state is not zero.")
|
|
|
|
}
|
|
|
|
bs.Increase(100, 0)
|
|
|
|
r := bs.Int()
|
|
|
|
if r != 100 {
|
|
|
|
t.Errorf("Unexpected result %d after ban score increase.", r)
|
|
|
|
}
|
|
|
|
bs.Reset()
|
|
|
|
if bs.Int() != 0 {
|
|
|
|
t.Errorf("Failed to reset ban score.")
|
|
|
|
}
|
|
|
|
}
|