Chris Lu
7 years ago
3 changed files with 460 additions and 13 deletions
@ -0,0 +1,112 @@ |
|||||
|
package filer2 |
||||
|
|
||||
|
import ( |
||||
|
"testing" |
||||
|
"github.com/chrislusf/seaweedfs/weed/pb/filer_pb" |
||||
|
"log" |
||||
|
) |
||||
|
|
||||
|
func TestIntervalMerging(t *testing.T) { |
||||
|
|
||||
|
testcases := []struct { |
||||
|
Chunks []*filer_pb.FileChunk |
||||
|
Expected []*visibleInterval |
||||
|
}{ |
||||
|
// case 0: normal
|
||||
|
{ |
||||
|
Chunks: []*filer_pb.FileChunk{ |
||||
|
{Offset: 0, Size: 100, FileId: "abc", Mtime: 123}, |
||||
|
{Offset: 100, Size: 100, FileId: "asdf", Mtime: 134}, |
||||
|
{Offset: 200, Size: 100, FileId: "fsad", Mtime: 353}, |
||||
|
}, |
||||
|
Expected: []*visibleInterval{ |
||||
|
{start: 0, stop: 100, fileId: "abc"}, |
||||
|
{start: 100, stop: 200, fileId: "asdf"}, |
||||
|
{start: 200, stop: 300, fileId: "fsad"}, |
||||
|
}, |
||||
|
}, |
||||
|
// case 1: updates overwrite full chunks
|
||||
|
{ |
||||
|
Chunks: []*filer_pb.FileChunk{ |
||||
|
{Offset: 0, Size: 100, FileId: "abc", Mtime: 123}, |
||||
|
{Offset: 0, Size: 200, FileId: "asdf", Mtime: 134}, |
||||
|
}, |
||||
|
Expected: []*visibleInterval{ |
||||
|
{start: 0, stop: 200, fileId: "asdf"}, |
||||
|
}, |
||||
|
}, |
||||
|
// case 2: updates overwrite part of previous chunks
|
||||
|
{ |
||||
|
Chunks: []*filer_pb.FileChunk{ |
||||
|
{Offset: 0, Size: 100, FileId: "abc", Mtime: 123}, |
||||
|
{Offset: 0, Size: 50, FileId: "asdf", Mtime: 134}, |
||||
|
}, |
||||
|
Expected: []*visibleInterval{ |
||||
|
{start: 0, stop: 50, fileId: "asdf"}, |
||||
|
{start: 50, stop: 100, fileId: "abc"}, |
||||
|
}, |
||||
|
}, |
||||
|
// case 3: updates overwrite full chunks
|
||||
|
{ |
||||
|
Chunks: []*filer_pb.FileChunk{ |
||||
|
{Offset: 0, Size: 100, FileId: "abc", Mtime: 123}, |
||||
|
{Offset: 0, Size: 200, FileId: "asdf", Mtime: 134}, |
||||
|
{Offset: 50, Size: 250, FileId: "xxxx", Mtime: 154}, |
||||
|
}, |
||||
|
Expected: []*visibleInterval{ |
||||
|
{start: 0, stop: 50, fileId: "asdf"}, |
||||
|
{start: 50, stop: 300, fileId: "xxxx"}, |
||||
|
}, |
||||
|
}, |
||||
|
// case 4: updates far away from prev chunks
|
||||
|
{ |
||||
|
Chunks: []*filer_pb.FileChunk{ |
||||
|
{Offset: 0, Size: 100, FileId: "abc", Mtime: 123}, |
||||
|
{Offset: 0, Size: 200, FileId: "asdf", Mtime: 134}, |
||||
|
{Offset: 250, Size: 250, FileId: "xxxx", Mtime: 154}, |
||||
|
}, |
||||
|
Expected: []*visibleInterval{ |
||||
|
{start: 0, stop: 200, fileId: "asdf"}, |
||||
|
{start: 250, stop: 500, fileId: "xxxx"}, |
||||
|
}, |
||||
|
}, |
||||
|
// case 5: updates overwrite full chunks
|
||||
|
{ |
||||
|
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: "abc", Mtime: 143}, |
||||
|
{Offset: 80, Size: 100, FileId: "xxxx", Mtime: 134}, |
||||
|
}, |
||||
|
Expected: []*visibleInterval{ |
||||
|
{start: 0, stop: 200, fileId: "asdf"}, |
||||
|
{start: 200, stop: 220, fileId: "abc"}, |
||||
|
}, |
||||
|
}, |
||||
|
} |
||||
|
|
||||
|
for i, testcase := range testcases { |
||||
|
log.Printf("++++++++++ merged test case %d ++++++++++++++++++++", i) |
||||
|
intervals := nonOverlappingVisibleIntervals(testcase.Chunks) |
||||
|
for x, interval := range intervals { |
||||
|
log.Printf("test case %d, interval %d, start=%d, stop=%d, fileId=%s", |
||||
|
i, x, interval.start, interval.stop, interval.fileId) |
||||
|
if interval.start != testcase.Expected[x].start { |
||||
|
t.Fatalf("failed on test case %d, interval %d, start %d, expect %d", |
||||
|
i, x, interval.start, testcase.Expected[x].start) |
||||
|
} |
||||
|
if interval.stop != testcase.Expected[x].stop { |
||||
|
t.Fatalf("failed on test case %d, interval %d, stop %d, expect %d", |
||||
|
i, x, interval.stop, testcase.Expected[x].stop) |
||||
|
} |
||||
|
if interval.fileId != testcase.Expected[x].fileId { |
||||
|
t.Fatalf("failed on test case %d, interval %d, chunkId %s, expect %s", |
||||
|
i, x, interval.fileId, testcase.Expected[x].fileId) |
||||
|
} |
||||
|
} |
||||
|
if len(intervals) != len(testcase.Expected) { |
||||
|
t.Fatalf("failed to compact test case %d, len %d expected %d", i, len(intervals), len(testcase.Expected)) |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
} |
Write
Preview
Loading…
Cancel
Save
Reference in new issue