2
2
mirror of https://github.com/octoleo/restic.git synced 2025-01-23 23:28:32 +00:00
restic/internal/archiver/blob_saver_test.go

117 lines
2.4 KiB
Go
Raw Normal View History

package archiver
import (
"context"
"fmt"
"runtime"
"strings"
"sync"
"sync/atomic"
"testing"
"github.com/restic/restic/internal/errors"
"github.com/restic/restic/internal/restic"
rtest "github.com/restic/restic/internal/test"
2022-05-27 19:08:50 +02:00
"golang.org/x/sync/errgroup"
)
var errTest = errors.New("test error")
type saveFail struct {
cnt int32
failAt int32
}
func (b *saveFail) SaveBlob(_ context.Context, _ restic.BlobType, _ []byte, id restic.ID, _ bool) (restic.ID, bool, int, error) {
val := atomic.AddInt32(&b.cnt, 1)
if val == b.failAt {
2022-05-01 14:26:57 +02:00
return restic.ID{}, false, 0, errTest
}
2022-05-01 14:26:57 +02:00
return id, false, 0, nil
}
func TestBlobSaver(t *testing.T) {
ctx, cancel := context.WithCancel(context.Background())
defer cancel()
2022-05-27 19:08:50 +02:00
wg, ctx := errgroup.WithContext(ctx)
saver := &saveFail{}
2024-08-27 11:26:52 +02:00
b := newBlobSaver(ctx, wg, saver, uint(runtime.NumCPU()))
var wait sync.WaitGroup
2024-08-27 11:26:52 +02:00
var results []saveBlobResponse
var lock sync.Mutex
wait.Add(20)
for i := 0; i < 20; i++ {
2024-08-27 11:26:52 +02:00
buf := &buffer{Data: []byte(fmt.Sprintf("foo%d", i))}
idx := i
lock.Lock()
2024-08-27 11:26:52 +02:00
results = append(results, saveBlobResponse{})
lock.Unlock()
2024-08-27 11:26:52 +02:00
b.Save(ctx, restic.DataBlob, buf, "file", func(res saveBlobResponse) {
lock.Lock()
results[idx] = res
lock.Unlock()
wait.Done()
})
}
wait.Wait()
for i, sbr := range results {
if sbr.known {
t.Errorf("blob %v is known, that should not be the case", i)
}
}
2022-05-27 19:08:50 +02:00
b.TriggerShutdown()
2022-05-27 19:08:50 +02:00
err := wg.Wait()
if err != nil {
t.Fatal(err)
}
}
func TestBlobSaverError(t *testing.T) {
var tests = []struct {
blobs int
failAt int
}{
{20, 2},
{20, 5},
{20, 15},
{200, 150},
}
for _, test := range tests {
t.Run("", func(t *testing.T) {
ctx, cancel := context.WithCancel(context.Background())
defer cancel()
2022-05-27 19:08:50 +02:00
wg, ctx := errgroup.WithContext(ctx)
saver := &saveFail{
failAt: int32(test.failAt),
}
2024-08-27 11:26:52 +02:00
b := newBlobSaver(ctx, wg, saver, uint(runtime.NumCPU()))
for i := 0; i < test.blobs; i++ {
2024-08-27 11:26:52 +02:00
buf := &buffer{Data: []byte(fmt.Sprintf("foo%d", i))}
b.Save(ctx, restic.DataBlob, buf, "errfile", func(res saveBlobResponse) {})
}
2022-05-27 19:08:50 +02:00
b.TriggerShutdown()
2022-05-27 19:08:50 +02:00
err := wg.Wait()
if err == nil {
t.Errorf("expected error not found")
}
rtest.Assert(t, errors.Is(err, errTest), "unexpected error %v", err)
rtest.Assert(t, strings.Contains(err.Error(), "errfile"), "expected error to contain 'errfile' got: %v", err)
})
}
}