mirror of
https://gitlab.com/pulsechaincom/erigon-pulse.git
synced 2025-01-15 07:18:19 +00:00
d739810dc5
* (EIP-4399) MixDigest is utilized for RANDOM * Add GetTd to ChainHeaderReader * Remove unused VerifyHeaders from consensus consensus * Introduce params.MaxGasLimit * Serenity engine: fall back to eth1 engine before the Merge * Serenity engine in CreateConsensusEngine * ethOne -> eth1Engine
83 lines
1.8 KiB
Go
83 lines
1.8 KiB
Go
package serenity
|
|
|
|
import (
|
|
"math/big"
|
|
"testing"
|
|
|
|
"github.com/ledgerwatch/erigon/common"
|
|
"github.com/ledgerwatch/erigon/consensus"
|
|
"github.com/ledgerwatch/erigon/core/types"
|
|
"github.com/ledgerwatch/erigon/params"
|
|
)
|
|
|
|
type readerMock struct{}
|
|
|
|
func (r readerMock) Config() *params.ChainConfig {
|
|
return nil
|
|
}
|
|
|
|
func (r readerMock) CurrentHeader() *types.Header {
|
|
return nil
|
|
}
|
|
|
|
func (r readerMock) GetHeader(common.Hash, uint64) *types.Header {
|
|
return nil
|
|
}
|
|
|
|
func (r readerMock) GetHeaderByNumber(uint64) *types.Header {
|
|
return nil
|
|
}
|
|
|
|
func (r readerMock) GetHeaderByHash(common.Hash) *types.Header {
|
|
return nil
|
|
}
|
|
|
|
func (r readerMock) GetTd(common.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")
|
|
}
|
|
}
|
|
}
|