2
2
mirror of https://github.com/octoleo/restic.git synced 2025-01-25 16:18:34 +00:00
restic/map_test.go

147 lines
2.6 KiB
Go
Raw Normal View History

2014-12-05 21:45:49 +01:00
package restic_test
2014-11-21 21:21:44 +01:00
import (
"crypto/rand"
"encoding/json"
"flag"
"io"
mrand "math/rand"
"sync"
"testing"
"time"
2014-12-05 21:45:49 +01:00
"github.com/restic/restic"
"github.com/restic/restic/backend"
2015-04-09 21:15:48 +02:00
. "github.com/restic/restic/test"
2014-11-21 21:21:44 +01:00
)
var maxWorkers = flag.Uint("workers", 20, "number of workers to test Map concurrent access against")
2014-11-21 21:21:44 +01:00
func randomID() []byte {
buf := make([]byte, backend.IDSize)
2014-11-21 21:21:44 +01:00
_, err := io.ReadFull(rand.Reader, buf)
if err != nil {
panic(err)
}
return buf
}
2014-12-05 21:45:49 +01:00
func newBlob() restic.Blob {
return restic.Blob{
ID: randomID(),
Size: uint64(mrand.Uint32()),
Storage: randomID(),
StorageSize: uint64(mrand.Uint32()),
}
2014-11-21 21:21:44 +01:00
}
// Test basic functionality
func TestMap(t *testing.T) {
bl := restic.NewMap()
2014-11-21 21:21:44 +01:00
b := newBlob()
bl.Insert(b)
for i := 0; i < 1000; i++ {
bl.Insert(newBlob())
}
b2, err := bl.Find(restic.Blob{ID: b.ID, Size: b.Size})
2015-04-09 21:15:48 +02:00
OK(t, err)
Assert(t, b2.Compare(b) == 0, "items are not equal: want %v, got %v", b, b2)
b2, err = bl.FindID(b.ID)
2015-04-09 21:15:48 +02:00
OK(t, err)
Assert(t, b2.Compare(b) == 0, "items are not equal: want %v, got %v", b, b2)
2014-11-21 21:21:44 +01:00
bl2 := restic.NewMap()
2014-11-21 21:21:44 +01:00
for i := 0; i < 1000; i++ {
bl.Insert(newBlob())
}
b2, err = bl2.Find(b)
2015-04-09 21:15:48 +02:00
Assert(t, err != nil, "found ID in restic that was never inserted: %v", b2)
2014-11-21 21:21:44 +01:00
bl2.Merge(bl)
b2, err = bl2.Find(b)
if err != nil {
t.Fatal(err)
}
if b.Compare(b2) != 0 {
t.Fatalf("items are not equal: want %v, got %v", b, b2)
}
}
// Test JSON encode/decode
func TestMapJSON(t *testing.T) {
bl := restic.NewMap()
2014-12-05 21:45:49 +01:00
b := restic.Blob{ID: randomID()}
2014-11-21 21:21:44 +01:00
bl.Insert(b)
b2, err := bl.Find(b)
2015-04-09 21:15:48 +02:00
OK(t, err)
Assert(t, b2.Compare(b) == 0, "items are not equal: want %v, got %v", b, b2)
2014-11-21 21:21:44 +01:00
buf, err := json.Marshal(bl)
2015-04-09 21:15:48 +02:00
OK(t, err)
2014-11-21 21:21:44 +01:00
bl2 := restic.Map{}
2014-11-21 21:21:44 +01:00
json.Unmarshal(buf, &bl2)
b2, err = bl2.Find(b)
2015-04-09 21:15:48 +02:00
OK(t, err)
Assert(t, b2.Compare(b) == 0, "items are not equal: want %v, got %v", b, b2)
2014-11-21 21:21:44 +01:00
buf, err = json.Marshal(bl2)
2015-04-09 21:15:48 +02:00
OK(t, err)
2014-11-21 21:21:44 +01:00
}
// random insert/find access by several goroutines
func TestMapRandom(t *testing.T) {
2014-11-21 21:21:44 +01:00
var wg sync.WaitGroup
worker := func(bl *restic.Map) {
2014-11-21 21:21:44 +01:00
defer wg.Done()
b := newBlob()
bl.Insert(b)
for i := 0; i < 200; i++ {
bl.Insert(newBlob())
}
d := time.Duration(mrand.Intn(10)*100) * time.Millisecond
time.Sleep(d)
for i := 0; i < 100; i++ {
b2, err := bl.Find(b)
if err != nil {
t.Fatal(err)
}
if b.Compare(b2) != 0 {
t.Fatalf("items are not equal: want %v, got %v", b, b2)
}
}
bl2 := restic.NewMap()
2014-11-21 21:21:44 +01:00
for i := 0; i < 200; i++ {
bl2.Insert(newBlob())
}
bl2.Merge(bl)
}
bl := restic.NewMap()
2014-11-21 21:21:44 +01:00
for i := 0; uint(i) < *maxWorkers; i++ {
wg.Add(1)
go worker(bl)
}
wg.Wait()
}