2023-12-28 17:57:44 +00:00
|
|
|
package heimdall
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"io"
|
|
|
|
"net/http"
|
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/golang/mock/gomock"
|
|
|
|
"github.com/ledgerwatch/log/v3"
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
|
2024-01-09 18:20:42 +00:00
|
|
|
"github.com/ledgerwatch/erigon/polygon/heimdall/mock"
|
|
|
|
|
2023-12-28 17:57:44 +00:00
|
|
|
"github.com/ledgerwatch/erigon/turbo/testlog"
|
|
|
|
)
|
|
|
|
|
|
|
|
type emptyBodyReadCloser struct{}
|
|
|
|
|
|
|
|
func (ebrc emptyBodyReadCloser) Read(_ []byte) (n int, err error) {
|
|
|
|
return 0, io.EOF
|
|
|
|
}
|
|
|
|
|
|
|
|
func (ebrc emptyBodyReadCloser) Close() error {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestHeimdallClientFetchesTerminateUponTooManyErrors(t *testing.T) {
|
|
|
|
ctx := context.Background()
|
|
|
|
ctrl := gomock.NewController(t)
|
|
|
|
httpClient := mock.NewMockHttpClient(ctrl)
|
|
|
|
httpClient.EXPECT().
|
|
|
|
Do(gomock.Any()).
|
2023-12-30 11:23:25 +00:00
|
|
|
Return(&http.Response{
|
|
|
|
StatusCode: 404,
|
|
|
|
Body: emptyBodyReadCloser{},
|
|
|
|
}, nil).
|
2023-12-28 17:57:44 +00:00
|
|
|
Times(5)
|
|
|
|
logger := testlog.Logger(t, log.LvlDebug)
|
|
|
|
heimdallClient := newHeimdallClient("https://dummyheimdal.com", httpClient, 100*time.Millisecond, 5, logger)
|
|
|
|
|
|
|
|
spanRes, err := heimdallClient.Span(ctx, 1534)
|
|
|
|
require.Nil(t, spanRes)
|
|
|
|
require.Error(t, err)
|
|
|
|
}
|
2023-12-30 11:23:25 +00:00
|
|
|
|
|
|
|
func TestHeimdallClientStateSyncEventsReturnsErrNoResponseWhenHttp200WithEmptyBody(t *testing.T) {
|
|
|
|
ctx := context.Background()
|
|
|
|
ctrl := gomock.NewController(t)
|
|
|
|
httpClient := mock.NewMockHttpClient(ctrl)
|
|
|
|
httpClient.EXPECT().
|
|
|
|
Do(gomock.Any()).
|
|
|
|
Return(&http.Response{
|
|
|
|
StatusCode: 200,
|
|
|
|
Body: emptyBodyReadCloser{},
|
|
|
|
}, nil).
|
|
|
|
Times(2)
|
|
|
|
logger := testlog.Logger(t, log.LvlDebug)
|
|
|
|
heimdallClient := newHeimdallClient("https://dummyheimdal.com", httpClient, time.Millisecond, 2, logger)
|
|
|
|
|
|
|
|
spanRes, err := heimdallClient.StateSyncEvents(ctx, 100, time.Now().Unix())
|
|
|
|
require.Nil(t, spanRes)
|
|
|
|
require.ErrorIs(t, err, ErrNoResponse)
|
|
|
|
}
|