Skip to content

Commit

Permalink
go: add byzantine subcommand
Browse files Browse the repository at this point in the history
  • Loading branch information
pro-wh committed Jul 13, 2019
1 parent 505b589 commit 665108c
Show file tree
Hide file tree
Showing 4 changed files with 154 additions and 1 deletion.
37 changes: 37 additions & 0 deletions go/ekiden/cmd/debug/byzantine/byzantine.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
package byzantine

import (
"github.com/spf13/cobra"

"github.com/oasislabs/ekiden/go/common/logging"
"github.com/oasislabs/ekiden/go/ekiden/cmd/common"
)

var (
logger = logging.GetLogger("cmd/byzantine")
byzantineCmd = &cobra.Command{
Use: "byzantine",
Short: "run some node behaviors for testing, often not honest",
}
computeHonestCmd = &cobra.Command{
Use: "compute-honest",
Short: "act as an honest compute worker",
Run: doComputeHonest,
}
)

func doComputeHonest(cmd *cobra.Command, args []string) {
if err := common.Init(); err != nil {
common.EarlyLogAndExit(err)
}

startHonestTendermint()
defer stopHonestTendermint()
logger.Debug("compute honest: ok %%%")
}

// Register registers the byzantine sub-command and all of its children.
func Register(parentCmd *cobra.Command) {
byzantineCmd.AddCommand(computeHonestCmd)
parentCmd.AddCommand(byzantineCmd)
}
114 changes: 114 additions & 0 deletions go/ekiden/cmd/debug/byzantine/steps.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,114 @@
package byzantine

import (
"context"
"time"

"github.com/oasislabs/ekiden/go/common/identity"
"github.com/oasislabs/ekiden/go/common/pubsub"
"github.com/oasislabs/ekiden/go/ekiden/cmd/common"
"github.com/oasislabs/ekiden/go/epochtime/api"
"github.com/oasislabs/ekiden/go/genesis"
"github.com/oasislabs/ekiden/go/tendermint"
"github.com/oasislabs/ekiden/go/tendermint/apps/beacon"
"github.com/oasislabs/ekiden/go/tendermint/apps/registry"
"github.com/oasislabs/ekiden/go/tendermint/apps/scheduler"
"github.com/oasislabs/ekiden/go/tendermint/apps/staking"
"github.com/oasislabs/ekiden/go/tendermint/service"
"github.com/oasislabs/ekiden/go/tendermint/apps/roothash"
)

var (
honestTendermint service.TendermintService

_ api.Backend = (*FakeTimeBackend)(nil)
)

// FakeTimeBackend is like TendermintBackend (of epochtime), but without
// any workers.
// TODO: come up with an acceptable way to do this
type FakeTimeBackend struct{}

// GetEpoch implements epochtime Backend.
func (*FakeTimeBackend) GetEpoch(ctx context.Context, height int64) (api.EpochTime, error) {
if height == 0 {
panic("0 height not supported")
}
return api.EpochTime(height / 30), nil
}

// GetEpochBlock implements epochtime Backend.
func (*FakeTimeBackend) GetEpochBlock(ctx context.Context, epoch api.EpochTime) (int64, error) {
panic("GetEpochBlock not supported")
// return int64(epoch) * 30, nil
}

// WatchEpochs implements epochtime Backend.
func (*FakeTimeBackend) WatchEpochs() (<-chan api.EpochTime, *pubsub.Subscription) {
panic("WatchEpochs not supported")
}

func startHonestTendermint() {
if honestTendermint != nil {
panic("honest Tendermint service already started")
}

dataDir := common.DataDir()
identity, err := identity.LoadOrGenerate(dataDir)
if err != nil {
panic("identity.LoadOrGenerate: " + err.Error())
}
genesis, err := genesis.New(identity)
if err != nil {
panic("genesis.New: " + err.Error())
}
honestTendermint = tendermint.New(context.Background(), dataDir, identity, genesis)
logger.Debug("honest Tendermint service instantiated %%%", "honestTendermint", honestTendermint)

if err := honestTendermint.ForceInitialize(); err != nil {
panic("honestTendermint.ForceInitialize: " + err.Error())
}
logger.Debug("honest Tendermint service force initialized %%%")

// Register honest mux apps.
timeSource := &FakeTimeBackend{}
// tendermint epochtime has no registration
// TODO: tendermint_mock epochtime?
if err := honestTendermint.RegisterApplication(beacon.New(timeSource, true)); err != nil {
panic("honestTendermint.RegisterApplication beacon: " + err.Error())
}
if err := honestTendermint.RegisterApplication(registry.New(timeSource)); err != nil {
panic("honestTendermint.RegisterApplication registry: " + err.Error())
}
if err := honestTendermint.RegisterApplication(staking.New(nil)); err != nil {
panic("honestTendermint.RegisterApplication staking: " + err.Error())
}
if err := honestTendermint.RegisterApplication(scheduler.New(timeSource)); err != nil {
panic("honestTendermint.RegisterApplication scheduler: " + err.Error())
}
// storage has no registration
if err := honestTendermint.RegisterApplication(roothash.New(context.Background(), timeSource, nil, 10 * time.Second)); err != nil {
panic("honestTendermint.RegisterApplication roothash: " + err.Error())
}

if err := honestTendermint.Start(); err != nil {
panic("honestTendermint.Start: " + err.Error())
}
logger.Debug("honest Tendermint service start returned %%%")
<-honestTendermint.Started()
logger.Debug("honest Tendermint service start channel closed %%%")
<-honestTendermint.Synced()
logger.Debug("honest Tendermint service sync channel closed %%%")
}

func stopHonestTendermint() {
if honestTendermint == nil {
panic("honest Tendermint service not started")
}

honestTendermint.Stop()
logger.Debug("honest Tendermint service stop returned %%%")
<-honestTendermint.Quit()
logger.Debug("honest Tendermint service quit channel closed %%%")
honestTendermint = nil
}
2 changes: 2 additions & 0 deletions go/ekiden/cmd/debug/debug.go
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@ import (
"github.com/spf13/cobra"

"github.com/oasislabs/ekiden/go/ekiden/cmd/debug/bootstrap"
"github.com/oasislabs/ekiden/go/ekiden/cmd/debug/byzantine"
"github.com/oasislabs/ekiden/go/ekiden/cmd/debug/client"
"github.com/oasislabs/ekiden/go/ekiden/cmd/debug/dummy"
"github.com/oasislabs/ekiden/go/ekiden/cmd/debug/roothash"
Expand All @@ -23,6 +24,7 @@ func Register(parentCmd *cobra.Command) {
roothash.Register(debugCmd)
tendermint.Register(debugCmd)
bootstrap.Register(debugCmd)
byzantine.Register(debugCmd)

parentCmd.AddCommand(debugCmd)
}
2 changes: 1 addition & 1 deletion go/ekiden/cmd/debug/dummy/dummy.go
Original file line number Diff line number Diff line change
Expand Up @@ -108,7 +108,7 @@ func doWaitNodes(cmd *cobra.Command, args []string) {
logger.Info("enough nodes have been registered")
}

// Register registers the dummy sub-command and all of it's children.
// Register registers the dummy sub-command and all of its children.
func Register(parentCmd *cobra.Command) {
cmdGrpc.RegisterClientFlags(dummyCmd, true)
dummySetEpochCmd.Flags().Uint64VarP(&epoch, "epoch", "e", 0, "set epoch to given value")
Expand Down

0 comments on commit 665108c

Please sign in to comment.