mirror of
https://github.com/seaweedfs/seaweedfs.git
synced 2025-01-12 07:42:16 +08:00
79 lines
2.2 KiB
Go
79 lines
2.2 KiB
Go
|
package storage
|
||
|
|
||
|
import (
|
||
|
"testing"
|
||
|
"time"
|
||
|
|
||
|
"github.com/seaweedfs/seaweedfs/weed/storage/backend"
|
||
|
"github.com/seaweedfs/seaweedfs/weed/storage/needle"
|
||
|
"github.com/seaweedfs/seaweedfs/weed/util"
|
||
|
)
|
||
|
|
||
|
type (
|
||
|
mockBackendStorageFile struct {
|
||
|
backend.DiskFile
|
||
|
|
||
|
datSize int64
|
||
|
}
|
||
|
)
|
||
|
|
||
|
func (df *mockBackendStorageFile) GetStat() (datSize int64, modTime time.Time, err error) {
|
||
|
return df.datSize, time.Now(), nil
|
||
|
}
|
||
|
|
||
|
type (
|
||
|
mockNeedleMapper struct {
|
||
|
NeedleMap
|
||
|
|
||
|
idxSize uint64
|
||
|
}
|
||
|
)
|
||
|
|
||
|
func (nm *mockNeedleMapper) IndexFileSize() (idxSize uint64) {
|
||
|
return nm.idxSize
|
||
|
}
|
||
|
|
||
|
func TestUnUsedSpace(t *testing.T) {
|
||
|
minFreeSpace := util.MinFreeSpace{Type: util.AsPercent, Percent: 1, Raw: "1"}
|
||
|
|
||
|
diskLocation := DiskLocation{
|
||
|
Directory: "/test/",
|
||
|
DirectoryUuid: "1234",
|
||
|
IdxDirectory: "/test/",
|
||
|
DiskType: "hdd",
|
||
|
MaxVolumeCount: 0,
|
||
|
OriginalMaxVolumeCount: 0,
|
||
|
MinFreeSpace: minFreeSpace,
|
||
|
}
|
||
|
diskLocation.volumes = make(map[needle.VolumeId]*Volume)
|
||
|
|
||
|
volumes := [3]*Volume{
|
||
|
{dir: diskLocation.Directory, dirIdx: diskLocation.IdxDirectory, Collection: "", Id: 0, DataBackend: &mockBackendStorageFile{datSize: 990}, nm: &mockNeedleMapper{idxSize: 10}},
|
||
|
{dir: diskLocation.Directory, dirIdx: diskLocation.IdxDirectory, Collection: "", Id: 1, DataBackend: &mockBackendStorageFile{datSize: 990}, nm: &mockNeedleMapper{idxSize: 10}},
|
||
|
{dir: diskLocation.Directory, dirIdx: diskLocation.IdxDirectory, Collection: "", Id: 2, DataBackend: &mockBackendStorageFile{datSize: 990}, nm: &mockNeedleMapper{idxSize: 10}},
|
||
|
}
|
||
|
|
||
|
for i, vol := range volumes {
|
||
|
diskLocation.SetVolume(needle.VolumeId(i), vol)
|
||
|
}
|
||
|
|
||
|
// Testing when there's still space
|
||
|
unUsedSpace := diskLocation.UnUsedSpace(1200)
|
||
|
if unUsedSpace != 600 {
|
||
|
t.Errorf("unUsedSpace incorrect: %d != %d", unUsedSpace, 1500)
|
||
|
}
|
||
|
|
||
|
// Testing when there's exactly 0 space
|
||
|
unUsedSpace = diskLocation.UnUsedSpace(1000)
|
||
|
if unUsedSpace != 0 {
|
||
|
t.Errorf("unUsedSpace incorrect: %d != %d", unUsedSpace, 0)
|
||
|
}
|
||
|
|
||
|
// Testing when there's negative free space
|
||
|
unUsedSpace = diskLocation.UnUsedSpace(900)
|
||
|
if unUsedSpace != 0 {
|
||
|
t.Errorf("unUsedSpace incorrect: %d != %d", unUsedSpace, 0)
|
||
|
}
|
||
|
|
||
|
}
|