2020-12-10 18:56:18 +00:00
|
|
|
package client
|
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
|
2022-04-29 14:32:11 +00:00
|
|
|
types "github.com/prysmaticlabs/prysm/consensus-types/primitives"
|
2021-07-21 21:34:07 +00:00
|
|
|
ethpb "github.com/prysmaticlabs/prysm/proto/prysm/v1alpha1"
|
2021-09-23 18:53:46 +00:00
|
|
|
"github.com/prysmaticlabs/prysm/testing/require"
|
2020-12-10 18:56:18 +00:00
|
|
|
logTest "github.com/sirupsen/logrus/hooks/test"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestLogNextDutyCountDown_NoDuty(t *testing.T) {
|
|
|
|
hook := logTest.NewGlobal()
|
|
|
|
v := &validator{
|
2020-12-18 21:12:57 +00:00
|
|
|
logDutyCountDown: true,
|
2020-12-10 18:56:18 +00:00
|
|
|
duties: ðpb.DutiesResponse{CurrentEpochDuties: []*ethpb.DutiesResponse_Duty{
|
2021-02-16 07:45:34 +00:00
|
|
|
{AttesterSlot: 100, ProposerSlots: []types.Slot{105}},
|
2020-12-10 18:56:18 +00:00
|
|
|
{AttesterSlot: 110},
|
|
|
|
{AttesterSlot: 120},
|
|
|
|
}},
|
|
|
|
}
|
|
|
|
require.NoError(t, v.LogNextDutyTimeLeft(121))
|
|
|
|
require.LogsContain(t, hook, "No duty until next epoch")
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestLogNextDutyCountDown_HasDutyAttester(t *testing.T) {
|
|
|
|
hook := logTest.NewGlobal()
|
|
|
|
v := &validator{
|
2020-12-18 21:12:57 +00:00
|
|
|
logDutyCountDown: true,
|
2020-12-10 18:56:18 +00:00
|
|
|
duties: ðpb.DutiesResponse{CurrentEpochDuties: []*ethpb.DutiesResponse_Duty{
|
2021-02-16 07:45:34 +00:00
|
|
|
{AttesterSlot: 100, ProposerSlots: []types.Slot{105}},
|
2020-12-10 18:56:18 +00:00
|
|
|
{AttesterSlot: 110},
|
|
|
|
{AttesterSlot: 120},
|
|
|
|
}},
|
|
|
|
}
|
|
|
|
require.NoError(t, v.LogNextDutyTimeLeft(115))
|
2021-01-07 10:22:38 +00:00
|
|
|
require.LogsContain(t, hook, "\"Next duty\" attesting=1 currentSlot=115 dutySlot=120 prefix=validator proposing=0")
|
2020-12-10 18:56:18 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestLogNextDutyCountDown_HasDutyProposer(t *testing.T) {
|
|
|
|
hook := logTest.NewGlobal()
|
|
|
|
v := &validator{
|
2020-12-18 21:12:57 +00:00
|
|
|
logDutyCountDown: true,
|
2020-12-10 18:56:18 +00:00
|
|
|
duties: ðpb.DutiesResponse{CurrentEpochDuties: []*ethpb.DutiesResponse_Duty{
|
2021-02-16 07:45:34 +00:00
|
|
|
{AttesterSlot: 100, ProposerSlots: []types.Slot{105}},
|
2020-12-10 18:56:18 +00:00
|
|
|
{AttesterSlot: 110},
|
|
|
|
{AttesterSlot: 120},
|
|
|
|
}},
|
|
|
|
}
|
|
|
|
require.NoError(t, v.LogNextDutyTimeLeft(101))
|
2021-01-07 10:22:38 +00:00
|
|
|
require.LogsContain(t, hook, "\"Next duty\" attesting=0 currentSlot=101 dutySlot=105 prefix=validator proposing=1")
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestLogNextDutyCountDown_HasMultipleDuties(t *testing.T) {
|
|
|
|
hook := logTest.NewGlobal()
|
|
|
|
v := &validator{
|
|
|
|
logDutyCountDown: true,
|
|
|
|
duties: ðpb.DutiesResponse{CurrentEpochDuties: []*ethpb.DutiesResponse_Duty{
|
|
|
|
{AttesterSlot: 120},
|
|
|
|
{AttesterSlot: 110},
|
|
|
|
{AttesterSlot: 105},
|
|
|
|
{AttesterSlot: 105},
|
2021-02-16 07:45:34 +00:00
|
|
|
{AttesterSlot: 100, ProposerSlots: []types.Slot{105}},
|
2021-01-07 10:22:38 +00:00
|
|
|
}},
|
|
|
|
}
|
|
|
|
require.NoError(t, v.LogNextDutyTimeLeft(101))
|
|
|
|
require.LogsContain(t, hook, "\"Next duty\" attesting=2 currentSlot=101 dutySlot=105 prefix=validator proposing=1")
|
2020-12-10 18:56:18 +00:00
|
|
|
}
|
2021-01-04 17:28:00 +00:00
|
|
|
|
|
|
|
func TestLogNextDutyCountDown_NilDuty(t *testing.T) {
|
|
|
|
v := &validator{
|
|
|
|
logDutyCountDown: true,
|
|
|
|
}
|
|
|
|
require.NoError(t, v.LogNextDutyTimeLeft(101))
|
|
|
|
}
|