1
0
Fork 0

Start adding compressed download testing

master
Philip O'Toole 1 year ago
parent d142e47a17
commit ed074519f6

@ -2,6 +2,7 @@ package download
import ( import (
"bytes" "bytes"
"compress/gzip"
"context" "context"
"errors" "errors"
"fmt" "fmt"
@ -9,44 +10,27 @@ import (
"testing" "testing"
) )
type mockStorageClient struct {
data []byte
error error
}
func (m *mockStorageClient) Download(ctx context.Context, writer io.WriterAt) error {
if m.error != nil {
return m.error
}
n, err := writer.WriteAt(m.data, 0)
if n != len(m.data) || err != nil {
return fmt.Errorf("failed to write data: %w", err)
}
return nil
}
func (m *mockStorageClient) String() string {
return "mockStorageClient"
}
func TestDownloader_Do(t *testing.T) { func TestDownloader_Do(t *testing.T) {
tests := []struct { tests := []struct {
name string name string
mockClientData []byte mockClientData []byte
mockClientError error compress bool
expectedOutputData []byte expectError error
expectError bool
}{ }{
{ {
name: "Successful Download", name: "Successful download",
mockClientData: []byte("test data"),
expectError: nil,
},
{
name: "Successful download of compressed data",
mockClientData: []byte("test data"), mockClientData: []byte("test data"),
expectedOutputData: []byte("test data"), compress: false,
expectError: false, expectError: nil,
}, },
{ {
name: "Download Error", name: "Download error",
mockClientError: errors.New("download error"), expectError: errors.New("download error"),
expectError: true,
}, },
} }
@ -54,55 +38,92 @@ func TestDownloader_Do(t *testing.T) {
t.Run(tt.name, func(t *testing.T) { t.Run(tt.name, func(t *testing.T) {
mockClient := &mockStorageClient{ mockClient := &mockStorageClient{
data: tt.mockClientData, data: tt.mockClientData,
error: tt.mockClientError, error: tt.expectError,
} }
downloader := download.NewDownloader(mockClient) if tt.compress {
mockClient.Compress()
}
downloader := NewDownloader(mockClient)
outputBuffer := bytes.NewBuffer(make([]byte, 0, len(tt.expectedOutputData))) f := newmockWriterAt(len(tt.mockClientData))
err := downloader.Do(context.Background(), outputBuffer)
if tt.expectError { err := downloader.Do(context.Background(), f)
if tt.expectError != nil {
if err == nil { if err == nil {
t.Errorf("Expected error, but got none") t.Errorf("Expected error, but got none")
} }
if err.Error() != tt.expectError.Error() {
t.Errorf("Expected error %v, but got %v", tt.expectError, err)
}
} else { } else {
if err != nil { if err != nil {
t.Errorf("Unexpected error: %v", err) t.Errorf("Unexpected error: %v", err)
} }
if !bytes.Equal(tt.expectedOutputData, outputBuffer.Bytes()) { if !bytes.Equal(tt.mockClientData, f.Bytes()) {
t.Errorf("Expected output data %v, but got %v", tt.expectedOutputData, outputBuffer.Bytes()) t.Errorf("Expected output data %v, but got %v", tt.mockClientData, f.Bytes())
} }
} }
}) })
} }
} }
func TestDownloader_Stats(t *testing.T) { type mockStorageClient struct {
mockClient := &mockStorageClient{ data []byte
data: []byte("test data"), error error
}
func (m *mockStorageClient) Download(ctx context.Context, writer io.WriterAt) error {
if m.error != nil {
return m.error
}
n, err := writer.WriteAt(m.data, 0)
if n != len(m.data) || err != nil {
return fmt.Errorf("failed to write data: %w", err)
} }
downloader := download.NewDownloader(mockClient) return nil
buffer := bytes.NewBuffer(make([]byte, 0, len(mockClient.data))) }
download.ResetStats() func (m *mockStorageClient) Compress() error {
var compressedData bytes.Buffer
gzipWriter := gzip.NewWriter(&compressedData)
err := downloader.Do(context.Background(), buffer) _, err := gzipWriter.Write(m.data)
if err != nil { if err != nil {
t.Errorf("Unexpected error: %v", err) return err
} }
numDownloadsOK := download.GetStats().Get(download.NumDownloadsOK) err = gzipWriter.Close()
if numDownloadsOK != 1 { if err != nil {
t.Errorf("Expected NumDownloadsOK to be 1, but got %d", numDownloadsOK) return err
} }
numDownloadsFail := download.GetStats().Get(download.NumDownloadsFail) m.data = compressedData.Bytes()
if numDownloadsFail != 0 { return nil
t.Errorf("Expected NumDownloadsFail to be 0, but got %d", numDownloadsFail) }
func (m *mockStorageClient) String() string {
return "mockStorageClient"
}
type mockWriterAt struct {
data []byte
}
func newmockWriterAt(size int) *mockWriterAt {
return &mockWriterAt{
data: make([]byte, size),
} }
}
numDownloadBytes := download.GetStats().Get(download.NumDownloadBytes) func (s *mockWriterAt) WriteAt(p []byte, off int64) (n int, err error) {
if numDownloadBytes != int64(len(mockClient.data)) { if off < 0 || int(off) > len(s.data) {
t.Errorf("Expected NumDownloadBytes to be %d, but got %d", len(mockClient.data), numDownloadBytes) return 0, errors.New("invalid offset")
} }
n = copy(s.data[off:], p)
return n, nil
}
func (s *mockWriterAt) Bytes() []byte {
return s.data
} }

Loading…
Cancel
Save