Skip to content

Commit

Permalink
inabox test retrieval from network
Browse files Browse the repository at this point in the history
  • Loading branch information
ian-shim committed Dec 16, 2024
1 parent b7fe161 commit 57326f1
Show file tree
Hide file tree
Showing 4 changed files with 54 additions and 32 deletions.
8 changes: 6 additions & 2 deletions api/clients/v2/retrieval_client.go
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ import (
// To retrieve a blob from the relay, use RelayClient instead.
type RetrievalClient interface {
// GetBlob downloads chunks of a blob from operator network and reconstructs the blob.
GetBlob(ctx context.Context, blobHeader corev2.BlobHeader, referenceBlockNumber uint64, quorumID core.QuorumID) ([]byte, error)
GetBlob(ctx context.Context, blobHeader *corev2.BlobHeader, referenceBlockNumber uint64, quorumID core.QuorumID) ([]byte, error)
}

type retrievalClient struct {
Expand Down Expand Up @@ -49,7 +49,11 @@ func NewRetrievalClient(
}
}

func (r *retrievalClient) GetBlob(ctx context.Context, blobHeader corev2.BlobHeader, referenceBlockNumber uint64, quorumID core.QuorumID) ([]byte, error) {
func (r *retrievalClient) GetBlob(ctx context.Context, blobHeader *corev2.BlobHeader, referenceBlockNumber uint64, quorumID core.QuorumID) ([]byte, error) {
if blobHeader == nil {
return nil, errors.New("blob header is nil")
}

blobKey, err := blobHeader.BlobKey()
if err != nil {
return nil, err
Expand Down
2 changes: 2 additions & 0 deletions inabox/deploy/config.go
Original file line number Diff line number Diff line change
Expand Up @@ -455,6 +455,8 @@ func (env *Config) generateRetrieverVars(ind int, key string, graphUrl, logPath,
RETRIEVER_VERBOSE: "true",
RETRIEVER_CACHE_ENCODED_BLOBS: "false",
RETRIEVER_GRAPH_URL: graphUrl,
RETRIEVER_GRAPH_BACKOFF: "1s",
RETRIEVER_GRAPH_MAX_RETRIES: "3",

RETRIEVER_INDEXER_PULL_INTERVAL: "1s",
}
Expand Down
33 changes: 16 additions & 17 deletions inabox/tests/integration_suite_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -11,17 +11,17 @@ import (
"time"

"github.com/Layr-Labs/eigenda/api/clients"
clientsv2 "github.com/Layr-Labs/eigenda/api/clients/v2"
"github.com/Layr-Labs/eigenda/common"
"github.com/Layr-Labs/eigenda/common/geth"
rollupbindings "github.com/Layr-Labs/eigenda/contracts/bindings/MockRollup"
"github.com/Layr-Labs/eigenda/core"
"github.com/Layr-Labs/eigenda/core/eth"
coreindexer "github.com/Layr-Labs/eigenda/core/indexer"
"github.com/Layr-Labs/eigenda/core/thegraph"
corev2 "github.com/Layr-Labs/eigenda/core/v2"
"github.com/Layr-Labs/eigenda/encoding/kzg"
"github.com/Layr-Labs/eigenda/encoding/kzg/verifier"
"github.com/Layr-Labs/eigenda/inabox/deploy"
"github.com/Layr-Labs/eigenda/indexer"
"github.com/Layr-Labs/eigensdk-go/logging"
gcommon "github.com/ethereum/go-ethereum/common"
ethrpc "github.com/ethereum/go-ethereum/rpc"
Expand All @@ -48,6 +48,7 @@ var (
rpcClient common.RPCEthClient
mockRollup *rollupbindings.ContractMockRollup
retrievalClient clients.RetrievalClient
retrievalClientV2 clientsv2.RetrievalClient
numConfirmations int = 3
numRetries = 0
relays = map[corev2.RelayKey]string{}
Expand Down Expand Up @@ -190,33 +191,31 @@ func setupRetrievalClient(testConfig *deploy.Config) error {
return err
}

indexer, err := coreindexer.CreateNewIndexer(
&indexer.Config{
PullInterval: 100 * time.Millisecond,
},
ethClient,
rpcClient,
testConfig.Retriever.RETRIEVER_EIGENDA_SERVICE_MANAGER,
logger,
)
graphBackoff, err := time.ParseDuration(testConfig.Retriever.RETRIEVER_GRAPH_BACKOFF)
if err != nil {
return err
}

ics, err := coreindexer.NewIndexedChainState(cs, indexer)
maxRetries, err := strconv.Atoi(testConfig.Retriever.RETRIEVER_GRAPH_MAX_RETRIES)
if err != nil {
return err
}
ics := thegraph.MakeIndexedChainState(thegraph.Config{
Endpoint: testConfig.Retriever.RETRIEVER_GRAPH_URL,
PullInterval: graphBackoff,
MaxRetries: maxRetries,
}, cs, logger)

retrievalClient, err = clients.NewRetrievalClient(logger, ics, agn, nodeClient, v, 10)
if err != nil {
return err
}
chainReader, err := eth.NewReader(logger, ethClient, testConfig.Retriever.RETRIEVER_BLS_OPERATOR_STATE_RETRIVER, testConfig.Retriever.RETRIEVER_EIGENDA_SERVICE_MANAGER)
if err != nil {
return err
}
retrievalClientV2 = clientsv2.NewRetrievalClient(logger, chainReader, ics, v, 10)

var ctx context.Context
ctx, cancel = context.WithCancel(context.Background())

return indexer.Index(ctx)
return ics.Start(context.Background())
}

var _ = AfterSuite(func() {
Expand Down
43 changes: 30 additions & 13 deletions inabox/tests/integration_v2_test.go
Original file line number Diff line number Diff line change
@@ -1,11 +1,13 @@
package integration_test

import (
"bytes"
"context"
"crypto/rand"
"time"

"github.com/Layr-Labs/eigenda/api/clients/v2"
commonpb "github.com/Layr-Labs/eigenda/api/grpc/common/v2"
disperserpb "github.com/Layr-Labs/eigenda/api/grpc/disperser/v2"
"github.com/Layr-Labs/eigenda/core"
auth "github.com/Layr-Labs/eigenda/core/auth/v2"
Expand Down Expand Up @@ -62,6 +64,8 @@ var _ = Describe("Inabox v2 Integration", func() {
var reply2 *disperserpb.BlobStatusReply
var blobCert1 *corev2.BlobCertificate
var blobCert2 *corev2.BlobCertificate
var batchHeader1 *commonpb.BatchHeader
var batchHeader2 *commonpb.BatchHeader
for loop := true; loop; {
select {
case <-ctx.Done():
Expand All @@ -83,10 +87,10 @@ var _ = Describe("Inabox v2 Integration", func() {
continue
}

batchHeader := reply1.GetSignedBatch().GetHeader()
Expect(batchHeader).To(Not(BeNil()))
Expect(batchHeader.GetBatchRoot()).To(Not(BeNil()))
Expect(batchHeader.GetReferenceBlockNumber()).To(BeNumerically(">", 0))
batchHeader1 = reply1.GetSignedBatch().GetHeader()
Expect(batchHeader1).To(Not(BeNil()))
Expect(batchHeader1.GetBatchRoot()).To(Not(BeNil()))
Expect(batchHeader1.GetReferenceBlockNumber()).To(BeNumerically(">", 0))
attestation := reply1.GetSignedBatch().GetAttestation()
Expect(attestation).To(Not(BeNil()))
blobVerification := reply1.GetBlobVerificationInfo()
Expand All @@ -102,14 +106,14 @@ var _ = Describe("Inabox v2 Integration", func() {
Expect(err).To(BeNil())
_, err = blobCert1.BlobHeader.BlobKey()
Expect(err).To(BeNil())
verified, err := merkletree.VerifyProofUsing(certHash[:], false, proof, [][]byte{batchHeader.BatchRoot}, keccak256.New())
verified, err := merkletree.VerifyProofUsing(certHash[:], false, proof, [][]byte{batchHeader1.BatchRoot}, keccak256.New())
Expect(err).To(BeNil())
Expect(verified).To(BeTrue())

batchHeader = reply2.GetSignedBatch().GetHeader()
Expect(batchHeader).To(Not(BeNil()))
Expect(batchHeader.GetBatchRoot()).To(Not(BeNil()))
Expect(batchHeader.GetReferenceBlockNumber()).To(BeNumerically(">", 0))
batchHeader2 = reply2.GetSignedBatch().GetHeader()
Expect(batchHeader2).To(Not(BeNil()))
Expect(batchHeader2.GetBatchRoot()).To(Not(BeNil()))
Expect(batchHeader2.GetReferenceBlockNumber()).To(BeNumerically(">", 0))
attestation = reply2.GetSignedBatch().GetAttestation()
Expect(attestation).To(Not(BeNil()))
blobVerification = reply2.GetBlobVerificationInfo()
Expand All @@ -123,7 +127,7 @@ var _ = Describe("Inabox v2 Integration", func() {
Expect(err).To(BeNil())
certHash, err = blobCert2.Hash()
Expect(err).To(BeNil())
verified, err = merkletree.VerifyProofUsing(certHash[:], false, proof, [][]byte{batchHeader.BatchRoot}, keccak256.New())
verified, err = merkletree.VerifyProofUsing(certHash[:], false, proof, [][]byte{batchHeader2.BatchRoot}, keccak256.New())
Expect(err).To(BeNil())
Expect(verified).To(BeTrue())
// TODO(ian-shim): verify the blob onchain using a mock rollup contract
Expand All @@ -136,8 +140,6 @@ var _ = Describe("Inabox v2 Integration", func() {
Sockets: relays,
}, logger)
Expect(err).To(BeNil())
ctx, cancel = context.WithTimeout(context.Background(), time.Second*5)
defer cancel()

blob1Relays := make(map[corev2.RelayKey]struct{}, 0)
blob2Relays := make(map[corev2.RelayKey]struct{}, 0)
Expand Down Expand Up @@ -165,6 +167,21 @@ var _ = Describe("Inabox v2 Integration", func() {
}
}

// TODO(ian-shim): test retrieval from DA nodes via retrieval client
b, err := retrievalClientV2.GetBlob(ctx, blobCert1.BlobHeader, batchHeader1.ReferenceBlockNumber, 0)
Expect(err).To(BeNil())
restored := bytes.TrimRight(b, "\x00")
Expect(restored).To(Equal(paddedData1))
b, err = retrievalClientV2.GetBlob(ctx, blobCert1.BlobHeader, batchHeader1.ReferenceBlockNumber, 1)
restored = bytes.TrimRight(b, "\x00")
Expect(err).To(BeNil())
Expect(restored).To(Equal(paddedData1))
b, err = retrievalClientV2.GetBlob(ctx, blobCert2.BlobHeader, batchHeader2.ReferenceBlockNumber, 0)
restored = bytes.TrimRight(b, "\x00")
Expect(err).To(BeNil())
Expect(restored).To(Equal(paddedData2))
b, err = retrievalClientV2.GetBlob(ctx, blobCert2.BlobHeader, batchHeader2.ReferenceBlockNumber, 1)
restored = bytes.TrimRight(b, "\x00")
Expect(err).NotTo(BeNil())
Expect(restored).To(BeNil())
})
})

0 comments on commit 57326f1

Please sign in to comment.