prysm-pulse/shared/interop/generate_deposits_test.go
Jim McDonald 485fc538c3 Utility to parallelise functions over arrays (#3813)
* Initial version of scatter

* Add mutex for scatter batch

* Provide mutex to worker processes

* Embed mputil

* Add notes on scatter

* Tidy-up

* Add mutex test

* Simplify scatter for users

* Tidy-ups/code coverage

* Gazelle update

* Add benchmark

* Mutex to RWMutex

* Add test against internal functions

* Bazel fixes

* Fix benchmark

* Benchmark values to constants

* Update shared/mputil/scatter.go

Co-Authored-By: Raul Jordan <raul@prysmaticlabs.com>

* Update shared/mputil/scatter.go

Co-Authored-By: Raul Jordan <raul@prysmaticlabs.com>

* Moved struct to top of file

* Add featureconfig for scatter

* Gate scatter behind feature flag

* Lint fixes

* fmt
2019-11-03 16:25:52 -05:00

73 lines
1.7 KiB
Go

package interop_test
import (
"bytes"
"testing"
"github.com/prysmaticlabs/prysm/shared/featureconfig"
"github.com/prysmaticlabs/prysm/shared/interop"
"github.com/prysmaticlabs/prysm/shared/params"
"github.com/prysmaticlabs/prysm/shared/trieutil"
)
func TestSPMPDeposits(t *testing.T) {
// Confirm that internal single-processor deposits end up with the same results as the multi-processor version
numDeposits := 557
cfg := &featureconfig.Flag{
Scatter: false,
}
featureconfig.Init(cfg)
spPrivKeys, spPubKeys, err := interop.DeterministicallyGenerateKeys(0 /*startIndex*/, uint64(numDeposits))
if err != nil {
t.Fatal(err)
}
spDepositDataItems, spDepositDataRoots, err := interop.DepositDataFromKeys(spPrivKeys, spPubKeys)
if err != nil {
t.Fatal(err)
}
trie, err := trieutil.GenerateTrieFromItems(
spDepositDataRoots,
int(params.BeaconConfig().DepositContractTreeDepth),
)
if err != nil {
t.Fatal(err)
}
spDeposits, err := interop.GenerateDepositsFromData(spDepositDataItems, trie)
if err != nil {
t.Fatal(err)
}
cfg = &featureconfig.Flag{
Scatter: true,
}
featureconfig.Init(cfg)
privKeys, pubKeys, err := interop.DeterministicallyGenerateKeys(0 /*startIndex*/, uint64(numDeposits))
if err != nil {
t.Fatal(err)
}
depositDataItems, _, err := interop.DepositDataFromKeys(privKeys, pubKeys)
if err != nil {
t.Fatal(err)
}
deposits, err := interop.GenerateDepositsFromData(depositDataItems, trie)
if err != nil {
t.Fatal(err)
}
for i := range deposits {
spD, err := spDeposits[i].Marshal()
if err != nil {
t.Fatal(err)
}
d, err := deposits[i].Marshal()
if err != nil {
t.Fatal(err)
}
if bytes.Compare(d, spD) != 0 {
t.Fatalf("Deposit mismatch at index %d: %v vs %v", i, spD, d)
}
}
}