good morning!!!!

Skip to content
Snippets Groups Projects
Commit 12ec1419 authored by atvanguard's avatar atvanguard Committed by Arpit Agarwal
Browse files

test: :recycle: segregate unit and e2e tests

parent 187fc06f
Branches devnet-70004
Tags v0.2.0-devnet-70004
No related merge requests found
...@@ -36,7 +36,8 @@ ios: ...@@ -36,7 +36,8 @@ ios:
@echo "Import \"$(GOBIN)/bor.framework\" to use the library." @echo "Import \"$(GOBIN)/bor.framework\" to use the library."
test: bor test: bor
go test github.com/maticnetwork/bor/consensus/bor/bor_test go test github.com/maticnetwork/bor/consensus/bor
go test github.com/maticnetwork/bor/tests/bor
lint: ## Run linters. lint: ## Run linters.
$(GORUN) build/ci.go lint $(GORUN) build/ci.go lint
......
package bortest package bor
import ( import (
"math/rand" "math/rand"
...@@ -9,7 +9,6 @@ import ( ...@@ -9,7 +9,6 @@ import (
"github.com/stretchr/testify/assert" "github.com/stretchr/testify/assert"
"github.com/maticnetwork/bor/common" "github.com/maticnetwork/bor/common"
"github.com/maticnetwork/bor/consensus/bor"
) )
const ( const (
...@@ -18,8 +17,8 @@ const ( ...@@ -18,8 +17,8 @@ const (
func TestGetSignerSuccessionNumber_ProposerIsSigner(t *testing.T) { func TestGetSignerSuccessionNumber_ProposerIsSigner(t *testing.T) {
validators := buildRandomValidatorSet(numVals) validators := buildRandomValidatorSet(numVals)
validatorSet := bor.NewValidatorSet(validators) validatorSet := NewValidatorSet(validators)
snap := bor.Snapshot{ snap := Snapshot{
ValidatorSet: validatorSet, ValidatorSet: validatorSet,
} }
...@@ -35,14 +34,14 @@ func TestGetSignerSuccessionNumber_ProposerIsSigner(t *testing.T) { ...@@ -35,14 +34,14 @@ func TestGetSignerSuccessionNumber_ProposerIsSigner(t *testing.T) {
func TestGetSignerSuccessionNumber_SignerIndexIsLarger(t *testing.T) { func TestGetSignerSuccessionNumber_SignerIndexIsLarger(t *testing.T) {
validators := buildRandomValidatorSet(numVals) validators := buildRandomValidatorSet(numVals)
// sort validators by address, which is what bor.NewValidatorSet also does // sort validators by address, which is what NewValidatorSet also does
sort.Sort(bor.ValidatorsByAddress(validators)) sort.Sort(ValidatorsByAddress(validators))
proposerIndex := 32 proposerIndex := 32
signerIndex := 56 signerIndex := 56
// give highest ProposerPriority to a particular val, so that they become the proposer // give highest ProposerPriority to a particular val, so that they become the proposer
validators[proposerIndex].VotingPower = 200 validators[proposerIndex].VotingPower = 200
snap := bor.Snapshot{ snap := Snapshot{
ValidatorSet: bor.NewValidatorSet(validators), ValidatorSet: NewValidatorSet(validators),
} }
// choose a signer at an index greater than proposer index // choose a signer at an index greater than proposer index
...@@ -60,8 +59,8 @@ func TestGetSignerSuccessionNumber_SignerIndexIsSmaller(t *testing.T) { ...@@ -60,8 +59,8 @@ func TestGetSignerSuccessionNumber_SignerIndexIsSmaller(t *testing.T) {
signerIndex := 11 signerIndex := 11
// give highest ProposerPriority to a particular val, so that they become the proposer // give highest ProposerPriority to a particular val, so that they become the proposer
validators[proposerIndex].VotingPower = 200 validators[proposerIndex].VotingPower = 200
snap := bor.Snapshot{ snap := Snapshot{
ValidatorSet: bor.NewValidatorSet(validators), ValidatorSet: NewValidatorSet(validators),
} }
// choose a signer at an index greater than proposer index // choose a signer at an index greater than proposer index
...@@ -75,46 +74,46 @@ func TestGetSignerSuccessionNumber_SignerIndexIsSmaller(t *testing.T) { ...@@ -75,46 +74,46 @@ func TestGetSignerSuccessionNumber_SignerIndexIsSmaller(t *testing.T) {
func TestGetSignerSuccessionNumber_ProposerNotFound(t *testing.T) { func TestGetSignerSuccessionNumber_ProposerNotFound(t *testing.T) {
validators := buildRandomValidatorSet(numVals) validators := buildRandomValidatorSet(numVals)
snap := bor.Snapshot{ snap := Snapshot{
ValidatorSet: bor.NewValidatorSet(validators), ValidatorSet: NewValidatorSet(validators),
} }
dummyProposerAddress := randomAddress() dummyProposerAddress := randomAddress()
snap.ValidatorSet.Proposer = &bor.Validator{Address: dummyProposerAddress} snap.ValidatorSet.Proposer = &Validator{Address: dummyProposerAddress}
// choose any signer // choose any signer
signer := snap.ValidatorSet.Validators[3].Address signer := snap.ValidatorSet.Validators[3].Address
_, err := snap.GetSignerSuccessionNumber(signer) _, err := snap.GetSignerSuccessionNumber(signer)
assert.NotNil(t, err) assert.NotNil(t, err)
e, ok := err.(*bor.UnauthorizedProposerError) e, ok := err.(*UnauthorizedProposerError)
assert.True(t, ok) assert.True(t, ok)
assert.Equal(t, dummyProposerAddress.Bytes(), e.Proposer) assert.Equal(t, dummyProposerAddress.Bytes(), e.Proposer)
} }
func TestGetSignerSuccessionNumber_SignerNotFound(t *testing.T) { func TestGetSignerSuccessionNumber_SignerNotFound(t *testing.T) {
validators := buildRandomValidatorSet(numVals) validators := buildRandomValidatorSet(numVals)
snap := bor.Snapshot{ snap := Snapshot{
ValidatorSet: bor.NewValidatorSet(validators), ValidatorSet: NewValidatorSet(validators),
} }
dummySignerAddress := randomAddress() dummySignerAddress := randomAddress()
_, err := snap.GetSignerSuccessionNumber(dummySignerAddress) _, err := snap.GetSignerSuccessionNumber(dummySignerAddress)
assert.NotNil(t, err) assert.NotNil(t, err)
e, ok := err.(*bor.UnauthorizedSignerError) e, ok := err.(*UnauthorizedSignerError)
assert.True(t, ok) assert.True(t, ok)
assert.Equal(t, dummySignerAddress.Bytes(), e.Signer) assert.Equal(t, dummySignerAddress.Bytes(), e.Signer)
} }
func buildRandomValidatorSet(numVals int) []*bor.Validator { func buildRandomValidatorSet(numVals int) []*Validator {
rand.Seed(time.Now().Unix()) rand.Seed(time.Now().Unix())
validators := make([]*bor.Validator, numVals) validators := make([]*Validator, numVals)
for i := 0; i < numVals; i++ { for i := 0; i < numVals; i++ {
validators[i] = &bor.Validator{ validators[i] = &Validator{
Address: randomAddress(), Address: randomAddress(),
// cannot process validators with voting power 0, hence +1 // cannot process validators with voting power 0, hence +1
VotingPower: int64(rand.Intn(99) + 1), VotingPower: int64(rand.Intn(99) + 1),
} }
} }
// sort validators by address, which is what bor.NewValidatorSet also does // sort validators by address, which is what NewValidatorSet also does
sort.Sort(bor.ValidatorsByAddress(validators)) sort.Sort(ValidatorsByAddress(validators))
return validators return validators
} }
......
package bortest package bor
import ( import (
"encoding/hex" "encoding/hex"
......
package bortest package bor
import ( import (
"encoding/hex" "encoding/hex"
...@@ -45,7 +45,7 @@ type initializeData struct { ...@@ -45,7 +45,7 @@ type initializeData struct {
} }
func buildEthereumInstance(t *testing.T, db ethdb.Database) *initializeData { func buildEthereumInstance(t *testing.T, db ethdb.Database) *initializeData {
genesisData, err := ioutil.ReadFile("genesis.json") genesisData, err := ioutil.ReadFile("./testdata/genesis.json")
if err != nil { if err != nil {
t.Fatalf("%s", err) t.Fatalf("%s", err)
} }
...@@ -157,7 +157,7 @@ func sign(t *testing.T, header *types.Header, signer []byte) { ...@@ -157,7 +157,7 @@ func sign(t *testing.T, header *types.Header, signer []byte) {
} }
func stateSyncEventsPayload(t *testing.T) *bor.ResponseWithHeight { func stateSyncEventsPayload(t *testing.T) *bor.ResponseWithHeight {
stateData, err := ioutil.ReadFile("states.json") stateData, err := ioutil.ReadFile("./testdata/states.json")
if err != nil { if err != nil {
t.Fatalf("%s", err) t.Fatalf("%s", err)
} }
...@@ -169,7 +169,7 @@ func stateSyncEventsPayload(t *testing.T) *bor.ResponseWithHeight { ...@@ -169,7 +169,7 @@ func stateSyncEventsPayload(t *testing.T) *bor.ResponseWithHeight {
} }
func loadSpanFromFile(t *testing.T) (*bor.ResponseWithHeight, *bor.HeimdallSpan) { func loadSpanFromFile(t *testing.T) (*bor.ResponseWithHeight, *bor.HeimdallSpan) {
spanData, err := ioutil.ReadFile("span.json") spanData, err := ioutil.ReadFile("./testdata/span.json")
if err != nil { if err != nil {
t.Fatalf("%s", err) t.Fatalf("%s", err)
} }
......
File moved
File moved
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Please register or to comment