diff --git a/Makefile b/Makefile index 5252fd2bb..6f8ed45ca 100644 --- a/Makefile +++ b/Makefile @@ -173,10 +173,14 @@ go_mockgen: ## Use `mockgen` to generate mocks used for testing purposes of all go generate ./pkg/relayer/interface.go go generate ./pkg/crypto/rings/interface.go -.PHONY: go_fixturegen -go_fixturegen: ## Generate fixture data for unit tests +.PHONY: go_testgen_fixtures +go_testgen_fixtures: ## Generate fixture data for unit tests go generate ./pkg/relayer/miner/miner_test.go +.PHONY: go_testgen_accounts +go_testgen_accounts: ## Generate test accounts for usage in test environments + go generate ./testutil/testkeyring/keyring.go + .PHONY: go_develop go_develop: proto_regen go_mockgen ## Generate protos and mocks diff --git a/pkg/relayer/miner/gen/gen_fixtures.go b/pkg/relayer/miner/gen/gen_fixtures.go index 87e27bb01..59071d9ab 100644 --- a/pkg/relayer/miner/gen/gen_fixtures.go +++ b/pkg/relayer/miner/gen/gen_fixtures.go @@ -72,7 +72,7 @@ func init() { // random bytes. // Output file is truncated and overwritten if it already exists. // -// To regenerate all fixtures, use `make go_fixturegen`; to regenerate only this +// To regenerate all fixtures, use `make go_testgen_fixtures`; to regenerate only this // test's fixtures run `go generate ./pkg/relayer/miner/miner_test.go`. func main() { flag.Parse() diff --git a/pkg/relayer/miner/gen/template.go b/pkg/relayer/miner/gen/template.go index 8eb32c53b..c75e761a4 100644 --- a/pkg/relayer/miner/gen/template.go +++ b/pkg/relayer/miner/gen/template.go @@ -9,7 +9,7 @@ var ( `// DO NOT EDIT: this file was generated by gen/gen_fixtures.go, // changes made will be overwritten upon regeneration. // -// To regenerate all fixtures, use make go_fixturegen; to regenerate only this +// To regenerate all fixtures, use make go_testgen_fixture; to regenerate only this // test's fixtures run go generate ./pkg/relayer/miner/miner_test.go. package miner_test diff --git a/pkg/relayer/miner/miner_test.go b/pkg/relayer/miner/miner_test.go index c6958616d..9366f4121 100644 --- a/pkg/relayer/miner/miner_test.go +++ b/pkg/relayer/miner/miner_test.go @@ -27,7 +27,7 @@ const testDifficulty = 16 // it pipes pre-mined relay fixtures. It asserts that the observable only emits // mined relays with difficulty equal to or greater than testDifficulty. // -// To regenerate all fixtures, use `make go_fixturegen`; to regenerate only this +// To regenerate all fixtures, use `make go_testgen_fixtures`; to regenerate only this // test's fixtures run `go generate ./pkg/relayer/miner/miner_test.go`. func TestMiner_MinedRelays(t *testing.T) { var ( diff --git a/pkg/relayer/miner/relay_fixtures_test.go b/pkg/relayer/miner/relay_fixtures_test.go index 7a8042fde..c32dd4509 100644 --- a/pkg/relayer/miner/relay_fixtures_test.go +++ b/pkg/relayer/miner/relay_fixtures_test.go @@ -1,7 +1,7 @@ // DO NOT EDIT: this file was generated by gen/gen_fixtures.go, // changes made will be overwritten upon regeneration. // -// To regenerate all fixtures, use make go_fixturegen; to regenerate only this +// To regenerate all fixtures, use make go_testgen_fixture; to regenerate only this // test's fixtures run go generate ./pkg/relayer/miner/miner_test.go. package miner_test diff --git a/testutil/testkeyring/accounts.go b/testutil/testkeyring/accounts.go new file mode 100644 index 000000000..f71fe665d --- /dev/null +++ b/testutil/testkeyring/accounts.go @@ -0,0 +1,118 @@ +package testkeyring + +import ( + "encoding/base64" + "encoding/json" + "sync/atomic" + + sdktypes "github.com/cosmos/cosmos-sdk/types" +) + +// PreGeneratedAccount holds the address and mnemonic of an account which was +// pre-generated by the `gen_accounts` package. It is intended to be used ONLY +// in tests. It is useful for scenarios where it is necessary to know the address +// of a specific key in a separate context from that of keyring and/or module +// genesis state construction. +type PreGeneratedAccount struct { + Address sdktypes.AccAddress `json:"address"` + Mnemonic string `json:"mnemonic"` +} + +// PreGeneratedAccountIterator is an iterator over the pre-generated accounts. +// A new iterator populated with existing pre-generated accounts can be created +// with the PreGeneratedAccounts function. Alternatively, a new iterator can be +// created with the NewPreGeneratedAccountIterator function, to which a list of +// pre-generated accounts to be iterated over must be provided. +type PreGeneratedAccountIterator struct { + accounts []*PreGeneratedAccount + nextIndex uint32 +} + +// PreGeneratedAccountAtIndex returns the pre-generated account at the given index. +// It returns nil and false if the index is out of range. +func PreGeneratedAccountAtIndex(index uint32) (_ *PreGeneratedAccount, ok bool) { + if preGeneratedAccounts.nextIndex >= uint32(len(preGeneratedAccounts.accounts)) { + return nil, false + } + + return preGeneratedAccounts.accounts[index], true +} + +// MustPreGeneratedAccountAtIndex returns the pre-generated account at the given index. +// It panics on error; i.e. if the index is out of range. +func MustPreGeneratedAccountAtIndex(index uint32) *PreGeneratedAccount { + account, ok := PreGeneratedAccountAtIndex(index) + if !ok { + panic("index out of range of pre-generated accounts list") + } + return account +} + +// PreGeneratedAccounts returns a new PreGeneratedAccountIterator with the +// accounts which were pre-generated by the `gen_accounts` package (i.e. accounts_table.go). +func PreGeneratedAccounts() *PreGeneratedAccountIterator { + return preGeneratedAccounts.Clone() +} + +// NewPreGeneratedAccountIterator returns a new PreGeneratedAccountIterator with +// the given accounts. It is primarily used by the generated code to initially +// construct the preGeneratedAccounts variable. +func NewPreGeneratedAccountIterator(accounts ...*PreGeneratedAccount) *PreGeneratedAccountIterator { + return &PreGeneratedAccountIterator{ + accounts: accounts, + nextIndex: 0, + } +} + +// Next returns the next account in the iterator. It is safe to call +// concurrently and is guaranteed to return a unique account on each call. +// If the iterator index goes out of range, it returns nil and false. +func (iter *PreGeneratedAccountIterator) Next() (_ *PreGeneratedAccount, ok bool) { + // NB: instead of loading and incrementing in separate steps, just increment + // and use nextIndex-1 for the current index. + nextIndex := atomic.AddUint32(&iter.nextIndex, 1) + currentIndex := nextIndex - 1 + + if currentIndex > uint32(len(iter.accounts)) { + return nil, false + } + + return iter.accounts[currentIndex], true +} + +// Clone returns a new PreGeneratedAccountIterator with the same accounts as the +// receiver but with its nextIndex reset to 0. +func (iter *PreGeneratedAccountIterator) Clone() *PreGeneratedAccountIterator { + return NewPreGeneratedAccountIterator(iter.accounts...) +} + +// Marshal returns the base64 and JSON encoded account string. +func (pga *PreGeneratedAccount) Marshal() (string, error) { + accountJson, err := json.Marshal(pga) + if err != nil { + return "", err + } + + accountStr := base64.StdEncoding.EncodeToString(accountJson) + return accountStr, nil +} + +// UnmarshalString parses the given base64 and JSON encoded account string into +// the PreGeneratedAccount receiver. +func (pga *PreGeneratedAccount) UnmarshalString(encodedAccountStr string) error { + accountJson, err := base64.StdEncoding.DecodeString(encodedAccountStr) + if err != nil { + return err + } + return json.Unmarshal(accountJson, pga) +} + +// mustParsePreGeneratedAccount parses the given base64 and JSON encoded account +// string into a PreGeneratedAccount. It panics on error. +func mustParsePreGeneratedAccount(accountStr string) *PreGeneratedAccount { + account := new(PreGeneratedAccount) + if err := account.UnmarshalString(accountStr); err != nil { + panic(err) + } + return account +} diff --git a/testutil/testkeyring/accounts_table.go b/testutil/testkeyring/accounts_table.go new file mode 100644 index 000000000..711a25018 --- /dev/null +++ b/testutil/testkeyring/accounts_table.go @@ -0,0 +1,111 @@ +// DO NOT EDIT. This Code is generated by gen_accounts/gen.go, +// changes will be overwritten upon regeneration. +// +// To regenerate this file, use make go_testgen_accounts or go generate ./testutil/network/keyring.go. + +package testkeyring + +var ( + preGeneratedAccounts = NewPreGeneratedAccountIterator( + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMWRwZzN5YWU5OWc4bHJ3Nzl3dzBrZzJ6YTg0MzY2ZDZ0NjNrdTdkIiwiTW5lbW9uaWMiOiJsaWtlIGhpcCBzd2FtcCBmb3VuZCBjcnlzdGFsIGZsYW1lIGRlY3JlYXNlIGNydXNoIGNvaW4gY29uZHVjdCBhZmZhaXIgdmlsbGFnZSBjcnVlbCBtb250aCBob3N0IGdsb2JlIHJlZnVzZSByaWdpZCBmZWJydWFyeSBvdmVuIGNvcmUgY3JvcCBpbnB1dCBndWlsdCJ9"), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMTczYzI2dG05enp2MnVnbGNhdmFkMGd3dG02azd0cTN0MmtzN2s4IiwiTW5lbW9uaWMiOiJyb2JvdCBzdW5ueSBoaWxsIHNvY2NlciB0b2JhY2NvIHBhbmVsIGluY2x1ZGUgdGFibGUgaW52aXRlIHNoeSB3b3JsZCBwZXJzb24gZG9vciBwdW5jaCBzdGluZyBkZWNvcmF0ZSB3aW5rIHNjaXNzb3JzIG94eWdlbiB0aG91Z2h0IGxpZnQgZGVjbGluZSBtb29uIGxvYW4ifQ=="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMTBzbTVlcDUzaGt5a2RnM3p0NHNwZ214amZ0YXJ6czh1ZjBkZXdqIiwiTW5lbW9uaWMiOiJzdG9uZSBwcmVzZW50IGdvbGQgYmFyZ2FpbiBsZWFmIHJlY2VpdmUgYmFyZ2FpbiByYXcgc2luY2Ugc2hvdmUgYWRqdXN0IGRlcHV0eSByb2NrZXQgZm9sbG93IGxhd3N1aXQgbWFuZ28gc3RhZ2UgcnVud2F5IGRvZyBiZWF1dHkgZ2FzIHNlbnNlIGRpYWdyYW0gdGFzayJ9"), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMWR1bHp3Z3RnN2xkeDJ6dGgzbXNtbXB1d3phN2tsZDUyOTJkenh1IiwiTW5lbW9uaWMiOiJkb25hdGUgYWxpZW4gcGxhbmV0IGRlZXIgbWFuc2lvbiBiZWdpbiBub3RoaW5nIGd1aWx0IGdvb3NlIGNpdmlsIGdhdGUgcHJvZHVjZSBvbGQgZXJyb3IgYmVoYXZlIG1ha2UgZmx1c2ggYmFubmVyIGNyaWNrZXQgbGFrZSBoaXN0b3J5IGxhbXAgdmljdG9yeSB0dW1ibGUifQ=="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMTRmODRqbGc3ZHFrNHlmNXY3bDg5cHh2a2FyczZtM2czbGRyYXM0IiwiTW5lbW9uaWMiOiJlbGRlciBncmllZiBmYXRhbCBzaXggY291c2luIHByb2JsZW0gdGlnZXIgdmFsdmUgaGVhdnkgY2hyb25pYyBkZXB0aCBnYXRoZXIgZmljdGlvbiBjaGltbmV5IGNyaXNwIGVjb2xvZ3kgbWFuc2lvbiBleGN1c2UgbGV0dGVyIGZhbGwgZXZva2UgY3Jhd2wgaWdub3JlIG9wZXJhIn0="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMWNwY25oanU0MDR6NDQ3Z2x4ZzlxdTNsN3c1ZHdzcGQ1emQ0NWhyIiwiTW5lbW9uaWMiOiJ3aGF0IGVtZXJnZSBob3NwaXRhbCBrZXkgZHV0Y2ggZXhhbXBsZSB1cG9uIGdvb2Qgbm9vZGxlIHNldHRsZSB3aXNlIGNvbm5lY3QgdGlwIGFsbCByb29mIGNvbWJpbmUgZXhwbGFpbiBjaGVzdCBsYWJlbCBsb2dpYyB3YWxrIGZvbGQgdHJheSByYWNjb29uIn0="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMTNrcm11ZGpldDNrY2xjZGVtMG5qaGdodzloMnBsZnFncmNqdnRlIiwiTW5lbW9uaWMiOiJraXdpIG9wcG9zZSBxdWVzdGlvbiBtb250aCByYW5kb20gZXh0cmEgZW1wb3dlciBiYW5hbmEgd29ydGggYXBhcnQgcmlzayBiZXR3ZWVuIGluc2FuZSByaXZhbCBkdWNrIGxlZyB0cmF2ZWwgcmVuZXcgc29jY2VyIGFkanVzdCBnb2RkZXNzIGNyb3VjaCBkaXNhZ3JlZSB0b3BpYyJ9"), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMXozZ3NrdjdlNjR5MzZ2eDN6Y3M3ZDYzbnJ1bWRhZnRzNjZ1MjluIiwiTW5lbW9uaWMiOiJtb3ZlIGZsaWdodCBjb21pYyB5b3V0aCBkcmFmdCB0cnV0aCB0cmFzaCBiYXNpYyBsYXdzdWl0IHdpbGQgcHJpZGUgdGlzc3VlIGFwYXJ0IGluaGFsZSB6ZWJyYSBmdWVsIHRyZWF0IGhvdXIgcGhvdG8gdG9zcyB2aXNpdCB0b3AgYWxsZXkgc3R1bWJsZSJ9"), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMTh1eHV2djA0MmUzbjd5d3FzMmZmODNzaDM2YzdkOXhuOGx1NmsyIiwiTW5lbW9uaWMiOiJ3b3J0aCBjaGlja2VuIGFybW9yIGNhbG0gaGVuIHRvaWxldCBldm9rZSByb3V0ZSBwYXRjaCBmYW1lIHBvcnRpb24gaG9iYnkgZXhjZXNzIG1hbmRhdGUgd29ybGQgdW5oYXBweSBoYXJkIG1vbSBvbHltcGljIGNyeXN0YWwgb2ZmaWNlIHJlbGllZiBmYXNoaW9uIHN1Y2gifQ=="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMWtqcGRneG0waHN5YWhxcTQ5NHVocGt3d2w4cXZ5N3JudG12OGxoIiwiTW5lbW9uaWMiOiJva2F5IHBvZW0gYm9vc3QgYmxlYWsgc3F1ZWV6ZSBwaXBlIHRvb2wgZmlsdGVyIHRpbWJlciBzbGFiIGdhaW4gcGVvcGxlIG5ldCBhcnJlc3Qgc2VjdXJpdHkgZGVjYWRlIGNyYWZ0IGFwcGVhciBzbW9rZSBib2R5IGFzc2F1bHQgYmVhY2ggZXhvdGljIGFsdGVyIn0="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMXVudXJnd3Zna2s1NmwzM2d3bjA3MjM3NTkwODluOGU0ajRweXJmIiwiTW5lbW9uaWMiOiJ1cmJhbiBicm9jY29saSBncml0IG1lcnJ5IHJvbWFuY2UgbXl0aCBqb2IgZm9jdXMgY2xpY2sgc2h5IHByaW9yaXR5IGFzc2V0IGJyaXNrIHJlY29yZCByZW5ldyB0aW1iZXIgc3RlYWsgZmF0IGd1YXJkIG1vdGhlciBoYW5kIG5vdmVsIGN1cnZlIGxhdmEifQ=="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMTY1ejRqc3Nncjl5dXNuZXNwdjd2YXk1bjcyNmNoMnYwdHF6dTU1IiwiTW5lbW9uaWMiOiJ0dW5uZWwgaHVtb3IgbWltaWMgZ2F0ZSBwaWxsIGJyZWFkIHRpbnkgc21vb3RoIHRvcGljIHdpc2UgdHdpY2Ugc3VnZ2VzdCBzb3VsIGxpbWl0IGluY3JlYXNlIGFyZWEgb3JhbmdlIHNoZXJpZmYgcHVyc2UgaW5jb21lIGphZ3VhciB3aWZlIG9yZGluYXJ5IHZpb2xpbiJ9"), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMW12cHl1OTV6bndscnprdDV0ZTdhZXMyeXN5eGhmZHptN3hlbWVsIiwiTW5lbW9uaWMiOiJsYXJnZSBiYW5hbmEgZ3JhcGUgbW9ua2V5IHVwcGVyIGdpYW50IGFjdGlvbiBtdXR1YWwgdGhlb3J5IGJlbmVmaXQgaW5kaWNhdGUgdGF0dG9vIHVwZ3JhZGUgb3BlcmEgY2hhb3MgcGFyYWRlIHNvbWVvbmUgZWR1Y2F0ZSBoYW5kIG5vYmxlIGpva2UgcmViZWwgcmFjY29vbiBhcm0ifQ=="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMTcwbmFrYTVnd2swOG5xdzVqYXZtZ3A3c3VnMzUwMHMyM242ZzZmIiwiTW5lbW9uaWMiOiJlbGRlciByYXRlIGJ1c2luZXNzIGdvYXQgdGFuayBtYXR0ZXIgdXBncmFkZSByaW5nIHNob3ZlIGVjb25vbXkgYXJ0aXN0IGJhY2hlbG9yIGZsYXZvciBicmlzayBmYW1pbHkgdGVuIGJ1ZGR5IHJvYm90IHJlcXVpcmUgYWRhcHQgc3VjaCBzYWQgc2libGluZyBwaXN0b2wifQ=="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMTlxcW5yNWE1M2R2azBodGgyNGRobjVhYXMwdm53bHpwbnZyNm1oIiwiTW5lbW9uaWMiOiJrYW5nYXJvbyBsaWNlbnNlIGdvb2Qgb3ZlciBxdWVzdGlvbiBzY3JhcCBhY3Jvc3MgZGVjb3JhdGUgZnJlc2ggaGFtbWVyIG1lcmdlIGNvbmZpcm0gZm9sZCB1bmFibGUgY3JhbSBzcXVlZXplIHN1cHBseSBiaXJ0aCBob3JzZSBkZXRhaWwgd2F2ZSBsaW1pdCBpbmNsdWRlIGhhaXIifQ=="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMTJnN2Z6OWV2YWE4OGd2Nm1nNHA3dmM3Y2hzaGh3Nmg1NmRyM25lIiwiTW5lbW9uaWMiOiJ3aWRlIGJhdHRsZSBsZW9wYXJkIGxlbmQgcmFpbCBkaXZlcnQgZm9nIG9ycGhhbiBvY2VhbiBlbmZvcmNlIHRydWUgY29tcGFueSBkcmF3IGVuam95IHRoYXQgY29yYWwgYmxvdXNlIGZyb250IHNwb25zb3IgY29udHJvbCBjb2xvciB0b3JuYWRvIHBpbmsgYWRhcHQifQ=="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMTZ3cXgwNHJqdmEzdjh4NWYzdnZtbXlwOW1mOHkzajJ1bDk3NmZhIiwiTW5lbW9uaWMiOiJncmllZiBhY3R1YWwgaW5wdXQgYmVsdCBicmFpbiB3aW5nIGp1bmsgeW91bmcgZ2VuaXVzIHBhcmsgY2lnYXIgaHVyZGxlIGxlYWRlciBkZWNlbWJlciB0d2VsdmUgbWl4dHVyZSBjb252aW5jZSB1bmZhaXIgZmxhZyBzY3JpcHQgY2hhb3Mgc3dvcmQgbWlkZGxlIGplbGx5In0="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMWFjMm52eHZ4aHhkaDlrc3U1M2VxdzQzMzg3emM0ajNjNHhrdW52IiwiTW5lbW9uaWMiOiJhbWF6aW5nIGh1bmdyeSBkdXN0IGVycm9yIHNjcnViIG1vcmFsIHdhdGVyIG9idGFpbiBib251cyBwdW5jaCBjbGVyayBicm9jY29saSBwcm91ZCBqdXN0IGNydWlzZSB0dXJrZXkgaWRsZSB0dW5uZWwgc2FsYWQgd2luZG93IHJlbnQgc3RvdmUgc2hhbGxvdyBydWcifQ=="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMXN2eXQ4OGtrYXNkM213ZnhmcWFnbnk0c21oeHA5a2g0Y2FncjAwIiwiTW5lbW9uaWMiOiJyZWFkeSBsaXF1aWQgbW9ua2V5IGluZG9vciBjYWJiYWdlIHRyb3BoeSBidXJkZW4gcGxheSBhbmdsZSByZXZpZXcgdW5sb2NrIGhhaXIgcGFyZW50IGhhcmQgaGFsZiBuZWdhdGl2ZSBwZXJtaXQgcmVndWxhciB0cmFkZSBmcm9zdCBsYWR5IGZ1cnkgcmVndWxhciBzcXVhcmUifQ=="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMXZocWNobTlkNnBybWU1enFsdHlzODYwZ3I3YWNka2RodGtnNnJhIiwiTW5lbW9uaWMiOiJpbnF1aXJ5IGxpYXIgaW1pdGF0ZSBzY2FuIHByZXBhcmUgc3RhdGUgZmluZSBjdXJyZW50IHZpcnVzIHBheW1lbnQgc2hvdmUgbm9ybWFsIGRvdWJsZSB2YXVsdCB0cmF5IGhlYWx0aCByZXNwb25zZSB3YXZlIHJlbmRlciByaXZlciBmbGF0IHNraXJ0IGxlY3R1cmUgdGVuYW50In0="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMWxkcTVrbHhjNmw1cjl5Mnc2NXJ2OGdrbmV4YXNkbjBmZzJwemxtIiwiTW5lbW9uaWMiOiJhZGQgaG9ja2V5IGJvb3N0IGNoYXQgc2lsZW50IGVyb2RlIGZsYW1lIGJhdHRsZSBwdXp6bGUgcm91Z2ggc2VjdGlvbiBiZWVmIGxpZ2h0IGZpbmQgcm91dGUgcmFiYml0IHZvaWQgYXJtZWQgbW9yYWwgcmlvdCBjaGFtcGlvbiBkcmlsbCBoYXphcmQgYm9vc3QifQ=="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMWR0ZTA4aHNueWowcmt6em1mcnk4ZXplYWFkcGVkeHQ3eTg1N3c2IiwiTW5lbW9uaWMiOiJoaWRkZW4gc3BhcmUgbW90aW9uIG5pZ2h0IGZhdCB0ZW4gb2J2aW91cyBwdXp6bGUgYWRkcmVzcyBtZWxvZHkgamFja2V0IGVsc2UgaW5mbGljdCBhYmlsaXR5IGtleSB2YWxsZXkgZHJlc3MgcG93ZXIgbXVzaWMgYXdmdWwgc29vbiB1bmRlciBzb3VsIGFybW9yIn0="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMTM4dnIwY3hqcHhsbGs1YXVhdWM0Z3V3eGxseWd0MzczOG1jcTBwIiwiTW5lbW9uaWMiOiJ0cmFwIGNvdXNpbiBzaGFsbG93IGZpcnN0IHJveWFsIHRvZ2V0aGVyIHZpYWJsZSBiYW1ib28gYm9tYiBvY3RvYmVyIHZhY2FudCBjYW1wIGZyYW1lIGRpc2FncmVlIGN1cCBjaHVja2xlIHN5bWJvbCBtYXRlcmlhbCBhdWd1c3QgYmVzdCBtYW5hZ2Ugcm9vZiBmbGF2b3IgaW5zaWRlIn0="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMXIwcDB4eTA3dXhmNngzcDNrZ25yeGN3bjdjNjczY3hlZzJtc240IiwiTW5lbW9uaWMiOiJpZ25vcmUgdG9hc3QgcmluZyBob21lIGFoZWFkIGRlY2VtYmVyIGJpY3ljbGUgbW91c2UgZ2VudGxlIGZsb2F0IG5hbWUgZW1iYXJrIGxhcmdlIGNodXJuIGVtYnJhY2Ugc3dhbXAgZnVybmFjZSBjcmFkbGUgcHVwcHkgYW5jaWVudCBub3NlIGRlc3Ryb3kgb3JkZXIgdmVoaWNsZSJ9"), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMW13MjlueXVndWFsNjd5d3E5c2N1NGMzNXZuaHdtcG1zampwNW5hIiwiTW5lbW9uaWMiOiJkYW5nZXIgd2ViIGxlbmQgZXJhc2UgaWdub3JlIHRyYWZmaWMgZGV2b3RlIGtuaWZlIGRvY3VtZW50IHNsZWVwIGludm9sdmUgdHJpcCB3aW5lIHNvbmcgZmVhdHVyZSBtYXJpbmUgbWlzZXJ5IGFyZWEgY2FuZHkgcmFkYXIgYm9tYiBkZXN0cm95IHJlbWVtYmVyIHNpdHVhdGUifQ=="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMWs3dzNkbWdrdG1oc3kwa2xoeTlhazBqcjQ1ajdoMzNra3B5anZ4IiwiTW5lbW9uaWMiOiJtZW50aW9uIGp1bXAgaWRlbnRpZnkgY2FwaXRhbCBtZW51IGNvcm4gY2FuY2VsIHJvYWQgZXF1aXAgZW5kb3JzZSB3aW4gYnVyZGVuIGZvc3RlciBsb3ZlIGNsZXJrIHByb2R1Y2UgZ3JlYXQgdGhlcmUgZ2FsYXh5IGRvbmtleSBzZW50ZW5jZSB0cnVjayBqb3VybmV5IHJvdXRlIn0="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMWQ2cWpqZTlzc3c0cTN6dzkzM3g5OXhkZTZrMzQ4bmx6cHcybThoIiwiTW5lbW9uaWMiOiJjeWNsZSBzdHVtYmxlIGRheSByZXNpc3QgYnVpbGQgY290dG9uIHZlcmIgcG93ZGVyIGFjY291bnQgdml0YWwgdmlicmFudCBzaW1pbGFyIGZhbWlseSBhZmZvcmQgc2FtZSBtdXR1YWwgcGVsaWNhbiBiYW5hbmEgYnJvdGhlciByb3VnaCBiYXJlbHkgaXNsYW5kIGF3ZXNvbWUgbHVuYXIifQ=="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMW5xcWZmd2xnZ3YyZzR3dWFzenU1M3QycWZjd3E5cHZlNHBtdTRjIiwiTW5lbW9uaWMiOiJwYXRpZW50IHNtYWxsIG11dHVhbCBhcmVuYSBmZXcgYm91bmNlIHRvbmUgYXV0aG9yIGJyb29tIGx5cmljcyBiZWdpbiByZXBhaXIgbWV0aG9kIGJyb256ZSBob3RlbCBwbGF0ZSB3aW50ZXIgZHdhcmYgaGFyYm9yIGNhZ2Ugc3Rvb2wgc25pZmYgc29hcCBleGNsdWRlIn0="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMWprMHVyaGRsYWF0enJwZjJzY3l3MmhjeHN5eGVyeHAyazV5ODlnIiwiTW5lbW9uaWMiOiJtaW5kIG1hbmRhdGUgYXNzYXVsdCB0ZXJtIGdsb29tIGJsYWRlIGNodXJuIHZlcmlmeSBicmlkZ2UgZ3JhbnQgYWhlYWQgZGljZSBqZWFucyBib3kgcGljdHVyZSBiaXJ0aCBleHBlY3QgaHVycnkgc2NhbGUgb2JzZXJ2ZSB0aHJlZSBhbG9uZSBtaXggdmVsdmV0In0="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMXd5d3Y5OTh5emxqcXZmNzNkMGVncm5qejVzdTZubGh1enFrM3plIiwiTW5lbW9uaWMiOiJ0dXJuIGVuZm9yY2UgZmFjZSBtdWNoIHV0aWxpdHkgcGF0aWVudCBhcnQgYnJvd24gYm94IHVwc2V0IGxhYm9yIGVuZG9yc2UgdGFnIGVhcnRoIG9mZmljZSBsb3VuZ2UgZGl2b3JjZSBiYXNlIGdsYXJlIGx1bWJlciB0b2UgdG93biBwaXRjaCBzaXN0ZXIifQ=="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMXBoeXhnaGN4NGZ5bnZydDR5NG52eW5kenhoMGRyOWZ4N3NrNXA3IiwiTW5lbW9uaWMiOiJyaXZhbCB0d28gbWFyZ2luIGh1bnQgYnVkZ2V0IHdhaXQgdHJpYmUgc3VubnkgcGlnZW9uIHB1bHAgc2hvb3QgdHJlYXQga2V5IGRpc2FncmVlIHVtYnJlbGxhIG9yaWVudCBuYXR1cmUgdG9tb3Jyb3cgbGVjdHVyZSBsb2dpYyByYW5jaCBzaGFmdCBmb3NzaWwgY2FuY2VsIn0="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMW5kejRsNHN1OWRjcWVxcjd1eDR3enJzY3c0dmVoZ2hxNXo4cnBoIiwiTW5lbW9uaWMiOiJ0aW1iZXIgdGVuYW50IHNpbmcgbHVuY2ggc2VlZCBiZWx0IGxldHRlciBydWxlIHNjYXR0ZXIgZmFsc2Ugcm90YXRlIGl0ZW0gY2xldmVyIHNsaWdodCBmaWx0ZXIgZmVlIHRyeSBibG9zc29tIGZsb2NrIGdyZWVuIHVudXN1YWwgbmV0IHNuYXAgYXdmdWwifQ=="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMWd5dGt5aDJoZHk0YzNqNzJxZGRrMjNjNmNsenV4emszMHRlY3ByIiwiTW5lbW9uaWMiOiJoYXZlIGxhbmd1YWdlIGhvcGUgY2hvaWNlIGZlZGVyYWwgYmljeWNsZSBxdWl0IGFsbGV5IHBhcmsgcGxlZGdlIHJlcG9ydCBhbm51YWwgc2hydWcgaG9yc2UgYWNjZXNzIGZvcnVtIGJsdWUgc29mdCBtaWRuaWdodCBsYXRpbiB3aWZlIGh1cnJ5IGVyb3Npb24gc2VnbWVudCJ9"), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMTVxeXdzOGx2eWRrandsN2VtM2c2ODVjcXZzMGU4amE5NmNjdXRkIiwiTW5lbW9uaWMiOiJub3RhYmxlIGlsbCBkcmFtYSBsdW5jaCBmb3JjZSBib21iIG1hcmdpbiBpZGxlIGZpbmUgdGFzdGUgZGlzaCBub3RhYmxlIHB1c2ggZXhpdCBhaXJwb3J0IGNhc2lubyBzY2hvb2wgY2FnZSBzdHVtYmxlIHRvd24ga2lkIHN1cHJlbWUgYWxhcm0gdGhleSJ9"), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMWN0NDV6a3RnNDd2a3I3a3lyNmVlNG54eWdndzU1c3R4c3ZkN2E5IiwiTW5lbW9uaWMiOiJldmlkZW5jZSBqb2luIHJhdGUgdW5rbm93biBzcG90IHNob2Ugd2hpc3BlciBzZWVkIGNpdmlsIG1haWQgbmVydmUgZG9ub3IgYmFsY29ueSBjcm91Y2ggc29jY2VyIG9rYXkgb2ZmZXIgamVsbHkgYWdlbnQgY3Jhd2wgY2FudmFzIGVsZGVyIHNhbmQgZGF1Z2h0ZXIifQ=="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMXh5bGEzbjNtY2RnOGdmbHJ4dmR3cG1ycDlhYWQ1eGZmcTY4eDY3IiwiTW5lbW9uaWMiOiJzb29uIGdvc3BlbCBmcmFnaWxlIHNhbG1vbiBnb29kIGVjaG8gcGFycm90IGRpbGVtbWEgc3BhcmUgZmF0aWd1ZSB0d2luIGVzY2FwZSBwYW50aGVyIHRyaXAgZXh0ZW5kIGVuYWN0IGJlYW4gbGVnYWwgYmlydGggY29uZmlybSBlbXBsb3kgY29sbGVjdCBtZWRhbCB2aXRhbCJ9"), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMXNrN2N1YWhxemd2aGRqdWE5djZhcW43eHBkc2c5azVqcWw2ZGx2IiwiTW5lbW9uaWMiOiJwcmlzb24gY2VudHVyeSBwdWRkaW5nIGZyaW5nZSBwcm9maXQgYWxwaGEgZGV2aWNlIGxvY2sgZW1wdHkgYWJvdXQgY3J5IG96b25lIGZlYXR1cmUgdmlvbGluIHlvdXRoIGRlY2lkZSByYXZlbiBkaXNwbGF5IHRhbGVudCB1c2FnZSBsb25lbHkgaGludCBoYWlyIHZpbnRhZ2UifQ=="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMWw4dXYydXRkZXJmNDczYW14Zno3bGw1djBlNWpnbWtqaGc5MHJyIiwiTW5lbW9uaWMiOiJ2b2lkIHNpYmxpbmcgd2FybSBmZWJydWFyeSBiaWN5Y2xlIGJlaGF2ZSBydXJhbCBjaHJvbmljIGNoZXJyeSBmYW1lIGRpc29yZGVyIHN3aXRjaCBicm93biBzYW1lIGNsaWVudCBnb29zZSBkcmlmdCB0b3NzIGFyZWEgcGVybWl0IGRlY3JlYXNlIHJpdHVhbCBpbmhhbGUgYmlydGgifQ=="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMWhncXduZzM4MGdka25xdHcza2ZyOXRweXE4em5ldHVrcWdrbTBoIiwiTW5lbW9uaWMiOiJ2aWN0b3J5IHdvcnRoIHllYXIgcmVkdWNlIGxlYWRlciBleGl0IHJhcGlkIHRydWNrIHNjYW4gbWl4ZWQgbGltaXQgbWFyaW5lIGluc3BpcmUgdGVzdCB3b3J0aCByZXBhaXIgY29tbW9uIHNpbWlsYXIgZ2hvc3QgY29uZ3Jlc3Mgc2NhcmUgZmluZ2VyIGFyY3RpYyBkb3NlIn0="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMTNkcW05M2poZDI5anJqdjl6eWFxOGtteTk2d3RqcXgycDh5ZnltIiwiTW5lbW9uaWMiOiJzaG92ZSBwcm92aWRlIG1lYXN1cmUgbGVhZiBkb25vciBnb3Zlcm4gcmViZWwgcmV0aXJlIGNvcHkgb25jZSBuYXN0eSBzdWJqZWN0IHNldHRsZSBjcnkgZmF2b3JpdGUgd2VhciBkaXNtaXNzIGFzdGhtYSBrZWVwIGZpbmFsIG1vZGVsIHRyaWdnZXIgbGF0ZXIgYmFycmVsIn0="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMXBjN2x3am5rejlrZnNsdmZyOHJrOTk0amh6dmowMDIyeXpoazU1IiwiTW5lbW9uaWMiOiJzbGlnaHQgbGFiIGNyZXcgZGVmZW5zZSBjb2FjaCB1cG9uIGZhY3VsdHkgYXJlYSB3b2xmIGV4cGxhaW4gbWFudWFsIGdvcmlsbGEgbW9uc3RlciBmbGlwIGV4YWN0IGR1c3QgYmxvb2QgdG95IHBsYXRlIHNhbG1vbiBkaXJlY3QgYWdlIGJ1bGIgdG9uZSJ9"), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMWY5c3IyN3Frajk4ZTJ5bXB2MHhjZDJ1Zmsyd2VqbGRsZnpmNHc3IiwiTW5lbW9uaWMiOiJjYW1wIGdhdGUgZ2lhbnQgbWFjaGluZSBwdW1wa2luIHNpYmxpbmcgaHViIHVuaWZvcm0gbGljZW5zZSB1bmRlciBjdXJ2ZSBsYW5ndWFnZSBkZXBhcnQgYXNzdW1lIGFtYXRldXIgZ3JvdyBkaWFsIG11dHVhbCByaWIgdm95YWdlIGdvZGRlc3MgY3JlZWsgYXNrIGNhc2gifQ=="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMXkwOWM0cmhndDJybWxjenhld2c3eTQ4cmp4aG1qZXM2NTc3dmRzIiwiTW5lbW9uaWMiOiJweXJhbWlkIHJlbmV3IGlsbCBzdG9jayBtYXJibGUgbnV0IGdvcmlsbGEgZGlydCBleGhhdXN0IHNoYWRvdyBjb3JuIGdvc3BlbCBpbnNpZGUgbnVyc2UgZWFydGggZm9vZCBwYXRoIGJ1eWVyIHNhdG9zaGkgY3JhZGxlIHBpZ2VvbiBsZWFmIHNlYXNvbiBzY3J1YiJ9"), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMTk0ZHZmN2F4ZjB4MnB1cG01ZXh0ejIyd242dWtmNGZrNWozZGhnIiwiTW5lbW9uaWMiOiJ0b3VyaXN0IHVuaWZvcm0gc2tpIHN1cnZleSBpbm5vY2VudCBvYmxpZ2UgZm9yY2UgYmVjb21lIGFjcXVpcmUgcmVtYWluIG11c2hyb29tIGJhbGNvbnkgY2hhcmdlIG1hc3RlciBjaGVlc2UgZW1wbG95IHJpZGUgYmFyIHJvYnVzdCB0aW1iZXIgc29jayB0b3VyaXN0IHVwcGVyIHJlc2lzdCJ9"), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMTQ1dTV3bnZnNXlzd3hqcmx1bXhsbmpjaDJxZndyMjUyem1yZGVqIiwiTW5lbW9uaWMiOiJiZXR3ZWVuIHRyYW5zZmVyIGxpZmUgcm91Z2ggc3RvY2sgaW5oZXJpdCBvdXRlciBza2F0ZSBhbmNpZW50IHRoZXkgYmluZCBjdWJlIG92ZXIgbXlzZWxmIHJlY3ljbGUgc2Vzc2lvbiB2ZW50dXJlIGJvaWwgZW1wdHkgbG9jayBicmVhZCBleHBsYWluIGFyZ3VlIG1hZCJ9"), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMWw1bHE1dTh6emc0Z2dyc2Y5ZmdxbDJsODBscjhxYWRmY3F5MGFuIiwiTW5lbW9uaWMiOiJweXJhbWlkIGd1biB2YXBvciBkZXBlbmQgcHVtcGtpbiBwZW4gY3JlZWsga2V0Y2h1cCBjYWxsIGJvb3N0IGNhcGFibGUgbmFwa2luIGF1ZGl0IGFtdXNlZCBzb2x1dGlvbiBsaXR0bGUgbWFwbGUgb2NlYW4gaGlsbCBsb29wIGxpbmsgZ2FsbGVyeSBib3ggc3RlcCJ9"), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMWFkbXdkMjQzbmo0Zmo1MGZsOHcyY2hqdnZucjZqbmduMno5NHkwIiwiTW5lbW9uaWMiOiJsZWdhbCBoZWFydCBva2F5IGFpcnBvcnQgYWdlIGhlZGdlaG9nIHNsZWVwIHJlcGVhdCBhY2N1c2Ugc3ltcHRvbSBmb3N0ZXIgYmluZCBkcmlsbCBjcnVtYmxlIGVmZm9ydCBmbG9jayBtYXJibGUgY3Jvd2QgZ3J1bnQgZ3JhYiBvcmlnaW5hbCBlc3RhdGUgYWRkcmVzcyBwdXNoIn0="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMTh5eGo2M3kwdXhtM2U5dzl4ZGE0cGxodzAyZnU4MDA1M2FtenU5IiwiTW5lbW9uaWMiOiJtZW50aW9uIHBsYXkgYmF0dGxlIGxveWFsIHVuZm9sZCBmb3VuZCBjZW50dXJ5IGVuZCBjb21lIGNsdXRjaCB3YWxsIHdvb2QgZW5yaWNoIGVxdWlwIGFybW9yIGJvbnVzIGhlbiB2aWRlbyBtb3JhbCBkb2xsIGFuZ2VyIHNraXJ0IHNvZGEgc2F2ZSJ9"), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMTczZHQydTdnOW1udWU4amZnamN3ZzZucXA2NjJsdTRjNm0zcHlsIiwiTW5lbW9uaWMiOiJjb25kdWN0IGludGFjdCBhaXNsZSBjaGFvcyBxdWFsaXR5IHRoZW9yeSBjaHVuayBqdWljZSBjcnVpc2UgZmVlIHJpcHBsZSBsaW1pdCBnYXVnZSBmb3Jlc3QgY2hhbmdlIHNhdXNhZ2UgZXh0cmEgYWxwaGEgdXNhZ2UgZXhvdGljIGRyaWZ0IGJyYXNzIGdvcmlsbGEgdGFzdGUifQ=="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMXBsenR3Z3Qzc2c1dmszbHNtbGtsOTV1cmw1ZDR0bGd4Y3RkZGU5IiwiTW5lbW9uaWMiOiJvYmplY3QgYmFyIGNhbG0gbXl0aCBmZWUgdG9vbCBmaW5nZXIganVuZ2xlIHNpbXBsZSBiYWcgem9uZSBjaGFzZSBzY2hvb2wgYmVuY2ggYmVsdCB0aW1lIHdlYXRoZXIgZXhwcmVzcyBhZmZhaXIgc2NpZW5jZSB2ZXJiIHJlY29yZCBpbnRhY3QgZGFyaW5nIn0="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMWhsZDhrYTBxaDY3ZjJuNWV4bXplY3RlNjRhd3VkNTNkMGY3bnhhIiwiTW5lbW9uaWMiOiJob2xpZGF5IGxpdHRsZSBwb2xhciBzdWRkZW4gY29uZmlybSBzb25nIGRpYW1vbmQgcHJpZGUganVzdCBkb3ZlIG5vYmxlIGZhdm9yaXRlIGNlbnR1cnkgcnVyYWwgZmFpbnQgYWxpZW4gYWN0dWFsIGhvbGUgZHJpZnQgcG9vbCBhcnJhbmdlIGFscGhhIGJvdHRvbSBlbnRyeSJ9"), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMXc2YzBleW56Zm5zd2RhNXpnOHRta3hrem1sbjNkZHY3cGd5enZ0IiwiTW5lbW9uaWMiOiJ0b25pZ2h0IGZpbGUgZGVmZW5zZSByZW5ldyBjb2lsIHVuY2xlIHBpZyBub2lzZSBibHVyIGVsc2UgZ2xvdmUgcmVtYWluIHJ1ZyBjdXJ0YWluIGNvbmZpcm0gb3JkaW5hcnkgYnVpbGQgY3J1c2ggY2FyZCBsZWF2ZSBmbGF0IGp1bmlvciBkZWJhdGUgd2F0ZXIifQ=="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMWxybTB1dXM5Mzdxeng4Y3hnNXNmNWo5Z2VnanFmd3B6dHAydWd6IiwiTW5lbW9uaWMiOiJzdGF0ZSBvcmNoYXJkIGZ1biBlY29ub215IGxhZGRlciBvY2VhbiBmb3ggYm95IGN1cmlvdXMgYWxidW0gdGVzdCBzdGFpcnMgcG9ldCBlaWdodCBiZXN0IHN0cmVldCBhdXRob3Igc3Bpa2UgdGlueSBmYW4gc2F1c2FnZSBub3RhYmxlIGNydW5jaCBzaG9ydCJ9"), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMTNobDdteGN0Y3QyZ2w2cDlnZTc2c2VjZDBtNG14dmp4ZGZmdWQ4IiwiTW5lbW9uaWMiOiJidWxsZXQgZ2lybCBtYXNrIHNhdXNhZ2UgdHJvdWJsZSBhZmZhaXIgcHJlc2VudCBvdmVuIGRpZXNlbCBlcm9zaW9uIHByb2dyYW0gY2hpbW5leSBsYXB0b3AgcGhvbmUgc291cmNlIGh5YnJpZCBidWJibGUgc2hpbmUgaGludCBzdXJ2ZXkgdG9ydG9pc2UgdmF1bHQgcGlhbm8gdGVuYW50In0="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMTI2M2ZkbjQ0dnQwcjBzeWN0MGh1NXMzeTZmeTVsYzIycWN6ZHNyIiwiTW5lbW9uaWMiOiJwYXRjaCBhbmltYWwgZGVicmlzIGltbXVuZSBhcmVhIGRvY3RvciB1dGlsaXR5IHJpYmJvbiByZXZpZXcga2l0dGVuIHByb2dyYW0gY2l0aXplbiBtb3RoZXIgYWxtb3N0IGRlZmluZSB3aGVlbCBhYm92ZSB5ZWxsb3cgdHVpdGlvbiBpZGxlIG1vcmFsIG91dGRvb3Igc3B5IHdpbGwifQ=="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMTQ4a2NhamY1dzZnZW04dmE5dmhncDl5Nmxxa3JmdXN2Z3Zqc2R6IiwiTW5lbW9uaWMiOiJtYXRyaXggYnVkZ2V0IGNsYWltIHJldGlyZSBnb2xkIGluc3RhbGwgdHJhdmVsIHN0dW1ibGUgbGF0ZXIgcmVzb3VyY2UgY3Jpc3AgY2xhcmlmeSBza2F0ZSB0b3Agc3BvcnQgZ2VucmUgbWFuYWdlIHNvYXAgZnVuIHRyaWdnZXIgZmluZ2VyIGJvcmRlciByZWFkeSBmb3JjZSJ9"), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMWRlY3M1bHY3OHV0a2V5aHUzc2h6N3cyaGd2MDhmOXk1dm03M2V4IiwiTW5lbW9uaWMiOiJwb29sIHNtYXJ0IGNpZ2FyIG1ldGhvZCBkaXp6eSB0YWxrIG1hbmdvIGJpbmQgd29vbCBicmFja2V0IGZpeCBlYXJseSBwZWFyIGVudmVsb3BlIGFlcm9iaWMgZXZva2UgdHJpZ2dlciBpbmNvbWUgbXlzZWxmIGhlbiBiaXJkIHBvc2l0aW9uIGhvbmV5IGFtb25nIn0="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMTJ2cXR0dmo5eDAwZW1kYXJxODk2eXJmMmFwYXN4Z3prZnJqOHJmIiwiTW5lbW9uaWMiOiJhZG1pdCB1c2FnZSBjb21wYW55IHJlY2VpdmUgcGF0dGVybiBjcnVlbCBzdW5ueSBuZWVkIGltcHJvdmUgbWlub3IgZGFuY2UgZXNzZW5jZSBzaGFsbG93IGVhcnRoIGlucXVpcnkgbm9vZGxlIGtuZWUgcmVzaXN0IGNvbWJpbmUgdm9pY2Ugc25ha2UgZGl6enkgbWFuIHBpYW5vIn0="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMWdkczR5NzRka3owY2pwdWRuZHM2MDY1Zzl4Mng4NHpxbmo2OWNjIiwiTW5lbW9uaWMiOiJ0b2RheSBxdWFydGVyIGludGFjdCBoZWFydCBtb3VzZSBncm91cCBleGN1c2UgbmVhciBmaWxtIHNob2Uga25vdyBjb21pYyB0cm9waHkgcmFpc2UgZm9zdGVyIHN1Z2dlc3QgbWF4aW11bSBvY3RvYmVyIGRpcnQgYXJteSBjdXJ0YWluIGVydXB0IGF0dGVuZCBmb2cifQ=="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMTVmdHZyNWV0dXRocHN0aHJyOWN0M3I0NWFwZ3dqN2tncmM4eGRkIiwiTW5lbW9uaWMiOiJ0aGFuayBmbHkgZGl2b3JjZSBzaHJpbXAgbGFrZSBzaWxrIGd1YXJkIHN5c3RlbSBjYXJ0IGVtYnJhY2UgZWRpdCBwYXBlciB0aWx0IHJpc2sgYmV0dGVyIG1vdG9yIHRvcnRvaXNlIGFjcXVpcmUgZWNobyBmb29kIG9yZGVyIG1hbW1hbCB0d2VsdmUgdm9pY2UifQ=="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMW4wMDhycGt5aHlyZHA5c2Z2ZDYyd3p0cHhseXU0eGc5YTVnanR2IiwiTW5lbW9uaWMiOiJjYXNlIGxlc3NvbiBzdXJmYWNlIHNjaXNzb3JzIGNpdmlsIHNvcnJ5IG5lc3QgZXRoaWNzIG1lc3NhZ2UgaG9ybiBhZmZhaXIgZGVtaXNlIGJsb3Nzb20gbXVmZmluIGRyaWZ0IGZhbWUgYmluZCBzaGFyZSBtaWRkbGUgc3BvbnNvciBkZW55IHByZXBhcmUgbGlnaHQgc2hpZnQifQ=="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMXhkdXc0YWFuanNteXIzZ2s4OGt2OXVjNHA4eG1lbGQzcWxsOXJxIiwiTW5lbW9uaWMiOiJydWRlIGJhc2tldCB0dXJrZXkgZWFybiBpbnNpZGUgYmVjb21lIGF3YWtlIG1vdmUgbGF5ZXIgYmFycmVsIHBlbmNpbCB1bmRvIGxhYm9yIGF2ZXJhZ2UgZHVuZSBjaGFuZ2UgYmFyZ2FpbiBwcmV0dHkgbGl0dGxlIGx1Y2t5IHN1aXQgcmVnaW9uIG1lbW9yeSBsYXp5In0="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMTU4NXA1ZzMyeHZ5N21weDA3eGhkeWF3NHZnZXN2YzRjZ3l5dThsIiwiTW5lbW9uaWMiOiJwYXRjaCB1bmxvY2sgdGhlcmUgY29weSBzaWxlbnQgcmVhZHkgcHVuY2ggdmVyYiBhZ2VudCBpbnZlc3QgbXl0aCByZXZlYWwgZHVuZSBsb25nIGNoaWxkIHN1bnNldCBrbmlmZSBzbWlsZSBtYWQgcm9vbSBtZXJjeSBhdWd1c3QgZ3JhY2UgcmVzb3VyY2UifQ=="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMXprNWtkNXA2Z2xlOHJsdzVqZ2huaDh2aHI2ZWNuYXdqbXpucHN3IiwiTW5lbW9uaWMiOiJlY2hvIHdpc2UgY2hhdCBkb2xwaGluIGhhcHB5IG5leHQgdGltZSBmaWN0aW9uIGlkbGUgZmxhdCBwcm9maXQgYXJyb3cgZGlmZmVyIGJlaGF2ZSB0YXN0ZSBmbGlwIGNyb3AgZ2xhbmNlIGNvbmdyZXNzIGZldGNoIGNhcnBldCBzcGljZSBzdGVyZW8gZXZpZGVuY2UifQ=="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMWY0MDU0azYwZjY5eXVtZnh6ZWc5dmNlbTRzeTByZWQ2cTRza2R5IiwiTW5lbW9uaWMiOiJqYXp6IG5hbWUgYmx1ZSBhbGJ1bSBhc3NldCBjaW5uYW1vbiBwZW5hbHR5IHJ1cmFsIG1hcGxlIGhlYWx0aCBzaWxseSBmbG9hdCBob3Jyb3Iga25pZmUgY2FuYWwgY3ViZSB3aGF0IHRvcHBsZSBlbXB0eSBqZWFucyBzcGhlcmUgYWdyZWUgYmxpbmQgdHJheSJ9"), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMTMwcjNwNG1nOWg1Z3FnanZ5d2hyazh3MDMwOXdkZzl6MmR1Z3ByIiwiTW5lbW9uaWMiOiJjb2FjaCBzZWdtZW50IHBhcnJvdCB1cmJhbiBjbG9jayBleHByZXNzIGp1ZGdlIGRhbWFnZSB2b3lhZ2Ugd2VhciByb3VnaCBoZWFydCBsaXF1aWQgZ3J1bnQgc29jY2VyIHBvaW50IGlkbGUgdGlkZSBzYXRvc2hpIGdpcmwgYmFnIG1hY2hpbmUgaW1wb3NlIGJyb3RoZXIifQ=="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMXdnNWdjZHg0ZTRoemRwenpkajNuM2hneTNqZHlkbDI1ZGFrbWVlIiwiTW5lbW9uaWMiOiJrbmVlIGNyaXRpYyBwcm92aWRlIGRvZyBvc3RyaWNoIGxhd3N1aXQgYm9uZSBzbWFydCBwcm9qZWN0IGluZGV4IGZhaW50IHNwb2lsIGRlY3JlYXNlIGV4aWxlIGNhdHRsZSBodXJ0IGJsYW5rZXQgYXJ0d29yayBkcnVtIHdhZ29uIHNvdXRoIHVwb24gb3JiaXQgcGhvbmUifQ=="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMTVnZjNnZTZ5cW55cjJneHRyNHo3dXI3dnpuN3NsNzZ2NnB0NTJ1IiwiTW5lbW9uaWMiOiJjdXAgY291bnRyeSB0cnVtcGV0IGFjdCBhc3RobWEgdXBwZXIgaW5wdXQgd2FsbnV0IGZsYWcgcHJhY3RpY2Ugc3RhYmxlIGN1dGUgbWlsbGlvbiBmaWd1cmUgbGFkeSBkaXJ0IHNoYXJlIHByZXZlbnQgb2ZmIGFkanVzdCBzdGluZyB0b3JuYWRvIGd1biBqdW5nbGUifQ=="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMXE4c214aDRtY3BlcDNucWE0bHMyd2p3eXlxOXo3cmdhemhxZ2c1IiwiTW5lbW9uaWMiOiJlY2hvIGJhc2UgY2FiYmFnZSBleGhpYml0IGluamVjdCBpY2UgY3JlZGl0IGhhdCBzdGVhayB3YXJmYXJlIGRlc2lnbiBqZXdlbCBjaHVuayBzdGVlbCB1bmRvIGVucmljaCBrZXRjaHVwIHNpeCB0aG91Z2h0IGplYW5zIG11c2V1bSBzZWN1cml0eSBlbGJvdyByb29mIn0="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMTk3ZHhmNzMyd3c1M2RwdXl4em4wcThjZ3d0Z3ZmeHZ1dnprZGw3IiwiTW5lbW9uaWMiOiJwaWxvdCBhYmFuZG9uIG11c3QgcmFpbiBkZXNrIGdsb3cgd29ycnkgc2VtaW5hciBncmFpbiByaHl0aG0gZGF3biBsaXF1aWQgd2lsZCBlbm91Z2ggZm9zdGVyIGVuam95IHdyZXN0bGUgZXllYnJvdyBpbnZlc3QgcmVsYXggYmFyIHByb3VkIHN1YmplY3Qgc3R1ZGVudCJ9"), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMTJnOGQ2dnhnbXNybGd4bXZqeHI2Y2R6dTdqYzQ0aG11dXptNTBmIiwiTW5lbW9uaWMiOiJjbGVhbiBub21pbmVlIHByb29mIGJvbWIga2lkbmV5IHByb2JsZW0gd2lsZCBpc29sYXRlIGhhcmQgYmljeWNsZSBzdXJ2ZXkgbm93IHJlZ3VsYXIgZGlyZWN0IHN1bm55IGNvbmdyZXNzIGFibGUgam91cm5leSBwb3dkZXIgZmF1bHQgbW90aW9uIHRhY2tsZSB2aXZpZCBqb3VybmV5In0="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMTJsNGVzcGFsZ3NxZTk4czRzMnd4dmdhY3BhaDNyMnRxZTNneXF4IiwiTW5lbW9uaWMiOiJjbG9nIGxhYiBkb3VibGUgc2VjdGlvbiBkaXp6eSBicmFpbiBpbnRhY3QgZGV2ZWxvcCBtb2RpZnkgaGVkZ2Vob2cgdG93ZXIgc2x1c2ggY2F1Z2h0IGRpdmlkZSBzcGFjZSBsaXR0bGUgdGFzayB0ZXJtIGF0dHJhY3QgbWlkZGxlIHNoaWZ0IGNsdWIgY3VsdHVyZSBodW1hbiJ9"), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMXgwYXlwYW10ZjN5bjRmbHQ2NjN2dmN0Zmd4d24yZnRucWozM2dzIiwiTW5lbW9uaWMiOiJiYWJ5IGJvcmluZyB3YWdlIHF1YWxpdHkgY2xpbmljIHNpZGUgYWZyYWlkIGtpbmQgd2FsbCBpbm5vY2VudCBzdGluZyBpZGVudGlmeSBjdWJlIG5pY2Ugc2xlZXAgcmFuZ2UgZmVlZCBjYXNpbm8gc3R1bWJsZSB1c2VmdWwgZWRpdCBob3N0IGZyb3N0IGJsaW5kIn0="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMWVtZ2ZjZWM4N3o1dXV0MnA5ZHFsYTVtNncwZ3luNzc4eHdwOTN0IiwiTW5lbW9uaWMiOiJidXJzdCBzaWNrIHR3byB0cnVtcGV0IGRyaWZ0IGJvdHRvbSBzaWJsaW5nIGNsb2NrIHllbGxvdyBtYXhpbXVtIGtpc3Mgc2hvY2sgaGVpZ2h0IHRlYWNoIHNhbHV0ZSBpZ25vcmUgY2F1dGlvbiBlYWdlciBmaW5kIGFwb2xvZ3kgc2F0b3NoaSBzcG9vbiBzYWRuZXNzIG1hdHRlciJ9"), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMWh2Y3Nmc2xzZXQzcXI0ODRocGxuN3FhY2x5cnpyZXc1ejcyd3d0IiwiTW5lbW9uaWMiOiJhaXNsZSBpbnB1dCB0ZW4gZ3JlZW4gbWFuYWdlIHZpYnJhbnQgZmFtZSBidXNpbmVzcyBibGluZCByYWNjb29uIHNsaW0gdHJhaW4gYnVzaW5lc3MgZW5nYWdlIGRlc3Ryb3kgaW1wb3NlIHBsdWcgcG90YXRvIGFib3ZlIHZlc3NlbCBhdmVyYWdlIGFncmVlIHN0ZWVsIGNhdGFsb2cifQ=="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMWxqNmhnaDkzamRjZ2c5NGowNWtnc3ZuYzl2OTd3c3BlcXRjNHU1IiwiTW5lbW9uaWMiOiJiYXR0bGUgYm9udXMgbnVyc2UgYWRkcmVzcyBzZWxsIHRvb3RoIGxhcmdlIGN5Y2xlIHB1ZGRpbmcgZXJhc2UgZGVwb3NpdCBtZWFkb3cgb2JzY3VyZSB0YWcgYWN0IGJhbGwgYXR0cmFjdCBjb3lvdGUgcmVwbGFjZSBpbm1hdGUgb3Bwb3NlIGFyb3VuZCByYXZlbiBwYXBlciJ9"), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMXhobTVyNTRobHR2M2FzM2hna3d0cW5xdXUybXE0bXdyZ3B6anpzIiwiTW5lbW9uaWMiOiJuZWl0aGVyIGdhbGF4eSB2aXJ1cyBwbGF5IHN1biBiZWxpZXZlIG9ycGhhbiBmaW5nZXIgYnVsayBzaG9jayBsZWcgY2FwdGFpbiBicnVzaCBzcGluIG1pZG5pZ2h0IGx1Y2t5IHVnbHkgcmV1bmlvbiB3ZWVrZW5kIHdvcmQgYnVkZ2V0IHZhbiBzY3JlZW4gc2xlbmRlciJ9"), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMXN4Nm5oZXNsa3RrczV3cXRlOThhYWhxbnVsZGNseG5sZ3ZtdHRtIiwiTW5lbW9uaWMiOiJjYXN0bGUgZW5nYWdlIHNoaWVsZCByb29raWUgY2hlZXNlIHB1enpsZSBiZXR3ZWVuIGZlZWQgbGlvbiBhY2N1c2UgYWhlYWQgY2FudmFzIGltYWdlIGluc3BpcmUgb21pdCBtb3JlIGNyYW5lIGRyYXN0aWMgc3Rvb2wgYmVjb21lIGhvbGUgcGx1Y2sgY29yZSB0cm9waHkifQ=="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMXE3cDdlYTQ2bGZkaGU0cncycThucGM1cGh2bTJhY2x5bm0wM3R0IiwiTW5lbW9uaWMiOiJhc3N1bWUgdmFuaXNoIHVwcGVyIGdvZGRlc3MgY29taWMgd3JlY2sgdGVhY2ggd3Jpc3QgbWlzZXJ5IGd1ZXNzIHJlbnQgaGF3ayB0ZXh0IHNhbG1vbiBlcXVpcCBnZW51aW5lIGJsdXNoIHZlcmIgY29pbCByb3V0ZSB1cGdyYWRlIGJhZGdlIHN1bm55IHNwZW5kIn0="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMW12d3loN2x0NnI5NXJseHBoN3UyMnB3OTZnemp1MDcwZHNycGd3IiwiTW5lbW9uaWMiOiJyYWJiaXQgd2F0ZXIgcGVuY2lsIHRvcm5hZG8gbmFycm93IGV4YWN0IGVuZG9yc2UgZmluZSBnaXJhZmZlIHB1cGlsIG1vbmtleSB2YWNhbnQgd2VpcmQgb2N0b2JlciB0aG91Z2h0IHN0ZWFrIGRlcGVuZCB2b2x1bWUgbmFzdHkgdG9iYWNjbyBzbGVlcCB3ZWFzZWwgYmxvb2QgdGFpbCJ9"), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMWF3M2twcXV6Z2x0c2F1NTRoOWtxZGxuaG1ldjVkNmNudnM1a25rIiwiTW5lbW9uaWMiOiJwb3RhdG8gc3dhcm0geW91dGggY2FzdWFsIHVzZWxlc3MgZ2FyZGVuIGRheSBzZXR0bGUgdG9wcGxlIGZsb2NrIG9idmlvdXMgcmViZWwgYnJpY2sgdmV0ZXJhbiBnbHVlIGZyZXF1ZW50IGJlaGF2ZSBzZW50ZW5jZSBjb29sIHN1cmdlIHVuaWZvcm0gYXR0ZW5kIG1lbnUgZGV2aWNlIn0="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMXV3OGwwcHFqNGxxZGFqbnN3NHB1bTd4dHR3c3E0azNqYXh3NnZqIiwiTW5lbW9uaWMiOiJtb3JuaW5nIGZsYXQgb3duIGJhcnJlbCBmcm9nIHNpeCBpbm1hdGUgY2xvd24gcHVkZGluZyBuZWdhdGl2ZSBleG90aWMgaG9ycm9yIHNoZWxsIGNyaW1lIHJpdmFsIGJlc3QgYnJva2VuIGNsaWNrIHN1bnNldCB0YWxlbnQgY2FibGUgZW1wb3dlciBhcm1vciBoZWFkIn0="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMXU5dDdjcXJwY3R2bHB5ZGRtMnBkbHJwNm45bDA4bWVyMjd1aHQ4IiwiTW5lbW9uaWMiOiJsZXNzb24gY29yZSBkaXNhZ3JlZSBkaWFsIHNhZCBoaXJlIG1ha2UgbGF0ZXIgZW52ZWxvcGUgaG9tZSBiZWF1dHkgYmVhY2ggYWZmYWlyIHZvdGUgdHJpYWwgZnJvd24gcmF0ZSBjYXN0bGUgcmVjZWl2ZSBvY2N1ciBodW1ibGUgd2VsY29tZSB1bnZlaWwgdW5rbm93biJ9"), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMXY4aHQwNThyOGM2czJlaGE2bjQyeDZueHBrZnE3cjJ3NjhnejlnIiwiTW5lbW9uaWMiOiJjb29sIGdvc3BlbCBkaXNoIG1ha2UgaGFyZCB3aXNkb20gYmVhY2ggdmlkZW8gYmFyZWx5IGNhdGNoIHNvbGFyIHN0ZXJlbyBmdW5ueSByb2FkIGFubnVhbCBib251cyBnYXRlIGFkanVzdCBsdW5jaCBmbGF0IGV4aXN0IGZldmVyIHN0cm9uZyByb3V0ZSJ9"), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMThoeWg0bnk5Nzh2bTQ3YXN4eXluM3VxeDNkOXJkaDN1aGx1a2hoIiwiTW5lbW9uaWMiOiJjYW1wIGJpZCBtYXplIG9seW1waWMgYmFsYW5jZSBzaWRlIGd1YXJkIHNwYXRpYWwgYXJyZXN0IG1lcnJ5IHBsYXkgc3VtbWVyIGdhdGUgbXVzaHJvb20gc2NpZW5jZSByaXBwbGUgcmVqZWN0IHRvcnRvaXNlIGZsb2NrIHN3YWxsb3cgcnVuIGNodWNrbGUgZWFnbGUgcmVmb3JtIn0="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMTZmZWRtOXpxMnBndnU1NXczZ2Z0NWRqcWNsa3Vubnc5NHBzZ2RlIiwiTW5lbW9uaWMiOiJ3aGFsZSBiYXJnYWluIGRpdmVydCBzb29uIGVyYXNlIGxvbmVseSBjbG90aCBidWRkeSBzY2llbmNlIHZhcG9yIG1pc3MgcXVvdGUgZml4IGxvb3AgZmllbGQgY2hlY2sgaGlzdG9yeSBwbHVjayB0b2RkbGVyIGltcHVsc2UgbWlyYWNsZSBiZWx0IHBvb2wgaW1tdW5lIn0="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMTRuMmU5bWN4dHZxN2xoeWNmZWhrc2YzYXYzMnJ2dTl5d3ZsMjcwIiwiTW5lbW9uaWMiOiJidWxiIGdhcmFnZSBhZGRpY3QgYXJjdGljIHN1YmplY3QgcmF2ZW4gdG9vbCBoZWxtZXQgY2FwYWJsZSBjb3VwbGUgYmFzZSBpbnZlc3QgYmVnaW4gY2FsbCBmYXRpZ3VlIGFsdGVyIGVhc3kgdXNlbGVzcyBnZW5pdXMgdW52ZWlsIGJlZWYga2luZ2RvbSBjb252aW5jZSBkYW5nZXIifQ=="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMXlwcXk0dHN1NHUwZHhnM2d6OTdyNmtxY2dmNjg0dWN4cGptbWxhIiwiTW5lbW9uaWMiOiJsYXB0b3AgcHJvY2VzcyBub3NlIHRlYWNoIGJhcmVseSBqZXdlbCBpbml0aWFsIGF2b2NhZG8gZGlubmVyIGNoYWxrIHRyYW5zZmVyIG5lYXIgc3dpdGNoIGNhYmJhZ2UgYWJvdXQgY2hhbGsgY2hhaXIgYXNwZWN0IGd1biBsaWJlcnR5IGhvb2Qgc2VsZWN0IGJyYW5kIGthbmdhcm9vIn0="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMTByZmwwOG5heWRjZnc4cWtnNmNjdXB6YWRrdGVlZXRkMmx1NmpzIiwiTW5lbW9uaWMiOiJ0d2luIGdsYWQgc2VydmljZSBmaWd1cmUgcm9hc3QgY3JlZWsgb3lzdGVyIHB1bGwgY2xheSBhdXRvIGNsb3VkIGtldGNodXAgYm91bmNlIGZpZWxkIGdlbnRsZSBncmlkIGJyYW5kIHN0YWdlIGhlbG1ldCBzcGF0aWFsIHNwb2lsIHRleHQgY2FydCBzcHJpbmcifQ=="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMTBhZTI4bDNua3FtN25saG5tczBwNnc4OHEyYWdzNWd1MHNrNjZ5IiwiTW5lbW9uaWMiOiJyZWd1bGFyIHdvb2wgb3JhbmdlIGlzbGFuZCBzaXJlbiB1bWJyZWxsYSBjcnVpc2UgYWxsZXkgdGlkZSBmbGlwIHNsYWIgdmVyaWZ5IHNob3VsZGVyIHR3aW4gbWV0YWwga2l0dGVuIGN1cGJvYXJkIGFjcXVpcmUgYWJsZSBzdXJmYWNlIHRlbGwgdW5kbyBiZXN0IGxlZ2VuZCJ9"), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMWxoNWhjeG1nOWNna3Bkcm10NzZkeXJheGtwdzhndDR3aHR3ZnQ1IiwiTW5lbW9uaWMiOiJ2b2xjYW5vIGJyb256ZSBzcHJlYWQgbnVtYmVyIHdlYWx0aCBkZWZ5IGNpdGl6ZW4gd2luZSBlZmZvcnQgbmV4dCBoYW1zdGVyIGJldHRlciBsb2NrIHN5bXB0b20gaHVzYmFuZCB1bmlmb3JtIGhvdXIgdmF1bHQgcGl0Y2ggd2FzcCBzd2lmdCBpbmRpY2F0ZSBhZXJvYmljIHRvd2FyZCJ9"), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMWZhNjA0bTdoa3NucXZoc2YydWpjbHFqZ3k1cDIwdXU1c3FoMHltIiwiTW5lbW9uaWMiOiJ3ZWFyIGJhbGwgaW52b2x2ZSBndWVzcyBzcG9uc29yIGVwaXNvZGUgZmljdGlvbiBjcmltZSBib3JpbmcgbWF0aCB3ZWIgc2NlbmUgYm95IGZsaWdodCBhY3RyZXNzIGltYWdlIG1hbnVhbCBxdWljayBtZWNoYW5pYyBiZWNhdXNlIGdyb3cgcnVkZSBub3JtYWwgYW50aXF1ZSJ9"), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMTNwamZ1YWd3MnRlZDBhbjVhcWhtdDJsOGhrM3Q2YTk1czcyZzV5IiwiTW5lbW9uaWMiOiJzbG93IGRlZmVuc2UgZHJ5IGNyYW0gbHVtYmVyIGdpYW50IGRhdWdodGVyIG1ldGFsIGJyZWV6ZSBmb3J3YXJkIG5ldCB3b2xmIGZsYW1lIGRhbXAgcGxhY2UgdHdpc3QgZWxpdGUgcHJvb2YgZWFybHkgcG90dGVyeSBzb25nIGNveW90ZSBsaXphcmQgc29tZW9uZSJ9"), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMTgwODJnZzU3dHlwd3ZxM2N0YWNhZzljcWg5ejJqZjdkbDJzeDlhIiwiTW5lbW9uaWMiOiJsb3ZlIG1lbHQgZ3JpZCBzaGFsbG93IGZhY3VsdHkgdG9zcyBzdXJyb3VuZCBpbWl0YXRlIG5lY2sgY2F0IGJhc2ljIHNsaWdodCBqYWd1YXIgYWNyb3NzIGdpdmUgYWJzZW50IHJlZ2lvbiBncmF2aXR5IGVuZG9yc2UgYnJpZ2h0IHNpbXBsZSBvY3RvYmVyIHJldW5pb24gc3RvcnkifQ=="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMWxqd3Jsczg3MnB4MnEwNWFyZmdrazZnajQ0YXBxOHM1ajk5Z3Q1IiwiTW5lbW9uaWMiOiJzY291dCBtb2JpbGUgcmVjYWxsIG1lbWJlciByYWxseSB0aWx0IGNhcmQgaW50byB1bWJyZWxsYSBmZWVkIHZlcnNpb24gbm92ZWwgZ2lyYWZmZSBoYW1tZXIgem9uZSBrZWVuIG9yaWVudCBoYWxmIGRpc2FncmVlIGJlYWNoIHBvZXQgaW1wYWN0IGRpbm5lciBtYXNrIn0="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMTVzYTc4eTRkZ2tlc3oyN3k5bTZyNDByMDBzZTdtd2h5MjU2dGxoIiwiTW5lbW9uaWMiOiJnb2RkZXNzIGZpeCBjcmFuZSByaWdpZCBjYXN1YWwgd2hlYXQgc3ByYXkgY3JlYW0gY29pbiBsZWFmIGRpc3BsYXkgaHVyZGxlIGVuc3VyZSBhcm1lZCBjb3JyZWN0IGJ1bmtlciBpZGVudGlmeSBkb25hdGUgc3Bpa2UgZmFudGFzeSByZWxpZWYgZGlzYWdyZWUgZ3JhcGUgc2hvdWxkZXIifQ=="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMTN6OWNteHVrdzdoaHYzNXgweDU0YXZhbXJuOXA2NWF0cGcybmR4IiwiTW5lbW9uaWMiOiJtb25zdGVyIGxhbmd1YWdlIHZvY2FsIGZseSBtYXJjaCBqb2tlIG5ldXRyYWwgamVsbHkgY2h1cm4gZ29kZGVzcyB3ZWFyIGNhbG0gdmFsaWQgbm93IGF1dHVtbiBsaWFyIHdhbnQgc3Bvb24gZ2xvb20gaGlnaCBqdXN0IHNvbWVvbmUgbWFudWFsIGVuZXJneSJ9"), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMTZjdTB4cTRyeDhlZWZqN3BrMmY5cHJmcmttejhtM3g1bWtyNjZyIiwiTW5lbW9uaWMiOiJtb3JuaW5nIG9mdGVuIGxhdGVyIGVjaG8geW91bmcgZGlsZW1tYSB1bnZlaWwgc3Vuc2V0IGdsYW5jZSBzaG9wIG9ic2VydmUgZXhwaXJlIHN0YWdlIG1lbWJlciBzaGlmdCBhY291c3RpYyBjb25maXJtIHJhZGlvIGp1ZGdlIGxhYiBtdWZmaW4gdHJpbSBnZW51aW5lIGJ1aWxkIn0="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMXQzcnVxZmN6aGp5cjRycDU5amNkdjZ4dmgwNnNhcDZuMzBjc2FhIiwiTW5lbW9uaWMiOiJsdW5jaCBib3Jyb3cgZGVmeSBwb29sIGxvY2FsIGdyYW50IHNoaXAgbXVzaHJvb20gYXdrd2FyZCBpbmNsdWRlIGtpZCBiZWx0IHBhaXIgaW50byBsZW5zIHRyYXZlbCByZWZsZWN0IHJvdXRlIG1pbmQgZW5hYmxlIG5lY2sga25lZSBzaXggd2lkdGgifQ=="), + mustParsePreGeneratedAccount("eyJBZGRyZXNzIjoiY29zbW9zMWg4MmVnOXBuN3pzM2w1bHRqdHN6ejN0MGdkNWVhejdnd3lyN2M1IiwiTW5lbW9uaWMiOiJzeXN0ZW0gdHJ5IGVhZ2VyIGNhcmQgbGVzc29uIGN1cnRhaW4gYmVjYXVzZSBmbGFtZSBpbWl0YXRlIHNpemUgc2libGluZyBsYXRlciBoaWdoIHNhbXBsZSBjbGF3IHNjYXR0ZXIgdXNlIHNlcmllcyBiYWNoZWxvciBwZXBwZXIgbmV4dCBhZ2FpbiBhbmdyeSBsb2dpYyJ9"), + ) +) diff --git a/testutil/testkeyring/gen_accounts/gen.go b/testutil/testkeyring/gen_accounts/gen.go new file mode 100644 index 000000000..8b05da7d2 --- /dev/null +++ b/testutil/testkeyring/gen_accounts/gen.go @@ -0,0 +1,79 @@ +//go:build ignore + +package main + +import ( + "bytes" + "flag" + "fmt" + "log" + "os" + "strings" + + "github.com/cosmos/cosmos-sdk/crypto/hd" + "github.com/cosmos/cosmos-sdk/crypto/keyring" + "github.com/cosmos/cosmos-sdk/types" + + "github.com/pokt-network/poktroll/testutil/testkeyring" + + "github.com/pokt-network/poktroll/app" +) + +var ( + flagOut string + flagAccountsLimit int + defaultOutPath = "accounts_table.go" +) + +func init() { + flag.StringVar(&flagOut, "out", defaultOutPath, "the path to the generated go source of pre-generated accounts.") + flag.IntVar(&flagAccountsLimit, "limit", 100, "the number of accounts to generate.") +} + +func main() { + flag.Parse() + + kr := keyring.NewInMemory(app.MakeEncodingConfig().Marshaler) + + preGeneratedAccountLines := make([]string, flagAccountsLimit) + for i := range preGeneratedAccountLines { + record, mnemonic, err := kr.NewMnemonic( + fmt.Sprintf("key-%d", i), + keyring.English, + types.FullFundraiserPath, + keyring.DefaultBIP39Passphrase, + hd.Secp256k1, + ) + addr, err := record.GetAddress() + if err != nil { + log.Fatal(err) + } + + preGeneratedAccount := &testkeyring.PreGeneratedAccount{ + Address: addr, + Mnemonic: mnemonic, + } + + preGeneratedAccountStr, err := preGeneratedAccount.Marshal() + if err != nil { + log.Fatal(err) + } + + preGeneratedAccountLines[i] = fmt.Sprintf(preGeneratedAccountLineFmt, preGeneratedAccountStr) + } + + newPreGeneratedAccountIteratorArgLines := strings.Join(preGeneratedAccountLines, "\n") + outputBuffer := new(bytes.Buffer) + if err := accountsTableTemplate.Execute( + outputBuffer, + map[string]any{ + "newPreGeneratedAccountIteratorArgLines": newPreGeneratedAccountIteratorArgLines, + }, + ); err != nil { + log.Fatal(err) + } + + if err := os.WriteFile(flagOut, outputBuffer.Bytes(), 0644); err != nil { + log.Fatal(err) + } +} diff --git a/testutil/testkeyring/gen_accounts/template.go b/testutil/testkeyring/gen_accounts/template.go new file mode 100644 index 000000000..e7dfb5b57 --- /dev/null +++ b/testutil/testkeyring/gen_accounts/template.go @@ -0,0 +1,26 @@ +//go:build ignore + +package main + +import "text/template" + +var ( + preGeneratedAccountLineFmt = "\t\tmustParsePreGeneratedAccount(%q)," + accountsTableTemplate = template.Must( + template.New("accounts_table.go").Parse( + `// DO NOT EDIT. This Code is generated by gen_accounts/gen.go, +// changes will be overwritten upon regeneration. +// +// To regenerate this file, use make go_testgen_accounts or go generate ./testutil/testkeyring/keyring.go. + +package testkeyring + +var ( + preGeneratedAccounts = NewPreGeneratedAccountIterator( +{{.newPreGeneratedAccountIteratorArgLines}} + ) +) +`, + ), + ) +) diff --git a/testutil/testkeyring/keyring.go b/testutil/testkeyring/keyring.go new file mode 100644 index 000000000..f6c503d8e --- /dev/null +++ b/testutil/testkeyring/keyring.go @@ -0,0 +1,47 @@ +//go:generate go run ./gen_accounts/gen.go ./gen_accounts/template.go + +package testkeyring + +import ( + "fmt" + "testing" + + "github.com/cosmos/cosmos-sdk/crypto/hd" + "github.com/cosmos/cosmos-sdk/crypto/keyring" + "github.com/cosmos/cosmos-sdk/types" + "github.com/stretchr/testify/assert" +) + +// CreatePreGeneratedKeyringAccounts uses the mnemonic from limit number of +// pre-generated accounts to populated the provided keyring, kr. It then returns +// the pre-generated accounts which were used. +// +// TODO_CONSIDERATION: Returning a new PreGeneratedAccountIterator instead of +// the slice of accounts could be more idiomatic. It would only contain keys which +// are known to be in the keyring. +func CreatePreGeneratedKeyringAccounts( + t *testing.T, + kr keyring.Keyring, + limit int, +) []*PreGeneratedAccount { + t.Helper() + + accounts := make([]*PreGeneratedAccount, limit) + for i := range accounts { + preGeneratedAccount := MustPreGeneratedAccountAtIndex(uint32(i)) + + uid := fmt.Sprintf("key-%d", i) + _, err := kr.NewAccount( + uid, + preGeneratedAccount.Mnemonic, + keyring.DefaultBIP39Passphrase, + types.FullFundraiserPath, + hd.Secp256k1, + ) + assert.NoError(t, err) + + accounts[i] = preGeneratedAccount + } + + return accounts[:limit] +}