mirror of
https://github.com/seaweedfs/seaweedfs.git
synced 2025-09-20 11:47:57 +08:00
mount: add on disk caching
This commit is contained in:
58
weed/util/chunk_cache/chunk_cache_on_disk_test.go
Normal file
58
weed/util/chunk_cache/chunk_cache_on_disk_test.go
Normal file
@@ -0,0 +1,58 @@
|
||||
package chunk_cache
|
||||
|
||||
import (
|
||||
"bytes"
|
||||
"fmt"
|
||||
"io/ioutil"
|
||||
"math/rand"
|
||||
"os"
|
||||
"testing"
|
||||
)
|
||||
|
||||
func TestOnDisk(t *testing.T) {
|
||||
|
||||
tmpDir, _ := ioutil.TempDir("", "c")
|
||||
defer os.RemoveAll(tmpDir)
|
||||
|
||||
totalDiskSizeMb := int64(6)
|
||||
segmentCount := 2
|
||||
|
||||
cache := NewChunkCache(0, tmpDir, totalDiskSizeMb, segmentCount)
|
||||
|
||||
writeCount := 5
|
||||
type test_data struct {
|
||||
data []byte
|
||||
fileId string
|
||||
}
|
||||
testData := make([]*test_data, writeCount)
|
||||
for i:=0;i<writeCount;i++{
|
||||
buff := make([]byte, 1024*1024)
|
||||
rand.Read(buff)
|
||||
testData[i] = &test_data{
|
||||
data: buff,
|
||||
fileId: fmt.Sprintf("1,%daabbccdd", i+1),
|
||||
}
|
||||
cache.SetChunk(testData[i].fileId, testData[i].data)
|
||||
}
|
||||
|
||||
for i:=0;i<writeCount;i++{
|
||||
data := cache.GetChunk(testData[i].fileId)
|
||||
if bytes.Compare(data, testData[i].data) != 0 {
|
||||
t.Errorf("failed to write to and read from cache: %d", i)
|
||||
}
|
||||
}
|
||||
|
||||
cache.Shutdown()
|
||||
|
||||
cache = NewChunkCache(0, tmpDir, totalDiskSizeMb, segmentCount)
|
||||
|
||||
for i:=0;i<writeCount;i++{
|
||||
data := cache.GetChunk(testData[i].fileId)
|
||||
if bytes.Compare(data, testData[i].data) != 0 {
|
||||
t.Errorf("failed to write to and read from cache: %d", i)
|
||||
}
|
||||
}
|
||||
|
||||
cache.Shutdown()
|
||||
|
||||
}
|
Reference in New Issue
Block a user