stlpmo-jn
6 years ago
4 changed files with 150 additions and 4 deletions
-
46weed/storage/needle/file_id.go
-
55weed/storage/needle/file_id_test.go
-
8weed/storage/needle/volume_id.go
-
45weed/storage/needle/volume_id_test.go
@ -0,0 +1,55 @@ |
|||
package needle |
|||
|
|||
import ( |
|||
"github.com/chrislusf/seaweedfs/weed/storage/types" |
|||
"testing" |
|||
) |
|||
|
|||
func TestParseFileIdFromString(t *testing.T) { |
|||
fidStr1 := "100,12345678" |
|||
_, err := ParseFileIdFromString(fidStr1) |
|||
if err == nil { |
|||
t.Errorf("%s : KeyHash is too short", fidStr1) |
|||
} |
|||
|
|||
fidStr1 = "100, 12345678" |
|||
_, err = ParseFileIdFromString(fidStr1) |
|||
if err == nil { |
|||
t.Errorf("%s : needlId invalid syntax", fidStr1) |
|||
} |
|||
|
|||
fidStr1 = "100,123456789" |
|||
_, err = ParseFileIdFromString(fidStr1) |
|||
if err != nil { |
|||
t.Errorf("%s : should be OK", fidStr1) |
|||
} |
|||
|
|||
var fileId *FileId |
|||
fidStr1 = "100,123456789012345678901234" |
|||
fileId, err = ParseFileIdFromString(fidStr1) |
|||
if err != nil { |
|||
t.Errorf("%s : should be OK", fidStr1) |
|||
} |
|||
if !(fileId.VolumeId == VolumeId(100) && |
|||
fileId.Key == types.NeedleId(0x1234567890123456) && |
|||
fileId.Cookie == types.Cookie(types.Uint32ToCookie(uint32(0x78901234)))) { |
|||
t.Errorf("src : %s, dest : %v", fidStr1, fileId) |
|||
} |
|||
|
|||
fidStr1 = "100,abcd0000abcd" |
|||
fileId, err = ParseFileIdFromString(fidStr1) |
|||
if err != nil { |
|||
t.Errorf("%s : should be OK", fidStr1) |
|||
} |
|||
if !(fileId.VolumeId == VolumeId(100) && |
|||
fileId.Key == types.NeedleId(0xabcd) && |
|||
fileId.Cookie == types.Cookie(types.Uint32ToCookie(uint32(0xabcd)))) { |
|||
t.Errorf("src : %s, dest : %v", fidStr1, fileId) |
|||
} |
|||
|
|||
fidStr1 = "100,1234567890123456789012345" |
|||
_, err = ParseFileIdFromString(fidStr1) |
|||
if err == nil { |
|||
t.Errorf("%s : needleId is too long", fidStr1) |
|||
} |
|||
} |
@ -0,0 +1,45 @@ |
|||
package needle |
|||
|
|||
import "testing" |
|||
|
|||
func TestNewVolumeId(t *testing.T) { |
|||
if _,err := NewVolumeId("1"); err != nil { |
|||
t.Error(err) |
|||
} |
|||
|
|||
if _, err := NewVolumeId("a");err != nil { |
|||
t.Logf("a is not legal volume id, %v", err) |
|||
} |
|||
} |
|||
|
|||
func TestVolumeId_String(t *testing.T) { |
|||
if str := VolumeId(10).String(); str != "10" { |
|||
t.Errorf("to string failed") |
|||
} |
|||
|
|||
vid := VolumeId(11) |
|||
if str := vid.String(); str != "11" { |
|||
t.Errorf("to string failed") |
|||
} |
|||
|
|||
pvid := &vid |
|||
if str := pvid.String(); str != "11" { |
|||
t.Errorf("to string failed") |
|||
} |
|||
} |
|||
|
|||
func TestVolumeId_Next(t *testing.T) { |
|||
if vid := VolumeId(10).Next(); vid != VolumeId(11) { |
|||
t.Errorf("get next volume id failed") |
|||
} |
|||
|
|||
vid := VolumeId(11) |
|||
if new := vid.Next(); new != 12 { |
|||
t.Errorf("get next volume id failed") |
|||
} |
|||
|
|||
pvid := &vid |
|||
if new := pvid.Next(); new != 12 { |
|||
t.Errorf("get next volume id failed") |
|||
} |
|||
} |
Write
Preview
Loading…
Cancel
Save
Reference in new issue