Merge pull request #220 from harmony-one/beaconchain-mock

beaconchain tests
pull/223/head
alajko 6 years ago committed by GitHub
commit 11a4fc30ed
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
  1. 28
      internal/beaconchain/libs/beaconchain.go
  2. 39
      internal/beaconchain/libs/beaconchain_test.go

@ -18,6 +18,9 @@ import (
"github.com/harmony-one/harmony/p2p/p2pimpl" "github.com/harmony-one/harmony/p2p/p2pimpl"
) )
//BCState keeps track of the state the beaconchain is in
type BCState int
var mutex sync.Mutex var mutex sync.Mutex
var identityPerBlock = 100000 var identityPerBlock = 100000
@ -35,10 +38,16 @@ type BeaconChain struct {
IP string IP string
Port string Port string
host host.Host host host.Host
state BCState
rpcServer *beaconchain.Server rpcServer *beaconchain.Server
} }
// Followings are the set of states of that beaconchain can be in.
const (
NodeInfoReceived BCState = iota
RandomInfoSent
)
// SupportRPC initializes and starts the rpc service // SupportRPC initializes and starts the rpc service
func (bc *BeaconChain) SupportRPC() { func (bc *BeaconChain) SupportRPC() {
bc.InitRPCServer() bc.InitRPCServer()
@ -90,8 +99,8 @@ func generateBCKey() kyber.Point {
return pubkey return pubkey
} }
//AcceptConnections welcomes new connections //AcceptNodeInfo deserializes node information received via beaconchain handler
func (bc *BeaconChain) AcceptConnections(b []byte) { func (bc *BeaconChain) AcceptNodeInfo(b []byte) *bcconn.NodeInfo {
Node := bcconn.DeserializeNodeInfo(b) Node := bcconn.DeserializeNodeInfo(b)
bc.log.Info("New Node Connection", "IP", Node.Self.IP, "Port", Node.Self.Port) bc.log.Info("New Node Connection", "IP", Node.Self.IP, "Port", Node.Self.Port)
bc.NumberOfNodesAdded = bc.NumberOfNodesAdded + 1 bc.NumberOfNodesAdded = bc.NumberOfNodesAdded + 1
@ -99,11 +108,24 @@ func (bc *BeaconChain) AcceptConnections(b []byte) {
if isLeader { if isLeader {
bc.Leaders = append(bc.Leaders, Node) bc.Leaders = append(bc.Leaders, Node)
} }
bc.state = NodeInfoReceived
return Node
}
//RespondRandomness sends a randomness beacon to the node inorder for it process what shard it will be in
func (bc *BeaconChain) RespondRandomness(Node *bcconn.NodeInfo) {
response := bcconn.ResponseRandomNumber{NumberOfShards: bc.NumberOfShards, NumberOfNodesAdded: bc.NumberOfNodesAdded, Leaders: bc.Leaders} response := bcconn.ResponseRandomNumber{NumberOfShards: bc.NumberOfShards, NumberOfNodesAdded: bc.NumberOfNodesAdded, Leaders: bc.Leaders}
msg := bcconn.SerializeRandomInfo(response) msg := bcconn.SerializeRandomInfo(response)
msgToSend := proto_identity.ConstructIdentityMessage(proto_identity.Acknowledge, msg) msgToSend := proto_identity.ConstructIdentityMessage(proto_identity.Acknowledge, msg)
bc.log.Info("Sent Out Msg", "# Nodes", response.NumberOfNodesAdded) bc.log.Info("Sent Out Msg", "# Nodes", response.NumberOfNodesAdded)
host.SendMessage(bc.host, Node.Self, msgToSend, nil) host.SendMessage(bc.host, Node.Self, msgToSend, nil)
bc.state = RandomInfoSent
}
//AcceptConnections welcomes new connections
func (bc *BeaconChain) AcceptConnections(b []byte) {
node := bc.AcceptNodeInfo(b)
bc.RespondRandomness(node)
} }
//StartServer a server and process the request by a handler. //StartServer a server and process the request by a handler.

@ -8,6 +8,7 @@ import (
"github.com/harmony-one/harmony/api/proto/bcconn" "github.com/harmony-one/harmony/api/proto/bcconn"
beaconchain "github.com/harmony-one/harmony/internal/beaconchain/rpc" beaconchain "github.com/harmony-one/harmony/internal/beaconchain/rpc"
"github.com/harmony-one/harmony/p2p" "github.com/harmony-one/harmony/p2p"
"github.com/stretchr/testify/assert"
) )
var ( var (
@ -71,3 +72,41 @@ func TestFetchLeaders(t *testing.T) {
} }
} }
func TestAcceptNodeInfo(t *testing.T) {
var ip string
ip = "127.0.0.1"
beaconport := "8080"
numshards := 1
bc := New(numshards, ip, beaconport)
b := bcconn.SerializeNodeInfo(leader1)
node := bc.AcceptNodeInfo(b)
if !reflect.DeepEqual(node, leader1) {
t.Error("Beaconchain is unable to deserialize incoming node info")
}
if len(bc.Leaders) != 1 {
t.Error("Beaconchain was unable to update the leader array")
}
}
func TestRespondRandomness(t *testing.T) {
var ip string
ip = "127.0.0.1"
beaconport := "8080"
numshards := 1
bc := New(numshards, ip, beaconport)
bc.RespondRandomness(leader1)
assert.Equal(t, RandomInfoSent, bc.state)
}
func TestAcceptConnections(t *testing.T) {
var ip string
ip = "127.0.0.1"
beaconport := "8080"
numshards := 1
bc := New(numshards, ip, beaconport)
b := bcconn.SerializeNodeInfo(leader1)
bc.AcceptConnections(b)
assert.Equal(t, RandomInfoSent, bc.state)
}

Loading…
Cancel
Save