erigon-pulse/consensus/serenity/serenity_test.go

84 lines
1.8 KiB
Go

package serenity
import (
"math/big"
"testing"
"github.com/ledgerwatch/erigon-lib/chain"
libcommon "github.com/ledgerwatch/erigon-lib/common"
"github.com/ledgerwatch/erigon/consensus"
"github.com/ledgerwatch/erigon/core/types"
)
type readerMock struct{}
func (r readerMock) Config() *chain.Config {
return nil
}
func (r readerMock) CurrentHeader() *types.Header {
return nil
}
func (r readerMock) GetHeader(libcommon.Hash, uint64) *types.Header {
return nil
}
func (r readerMock) GetHeaderByNumber(uint64) *types.Header {
return nil
}
func (r readerMock) GetHeaderByHash(libcommon.Hash) *types.Header {
return nil
}
func (r readerMock) GetTd(libcommon.Hash, uint64) *big.Int {
return nil
}
// The thing only that changes beetwen normal ethash checks other than POW, is difficulty
// and nonce so we are gonna test those
func TestVerifyHeaderDifficulty(t *testing.T) {
header := &types.Header{
Difficulty: big.NewInt(1),
Time: 1,
}
parent := &types.Header{}
var eth1Engine consensus.Engine
serenity := New(eth1Engine)
err := serenity.verifyHeader(readerMock{}, header, parent)
if err != errInvalidDifficulty {
if err != nil {
t.Fatalf("Serenity should not accept non-zero difficulty, got %s", err.Error())
} else {
t.Fatalf("Serenity should not accept non-zero difficulty")
}
}
}
func TestVerifyHeaderNonce(t *testing.T) {
header := &types.Header{
Nonce: types.BlockNonce{1, 0, 0, 0, 0, 0, 0, 0},
Difficulty: big.NewInt(0),
Time: 1,
}
parent := &types.Header{}
var eth1Engine consensus.Engine
serenity := New(eth1Engine)
err := serenity.verifyHeader(readerMock{}, header, parent)
if err != errInvalidNonce {
if err != nil {
t.Fatalf("Serenity should not accept non-zero difficulty, got %s", err.Error())
} else {
t.Fatalf("Serenity should not accept non-zero difficulty")
}
}
}