lotus/storage/sector/store_test.go

83 lines
1.9 KiB
Go
Raw Normal View History

2019-11-06 12:03:36 +00:00
package sector
import (
2019-11-06 01:22:16 +00:00
"context"
"fmt"
"io"
"math/rand"
2019-11-06 12:03:36 +00:00
"testing"
2019-11-06 23:09:48 +00:00
"github.com/stretchr/testify/assert"
2019-11-06 01:22:16 +00:00
"github.com/filecoin-project/lotus/build"
2019-11-06 23:09:48 +00:00
"github.com/filecoin-project/lotus/lib/sectorbuilder"
2019-11-06 01:22:16 +00:00
"github.com/ipfs/go-datastore"
2019-11-06 12:03:36 +00:00
)
2019-11-06 23:09:48 +00:00
func testFill(t *testing.T, n uint64, exp []uint64) {
f, err := fillersFromRem(n)
assert.NoError(t, err)
assert.Equal(t, exp, f)
var sum uint64
for _, u := range f {
sum += u
}
assert.Equal(t, n, sum)
}
func TestFillersFromRem(t *testing.T) {
for i := 8; i < 32; i++ {
// single
ub := sectorbuilder.UserBytesForSectorSize(uint64(1) << i)
testFill(t, ub, []uint64{ub})
// 2
ub = sectorbuilder.UserBytesForSectorSize(uint64(5) << i)
ub1 := sectorbuilder.UserBytesForSectorSize(uint64(1) << i)
ub3 := sectorbuilder.UserBytesForSectorSize(uint64(4) << i)
testFill(t, ub, []uint64{ub1, ub3})
// 4
ub = sectorbuilder.UserBytesForSectorSize(uint64(15) << i)
ub2 := sectorbuilder.UserBytesForSectorSize(uint64(2) << i)
ub4 := sectorbuilder.UserBytesForSectorSize(uint64(8) << i)
testFill(t, ub, []uint64{ub1, ub2, ub3, ub4})
// different 2
ub = sectorbuilder.UserBytesForSectorSize(uint64(9) << i)
testFill(t, ub, []uint64{ub1, ub4})
}
2019-11-06 12:04:33 +00:00
}
2019-11-06 01:22:16 +00:00
func TestSectorStore(t *testing.T) {
if err := build.GetParams(true); err != nil {
t.Fatal(err)
}
sb, cleanup, err := sectorbuilder.TempSectorbuilder(1024)
if err != nil {
t.Fatal(err)
}
defer cleanup()
tktFn := func(context.Context) (*sectorbuilder.SealTicket, error) {
return &sectorbuilder.SealTicket{
BlockHeight: 17,
TicketBytes: [32]byte{1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2},
}, nil
}
ds := datastore.NewMapDatastore()
store := NewStore(sb, ds, tktFn)
pr := io.LimitReader(rand.New(rand.NewSource(17)), 300)
sid, err := store.AddPiece("a", 300, pr, 1)
if err != nil {
t.Fatal(err)
}
fmt.Println(sid)
}