@ -1,12 +1,11 @@
package filer2
package filer2
import (
import (
"fmt"
"log"
"log"
"math"
"math"
"testing"
"testing"
"fmt"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/assert"
"github.com/chrislusf/seaweedfs/weed/pb/filer_pb"
"github.com/chrislusf/seaweedfs/weed/pb/filer_pb"
@ -95,12 +94,12 @@ func TestIntervalMerging(t *testing.T) {
// case 2: updates overwrite part of previous chunks
// case 2: updates overwrite part of previous chunks
{
{
Chunks : [ ] * filer_pb . FileChunk {
Chunks : [ ] * filer_pb . FileChunk {
{ Offset : 0 , Size : 100 , FileId : "abc " , Mtime : 123 } ,
{ Offset : 0 , Size : 5 0, FileId : "asdf " , Mtime : 134 } ,
{ Offset : 0 , Size : 100 , FileId : "a" , Mtime : 123 } ,
{ Offset : 0 , Size : 7 0, FileId : "b " , Mtime : 134 } ,
} ,
} ,
Expected : [ ] * VisibleInterval {
Expected : [ ] * VisibleInterval {
{ start : 0 , stop : 5 0, fileId : "asdf " } ,
{ start : 5 0, stop : 100 , fileId : "abc " } ,
{ start : 0 , stop : 7 0, fileId : "b " } ,
{ start : 7 0, stop : 100 , fileId : "a" , chunkOffset : 70 } ,
} ,
} ,
} ,
} ,
// case 3: updates overwrite full chunks
// case 3: updates overwrite full chunks
@ -130,14 +129,14 @@ func TestIntervalMerging(t *testing.T) {
// case 5: updates overwrite full chunks
// case 5: updates overwrite full chunks
{
{
Chunks : [ ] * filer_pb . FileChunk {
Chunks : [ ] * filer_pb . FileChunk {
{ Offset : 0 , Size : 100 , FileId : "abc " , Mtime : 123 } ,
{ Offset : 0 , Size : 200 , FileId : "as df " , Mtime : 184 } ,
{ Offset : 70 , Size : 150 , FileId : "ab c" , Mtime : 143 } ,
{ Offset : 80 , Size : 100 , FileId : "xxxx " , Mtime : 134 } ,
{ Offset : 0 , Size : 100 , FileId : "a" , Mtime : 123 } ,
{ Offset : 0 , Size : 200 , FileId : "d" , Mtime : 184 } ,
{ Offset : 70 , Size : 150 , FileId : "c" , Mtime : 143 } ,
{ Offset : 80 , Size : 100 , FileId : "b " , Mtime : 134 } ,
} ,
} ,
Expected : [ ] * VisibleInterval {
Expected : [ ] * VisibleInterval {
{ start : 0 , stop : 200 , fileId : "as df " } ,
{ start : 200 , stop : 220 , fileId : "ab c" } ,
{ start : 0 , stop : 200 , fileId : "d" } ,
{ start : 200 , stop : 220 , fileId : "c" , chunkOffset : 130 } ,
} ,
} ,
} ,
} ,
// case 6: same updates
// case 6: same updates
@ -208,6 +207,10 @@ func TestIntervalMerging(t *testing.T) {
t . Fatalf ( "failed on test case %d, interval %d, chunkId %s, expect %s" ,
t . Fatalf ( "failed on test case %d, interval %d, chunkId %s, expect %s" ,
i , x , interval . fileId , testcase . Expected [ x ] . fileId )
i , x , interval . fileId , testcase . Expected [ x ] . fileId )
}
}
if interval . chunkOffset != testcase . Expected [ x ] . chunkOffset {
t . Fatalf ( "failed on test case %d, interval %d, chunkOffset %d, expect %d" ,
i , x , interval . chunkOffset , testcase . Expected [ x ] . chunkOffset )
}
}
}
if len ( intervals ) != len ( testcase . Expected ) {
if len ( intervals ) != len ( testcase . Expected ) {
t . Fatalf ( "failed to compact test case %d, len %d expected %d" , i , len ( intervals ) , len ( testcase . Expected ) )
t . Fatalf ( "failed to compact test case %d, len %d expected %d" , i , len ( intervals ) , len ( testcase . Expected ) )
@ -255,14 +258,14 @@ func TestChunksReading(t *testing.T) {
// case 2: updates overwrite part of previous chunks
// case 2: updates overwrite part of previous chunks
{
{
Chunks : [ ] * filer_pb . FileChunk {
Chunks : [ ] * filer_pb . FileChunk {
{ Offset : 0 , Size : 100 , FileId : "abc " , Mtime : 123 } ,
{ Offset : 0 , Size : 50 , FileId : "asdf " , Mtime : 134 } ,
{ Offset : 3 , Size : 100 , FileId : "a" , Mtime : 123 } ,
{ Offset : 1 0, Size : 50 , FileId : "b " , Mtime : 134 } ,
} ,
} ,
Offset : 25 ,
Size : 5 0,
Offset : 30 ,
Size : 4 0,
Expected : [ ] * ChunkView {
Expected : [ ] * ChunkView {
{ Offset : 25 , Size : 25 , FileId : "asdf " , LogicOffset : 25 } ,
{ Offset : 0 , Size : 25 , FileId : "abc " , LogicOffset : 5 0} ,
{ Offset : 20 , Size : 30 , FileId : "b " , LogicOffset : 30 } ,
{ Offset : 57 , Size : 10 , FileId : "a" , LogicOffset : 6 0} ,
} ,
} ,
} ,
} ,
// case 3: updates overwrite full chunks
// case 3: updates overwrite full chunks
@ -296,16 +299,16 @@ func TestChunksReading(t *testing.T) {
// case 5: updates overwrite full chunks
// case 5: updates overwrite full chunks
{
{
Chunks : [ ] * filer_pb . FileChunk {
Chunks : [ ] * filer_pb . FileChunk {
{ Offset : 0 , Size : 100 , FileId : "abc " , Mtime : 123 } ,
{ Offset : 0 , Size : 200 , FileId : "asdf " , Mtime : 184 } ,
{ Offset : 70 , Size : 150 , FileId : "a bc " , Mtime : 143 } ,
{ Offset : 0 , Size : 100 , FileId : "a" , Mtime : 123 } ,
{ Offset : 0 , Size : 200 , FileId : "c " , Mtime : 184 } ,
{ Offset : 70 , Size : 150 , FileId : "b" , Mtime : 143 } ,
{ Offset : 80 , Size : 100 , FileId : "xxxx" , Mtime : 134 } ,
{ Offset : 80 , Size : 100 , FileId : "xxxx" , Mtime : 134 } ,
} ,
} ,
Offset : 0 ,
Offset : 0 ,
Size : 220 ,
Size : 220 ,
Expected : [ ] * ChunkView {
Expected : [ ] * ChunkView {
{ Offset : 0 , Size : 200 , FileId : "asdf " , LogicOffset : 0 } ,
{ Offset : 0 , Size : 20 , FileId : "a bc " , LogicOffset : 200 } ,
{ Offset : 0 , Size : 200 , FileId : "c " , LogicOffset : 0 } ,
{ Offset : 13 0, Size : 20 , FileId : "b" , LogicOffset : 200 } ,
} ,
} ,
} ,
} ,
// case 6: same updates
// case 6: same updates
@ -374,18 +377,21 @@ func TestChunksReading(t *testing.T) {
}
}
for i , testcase := range testcases {
for i , testcase := range testcases {
if i != 2 {
// continue
}
log . Printf ( "++++++++++ read test case %d ++++++++++++++++++++" , i )
log . Printf ( "++++++++++ read test case %d ++++++++++++++++++++" , i )
chunks := ViewFromChunks ( nil , testcase . Chunks , testcase . Offset , testcase . Size )
chunks := ViewFromChunks ( nil , testcase . Chunks , testcase . Offset , testcase . Size )
for x , chunk := range chunks {
for x , chunk := range chunks {
log . Printf ( "read case %d, chunk %d, offset=%d, size=%d, fileId=%s" ,
log . Printf ( "read case %d, chunk %d, offset=%d, size=%d, fileId=%s" ,
i , x , chunk . Offset , chunk . Size , chunk . FileId )
i , x , chunk . Offset , chunk . Size , chunk . FileId )
if chunk . Offset != testcase . Expected [ x ] . Offset {
if chunk . Offset != testcase . Expected [ x ] . Offset {
t . Fatalf ( "failed on read case %d, chunk %d , Offset %d, expect %d" ,
i , x , chunk . Offset , testcase . Expected [ x ] . Offset )
t . Fatalf ( "failed on read case %d, chunk %s , Offset %d, expect %d" ,
i , chunk . FileId , chunk . Offset , testcase . Expected [ x ] . Offset )
}
}
if chunk . Size != testcase . Expected [ x ] . Size {
if chunk . Size != testcase . Expected [ x ] . Size {
t . Fatalf ( "failed on read case %d, chunk %d , Size %d, expect %d" ,
i , x , chunk . Size , testcase . Expected [ x ] . Size )
t . Fatalf ( "failed on read case %d, chunk %s , Size %d, expect %d" ,
i , chunk . FileId , chunk . Size , testcase . Expected [ x ] . Size )
}
}
if chunk . FileId != testcase . Expected [ x ] . FileId {
if chunk . FileId != testcase . Expected [ x ] . FileId {
t . Fatalf ( "failed on read case %d, chunk %d, FileId %s, expect %s" ,
t . Fatalf ( "failed on read case %d, chunk %d, FileId %s, expect %s" ,
@ -449,3 +455,47 @@ func TestViewFromVisibleIntervals(t *testing.T) {
}
}
}
}
func TestViewFromVisibleIntervals2 ( t * testing . T ) {
visibles := [ ] VisibleInterval {
{
start : 344064 ,
stop : 348160 ,
fileId : "fid1" ,
} ,
{
start : 348160 ,
stop : 356352 ,
fileId : "fid2" ,
} ,
}
views := ViewFromVisibleIntervals ( visibles , 0 , math . MaxInt32 )
if len ( views ) != len ( visibles ) {
assert . Equal ( t , len ( visibles ) , len ( views ) , "ViewFromVisibleIntervals error" )
}
}
func TestViewFromVisibleIntervals3 ( t * testing . T ) {
visibles := [ ] VisibleInterval {
{
start : 1000 ,
stop : 2000 ,
fileId : "fid1" ,
} ,
{
start : 3000 ,
stop : 4000 ,
fileId : "fid2" ,
} ,
}
views := ViewFromVisibleIntervals ( visibles , 1700 , 1500 )
if len ( views ) != len ( visibles ) {
assert . Equal ( t , len ( visibles ) , len ( views ) , "ViewFromVisibleIntervals error" )
}
}