forked from TrueCloudLab/frostfs-node
59 lines
1.3 KiB
Go
59 lines
1.3 KiB
Go
|
package meta_test
|
||
|
|
||
|
import (
|
||
|
"strconv"
|
||
|
"testing"
|
||
|
|
||
|
"github.com/nspcc-dev/neofs-api-go/pkg/object"
|
||
|
objectV2 "github.com/nspcc-dev/neofs-api-go/v2/object"
|
||
|
meta "github.com/nspcc-dev/neofs-node/pkg/local_object_storage/metabase"
|
||
|
"github.com/stretchr/testify/require"
|
||
|
)
|
||
|
|
||
|
func TestDB_IterateExpired(t *testing.T) {
|
||
|
db := newDB(t)
|
||
|
defer releaseDB(db)
|
||
|
|
||
|
const epoch = 13
|
||
|
|
||
|
mAlive := map[object.Type]*object.Address{}
|
||
|
mExpired := map[object.Type]*object.Address{}
|
||
|
|
||
|
for _, typ := range []object.Type{
|
||
|
object.TypeRegular,
|
||
|
object.TypeTombstone,
|
||
|
object.TypeStorageGroup,
|
||
|
} {
|
||
|
mAlive[typ] = putWithExpiration(t, db, typ, epoch)
|
||
|
mExpired[typ] = putWithExpiration(t, db, typ, epoch-1)
|
||
|
}
|
||
|
|
||
|
err := db.IterateExpired(epoch, func(exp *meta.ExpiredObject) error {
|
||
|
if addr, ok := mAlive[exp.Type()]; ok {
|
||
|
require.NotEqual(t, addr, exp.Address())
|
||
|
}
|
||
|
|
||
|
addr, ok := mExpired[exp.Type()]
|
||
|
require.True(t, ok)
|
||
|
require.Equal(t, addr, exp.Address())
|
||
|
|
||
|
delete(mExpired, exp.Type())
|
||
|
|
||
|
return nil
|
||
|
})
|
||
|
require.NoError(t, err)
|
||
|
|
||
|
require.Empty(t, mExpired)
|
||
|
}
|
||
|
|
||
|
func putWithExpiration(t *testing.T, db *meta.DB, typ object.Type, expiresAt uint64) *object.Address {
|
||
|
raw := generateRawObject(t)
|
||
|
raw.SetType(typ)
|
||
|
addAttribute(raw, objectV2.SysAttributeExpEpoch, strconv.FormatUint(expiresAt, 10))
|
||
|
|
||
|
obj := raw.Object()
|
||
|
require.NoError(t, putBig(db, obj))
|
||
|
|
||
|
return obj.Address()
|
||
|
}
|