mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-15 14:38:20 +00:00
485fc538c3
* 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
73 lines
1.7 KiB
Go
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)
|
|
}
|
|
}
|
|
}
|