-
Notifications
You must be signed in to change notification settings - Fork 115
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
interop/protocl-server: support for initializing with mock consensus …
…state
- Loading branch information
Showing
10 changed files
with
373 additions
and
15 deletions.
There are no files selected for viewing
204 changes: 204 additions & 0 deletions
204
go/consensus/tendermint/apps/staking/state/interop/interop.go
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,204 @@ | ||
package interop | ||
|
||
import ( | ||
"context" | ||
"fmt" | ||
|
||
"github.com/oasisprotocol/oasis-core/go/common/crypto/signature" | ||
"github.com/oasisprotocol/oasis-core/go/common/quantity" | ||
stakingState "github.com/oasisprotocol/oasis-core/go/consensus/tendermint/apps/staking/state" | ||
staking "github.com/oasisprotocol/oasis-core/go/staking/api" | ||
"github.com/oasisprotocol/oasis-core/go/storage/mkvs" | ||
) | ||
|
||
var addresses []staking.Address | ||
|
||
// Keep this in sync with tests in runtimes/consensus/state/staking.rs. | ||
func InitializeTestStakingState(ctx context.Context, mkvs mkvs.Tree) error { | ||
state := stakingState.NewMutableState(mkvs) | ||
|
||
// Populate accounts. | ||
for _, acc := range []struct { | ||
address staking.Address | ||
account *staking.Account | ||
}{ | ||
{ | ||
addresses[0], | ||
&staking.Account{ | ||
General: staking.GeneralAccount{ | ||
Balance: *quantity.NewFromUint64(23), | ||
Nonce: 13, | ||
}, | ||
Escrow: staking.EscrowAccount{ | ||
Active: staking.SharePool{ | ||
Balance: *quantity.NewFromUint64(100), | ||
TotalShares: *quantity.NewFromUint64(10), | ||
}, | ||
Debonding: staking.SharePool{ | ||
Balance: *quantity.NewFromUint64(5), | ||
TotalShares: *quantity.NewFromUint64(5), | ||
}, | ||
}, | ||
}, | ||
}, | ||
{ | ||
addresses[1], | ||
&staking.Account{ | ||
General: staking.GeneralAccount{ | ||
Balance: *quantity.NewFromUint64(23), | ||
Nonce: 1, | ||
}, | ||
Escrow: staking.EscrowAccount{ | ||
Active: staking.SharePool{ | ||
Balance: *quantity.NewFromUint64(500), | ||
TotalShares: *quantity.NewFromUint64(5), | ||
}, | ||
}, | ||
}, | ||
}, | ||
{ | ||
addresses[2], | ||
&staking.Account{ | ||
General: staking.GeneralAccount{ | ||
Balance: *quantity.NewFromUint64(113), | ||
Nonce: 17, | ||
}, | ||
Escrow: staking.EscrowAccount{ | ||
Active: staking.SharePool{ | ||
Balance: *quantity.NewFromUint64(400), | ||
TotalShares: *quantity.NewFromUint64(35), | ||
}, | ||
}, | ||
}, | ||
}, | ||
} { | ||
if err := state.SetAccount(ctx, acc.address, acc.account); err != nil { | ||
return fmt.Errorf("setting account: %w", err) | ||
} | ||
} | ||
|
||
// Initialize delegations. | ||
for _, del := range []struct { | ||
from staking.Address | ||
to staking.Address | ||
d *staking.Delegation | ||
}{ | ||
{ | ||
from: addresses[0], | ||
to: addresses[0], | ||
d: &staking.Delegation{ | ||
Shares: *quantity.NewFromUint64(5), | ||
}, | ||
}, | ||
{ | ||
from: addresses[0], | ||
to: addresses[2], | ||
d: &staking.Delegation{ | ||
Shares: *quantity.NewFromUint64(20), | ||
}, | ||
}, | ||
{ | ||
from: addresses[1], | ||
to: addresses[0], | ||
d: &staking.Delegation{ | ||
Shares: *quantity.NewFromUint64(5), | ||
}, | ||
}, | ||
{ | ||
from: addresses[1], | ||
to: addresses[2], | ||
d: &staking.Delegation{ | ||
Shares: *quantity.NewFromUint64(6), | ||
}, | ||
}, | ||
{ | ||
from: addresses[2], | ||
to: addresses[1], | ||
d: &staking.Delegation{ | ||
Shares: *quantity.NewFromUint64(5), | ||
}, | ||
}, | ||
{ | ||
from: addresses[2], | ||
to: addresses[2], | ||
d: &staking.Delegation{ | ||
Shares: *quantity.NewFromUint64(10), | ||
}, | ||
}, | ||
} { | ||
if err := state.SetDelegation(ctx, del.from, del.to, del.d); err != nil { | ||
return err | ||
} | ||
} | ||
|
||
// Initialize debonding delegations. | ||
for _, deb := range []struct { | ||
from staking.Address | ||
to staking.Address | ||
d *staking.DebondingDelegation | ||
}{ | ||
{ | ||
from: addresses[0], | ||
to: addresses[0], | ||
d: &staking.DebondingDelegation{ | ||
Shares: *quantity.NewFromUint64(1), | ||
DebondEndTime: 33, | ||
}, | ||
}, | ||
{ | ||
from: addresses[1], | ||
to: addresses[0], | ||
d: &staking.DebondingDelegation{ | ||
Shares: *quantity.NewFromUint64(1), | ||
DebondEndTime: 15, | ||
}, | ||
}, | ||
{ | ||
from: addresses[1], | ||
to: addresses[0], | ||
d: &staking.DebondingDelegation{ | ||
Shares: *quantity.NewFromUint64(1), | ||
DebondEndTime: 21, | ||
}, | ||
}, | ||
{ | ||
from: addresses[2], | ||
to: addresses[0], | ||
d: &staking.DebondingDelegation{ | ||
Shares: *quantity.NewFromUint64(2), | ||
DebondEndTime: 100, | ||
}, | ||
}, | ||
} { | ||
if err := state.SetDebondingDelegation(ctx, deb.from, deb.to, deb.d.DebondEndTime, deb.d); err != nil { | ||
return err | ||
} | ||
} | ||
|
||
// Initialize balances. | ||
if err := state.SetTotalSupply(ctx, quantity.NewFromUint64(10000)); err != nil { | ||
return err | ||
} | ||
if err := state.SetCommonPool(ctx, quantity.NewFromUint64(1000)); err != nil { | ||
return err | ||
} | ||
if err := state.SetLastBlockFees(ctx, quantity.NewFromUint64(33)); err != nil { | ||
return err | ||
} | ||
if err := state.SetGovernanceDeposits(ctx, quantity.NewFromUint64(12)); err != nil { | ||
return err | ||
} | ||
|
||
return nil | ||
} | ||
|
||
func init() { | ||
pk := signature.NewPublicKey("7e57baaad01fffffffffffffffffffffffffffffffffffffffffffffffffffff") | ||
pk2 := signature.NewPublicKey("7e57baaad02fffffffffffffffffffffffffffffffffffffffffffffffffffff") | ||
pk3 := signature.NewPublicKey("7e57baaad03fffffffffffffffffffffffffffffffffffffffffffffffffffff") | ||
addresses = append(addresses, | ||
staking.NewAddress(pk), | ||
staking.NewAddress(pk2), | ||
staking.NewAddress(pk3), | ||
) | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,52 @@ | ||
package fixtures | ||
|
||
import ( | ||
"context" | ||
"fmt" | ||
|
||
"github.com/oasisprotocol/oasis-core/go/common" | ||
stakingInterop "github.com/oasisprotocol/oasis-core/go/consensus/tendermint/apps/staking/state/interop" | ||
storage "github.com/oasisprotocol/oasis-core/go/storage/api" | ||
"github.com/oasisprotocol/oasis-core/go/storage/mkvs" | ||
db "github.com/oasisprotocol/oasis-core/go/storage/mkvs/db/api" | ||
"github.com/oasisprotocol/oasis-core/go/storage/mkvs/node" | ||
) | ||
|
||
const consensusMockName = "consensus_mock" | ||
|
||
var consensusMockFixture = consensusMock{} | ||
|
||
type consensusMock struct { | ||
} | ||
|
||
func (c *consensusMock) Name() string { | ||
return consensusMockName | ||
} | ||
|
||
func (c *consensusMock) Populate(ctx context.Context, ndb db.NodeDB) error { | ||
var err error | ||
testRoot := storage.Root{ | ||
Type: storage.RootTypeState, | ||
Version: 1, | ||
} | ||
|
||
mkvsTree := mkvs.New(nil, ndb, node.RootTypeState, mkvs.WithoutWriteLog()) | ||
if err = stakingInterop.InitializeTestStakingState(ctx, mkvsTree); err != nil { | ||
return fmt.Errorf("consensus-mock: failed to initialize state: %w", err) | ||
} | ||
_, testRoot.Hash, err = mkvsTree.Commit(ctx, common.Namespace{}, 1) | ||
if err != nil { | ||
return fmt.Errorf("consensus-mock: failed to committ tree: %w", err) | ||
} | ||
if err = ndb.Finalize(ctx, []node.Root{testRoot}); err != nil { | ||
return fmt.Errorf("consensus-mock: failed to finalize test root: %w", err) | ||
} | ||
|
||
fmt.Println("Consensus state root hash:", testRoot.Hash) | ||
|
||
return nil | ||
} | ||
|
||
func init() { | ||
Register(&consensusMockFixture) | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,44 @@ | ||
package fixtures | ||
|
||
import ( | ||
"context" | ||
"fmt" | ||
"sync" | ||
|
||
db "github.com/oasisprotocol/oasis-core/go/storage/mkvs/db/api" | ||
) | ||
|
||
var ( | ||
registeredFixtures sync.Map | ||
|
||
// ErrMissingFixture is the error returned when getting a nonexisting fixture. | ||
ErrMissingFixture = fmt.Errorf("fixture does not exist") | ||
) | ||
|
||
// Fixture is a protocol server fixture. | ||
type Fixture interface { | ||
// Name is the name of the fixture. | ||
Name() string | ||
|
||
// Populate populates the db with the fixture. | ||
Populate(context.Context, db.NodeDB) error | ||
} | ||
|
||
// Register registers a new fixture. | ||
func Register(fixture Fixture) { | ||
name := fixture.Name() | ||
if _, isRegistered := registeredFixtures.Load(name); isRegistered { | ||
panic(fmt.Errorf("fixture already registered: %s", name)) | ||
} | ||
registeredFixtures.Store(name, fixture) | ||
} | ||
|
||
// GetFixture returns a registered fixture by name. | ||
func GetFixture(name string) (Fixture, error) { | ||
h, exists := registeredFixtures.Load(name) | ||
if !exists { | ||
return nil, ErrMissingFixture | ||
} | ||
|
||
return h.(Fixture), nil | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.