Parallelize longest tests #328
26 changed files with 212 additions and 81 deletions
|
@ -21,6 +21,7 @@ import (
|
||||||
"github.com/nspcc-dev/neo-go/pkg/wallet"
|
"github.com/nspcc-dev/neo-go/pkg/wallet"
|
||||||
"github.com/spf13/cobra"
|
"github.com/spf13/cobra"
|
||||||
"github.com/spf13/viper"
|
"github.com/spf13/viper"
|
||||||
|
"golang.org/x/sync/errgroup"
|
||||||
)
|
)
|
||||||
|
|
||||||
const (
|
const (
|
||||||
|
@ -92,28 +93,30 @@ func initializeWallets(v *viper.Viper, walletDir string, size int) ([]string, er
|
||||||
pubs[i] = w.Accounts[0].PrivateKey().PublicKey()
|
pubs[i] = w.Accounts[0].PrivateKey().PublicKey()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var errG errgroup.Group
|
||||||
|
|
||||||
// Create committee account with N/2+1 multi-signature.
|
// Create committee account with N/2+1 multi-signature.
|
||||||
majCount := smartcontract.GetMajorityHonestNodeCount(size)
|
majCount := smartcontract.GetMajorityHonestNodeCount(size)
|
||||||
for i, w := range wallets {
|
|
||||||
if err := addMultisigAccount(w, majCount, committeeAccountName, passwords[i], pubs); err != nil {
|
|
||||||
return nil, fmt.Errorf("can't create committee account: %w", err)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Create consensus account with 2*N/3+1 multi-signature.
|
// Create consensus account with 2*N/3+1 multi-signature.
|
||||||
bftCount := smartcontract.GetDefaultHonestNodeCount(size)
|
bftCount := smartcontract.GetDefaultHonestNodeCount(size)
|
||||||
for i, w := range wallets {
|
for i := range wallets {
|
||||||
if err := addMultisigAccount(w, bftCount, consensusAccountName, passwords[i], pubs); err != nil {
|
i := i
|
||||||
return nil, fmt.Errorf("can't create consensus account: %w", err)
|
errG.Go(func() error {
|
||||||
|
if err := addMultisigAccount(wallets[i], majCount, committeeAccountName, passwords[i], pubs); err != nil {
|
||||||
|
return fmt.Errorf("can't create committee account: %w", err)
|
||||||
}
|
}
|
||||||
|
if err := addMultisigAccount(wallets[i], bftCount, consensusAccountName, passwords[i], pubs); err != nil {
|
||||||
|
return fmt.Errorf("can't create consentus account: %w", err)
|
||||||
}
|
}
|
||||||
|
if err := wallets[i].SavePretty(); err != nil {
|
||||||
for _, w := range wallets {
|
return fmt.Errorf("can't save wallet: %w", err)
|
||||||
if err := w.SavePretty(); err != nil {
|
|
||||||
return nil, fmt.Errorf("can't save wallet: %w", err)
|
|
||||||
}
|
}
|
||||||
|
return nil
|
||||||
|
})
|
||||||
|
}
|
||||||
|
if err := errG.Wait(); err != nil {
|
||||||
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
return passwords, nil
|
return passwords, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -7,6 +7,7 @@ import (
|
||||||
"os"
|
"os"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
"strconv"
|
"strconv"
|
||||||
|
"sync"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"git.frostfs.info/TrueCloudLab/frostfs-node/pkg/innerring"
|
"git.frostfs.info/TrueCloudLab/frostfs-node/pkg/innerring"
|
||||||
|
@ -71,11 +72,16 @@ func TestGenerateAlphabet(t *testing.T) {
|
||||||
buf.WriteString(testContractPassword + "\r")
|
buf.WriteString(testContractPassword + "\r")
|
||||||
require.NoError(t, generateAlphabetCreds(generateAlphabetCmd, nil))
|
require.NoError(t, generateAlphabetCreds(generateAlphabetCmd, nil))
|
||||||
|
|
||||||
|
var wg sync.WaitGroup
|
||||||
for i := uint64(0); i < size; i++ {
|
for i := uint64(0); i < size; i++ {
|
||||||
|
i := i
|
||||||
|
go func() {
|
||||||
|
defer wg.Done()
|
||||||
p := filepath.Join(walletDir, innerring.GlagoliticLetter(i).String()+".json")
|
p := filepath.Join(walletDir, innerring.GlagoliticLetter(i).String()+".json")
|
||||||
w, err := wallet.NewWalletFromFile(p)
|
w, err := wallet.NewWalletFromFile(p)
|
||||||
require.NoError(t, err, "wallet doesn't exist")
|
require.NoError(t, err, "wallet doesn't exist")
|
||||||
require.Equal(t, 3, len(w.Accounts), "not all accounts were created")
|
require.Equal(t, 3, len(w.Accounts), "not all accounts were created")
|
||||||
|
|
||||||
for _, a := range w.Accounts {
|
for _, a := range w.Accounts {
|
||||||
err := a.Decrypt(strconv.FormatUint(i, 10), keys.NEP2ScryptParams())
|
err := a.Decrypt(strconv.FormatUint(i, 10), keys.NEP2ScryptParams())
|
||||||
require.NoError(t, err, "can't decrypt account")
|
require.NoError(t, err, "can't decrypt account")
|
||||||
|
@ -88,7 +94,9 @@ func TestGenerateAlphabet(t *testing.T) {
|
||||||
require.Equal(t, singleAccountName, a.Label)
|
require.Equal(t, singleAccountName, a.Label)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}()
|
||||||
}
|
}
|
||||||
|
wg.Wait()
|
||||||
|
|
||||||
t.Run("check contract group wallet", func(t *testing.T) {
|
t.Run("check contract group wallet", func(t *testing.T) {
|
||||||
p := filepath.Join(walletDir, contractWalletFilename)
|
p := filepath.Join(walletDir, contractWalletFilename)
|
||||||
|
|
|
@ -18,6 +18,8 @@ import (
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestDeleteBigObject(t *testing.T) {
|
func TestDeleteBigObject(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
defer os.RemoveAll(t.Name())
|
defer os.RemoveAll(t.Name())
|
||||||
|
|
||||||
cnr := cidtest.ID()
|
cnr := cidtest.ID()
|
||||||
|
|
|
@ -77,6 +77,8 @@ func newEngineEvacuate(t *testing.T, shardNum int, objPerShard int) (*StorageEng
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestEvacuateShard(t *testing.T) {
|
func TestEvacuateShard(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
const objPerShard = 3
|
const objPerShard = 3
|
||||||
|
|
||||||
e, ids, objects := newEngineEvacuate(t, 3, objPerShard)
|
e, ids, objects := newEngineEvacuate(t, 3, objPerShard)
|
||||||
|
@ -132,6 +134,8 @@ func TestEvacuateShard(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestEvacuateNetwork(t *testing.T) {
|
func TestEvacuateNetwork(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
var errReplication = errors.New("handler error")
|
var errReplication = errors.New("handler error")
|
||||||
|
|
||||||
acceptOneOf := func(objects []*objectSDK.Object, max int) func(context.Context, oid.Address, *objectSDK.Object) error {
|
acceptOneOf := func(objects []*objectSDK.Object, max int) func(context.Context, oid.Address, *objectSDK.Object) error {
|
||||||
|
@ -154,6 +158,7 @@ func TestEvacuateNetwork(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
t.Run("single shard", func(t *testing.T) {
|
t.Run("single shard", func(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
e, ids, objects := newEngineEvacuate(t, 1, 3)
|
e, ids, objects := newEngineEvacuate(t, 1, 3)
|
||||||
evacuateShardID := ids[0].String()
|
evacuateShardID := ids[0].String()
|
||||||
|
|
||||||
|
@ -173,6 +178,7 @@ func TestEvacuateNetwork(t *testing.T) {
|
||||||
require.Equal(t, 2, res.Count())
|
require.Equal(t, 2, res.Count())
|
||||||
})
|
})
|
||||||
t.Run("multiple shards, evacuate one", func(t *testing.T) {
|
t.Run("multiple shards, evacuate one", func(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
e, ids, objects := newEngineEvacuate(t, 2, 3)
|
e, ids, objects := newEngineEvacuate(t, 2, 3)
|
||||||
|
|
||||||
require.NoError(t, e.shards[ids[0].String()].SetMode(mode.ReadOnly))
|
require.NoError(t, e.shards[ids[0].String()].SetMode(mode.ReadOnly))
|
||||||
|
@ -195,6 +201,7 @@ func TestEvacuateNetwork(t *testing.T) {
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
t.Run("multiple shards, evacuate many", func(t *testing.T) {
|
t.Run("multiple shards, evacuate many", func(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
e, ids, objects := newEngineEvacuate(t, 4, 5)
|
e, ids, objects := newEngineEvacuate(t, 4, 5)
|
||||||
evacuateIDs := ids[0:3]
|
evacuateIDs := ids[0:3]
|
||||||
|
|
||||||
|
@ -229,6 +236,7 @@ func TestEvacuateNetwork(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestEvacuateCancellation(t *testing.T) {
|
func TestEvacuateCancellation(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
e, ids, _ := newEngineEvacuate(t, 2, 3)
|
e, ids, _ := newEngineEvacuate(t, 2, 3)
|
||||||
|
|
||||||
require.NoError(t, e.shards[ids[0].String()].SetMode(mode.ReadOnly))
|
require.NoError(t, e.shards[ids[0].String()].SetMode(mode.ReadOnly))
|
||||||
|
|
|
@ -29,6 +29,8 @@ func sortAddresses(addrWithType []object.AddressWithType) []object.AddressWithTy
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestListWithCursor(t *testing.T) {
|
func TestListWithCursor(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
tests := []struct {
|
tests := []struct {
|
||||||
name string
|
name string
|
||||||
shardNum int
|
shardNum int
|
||||||
|
@ -60,8 +62,10 @@ func TestListWithCursor(t *testing.T) {
|
||||||
batchSize: 100,
|
batchSize: 100,
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
for _, tt := range tests {
|
for i := range tests {
|
||||||
|
tt := tests[i]
|
||||||
t.Run(tt.name, func(t *testing.T) {
|
t.Run(tt.name, func(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
e := testNewEngine(t).setShardsNumOpts(t, tt.shardNum, func(id int) []shard.Option {
|
e := testNewEngine(t).setShardsNumOpts(t, tt.shardNum, func(id int) []shard.Option {
|
||||||
return []shard.Option{
|
return []shard.Option{
|
||||||
shard.WithLogger(&logger.Logger{Logger: zap.L()}),
|
shard.WithLogger(&logger.Logger{Logger: zap.L()}),
|
||||||
|
|
|
@ -31,6 +31,8 @@ func (t tss) IsTombstoneAvailable(ctx context.Context, _ oid.Address, epoch uint
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestLockUserScenario(t *testing.T) {
|
func TestLockUserScenario(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
// Tested user actions:
|
// Tested user actions:
|
||||||
// 1. stores some object
|
// 1. stores some object
|
||||||
// 2. locks the object
|
// 2. locks the object
|
||||||
|
@ -146,6 +148,8 @@ func TestLockUserScenario(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestLockExpiration(t *testing.T) {
|
func TestLockExpiration(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
// Tested scenario:
|
// Tested scenario:
|
||||||
// 1. some object is stored
|
// 1. some object is stored
|
||||||
// 2. lock object for it is stored, and the object is locked
|
// 2. lock object for it is stored, and the object is locked
|
||||||
|
@ -222,6 +226,8 @@ func TestLockExpiration(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestLockForceRemoval(t *testing.T) {
|
func TestLockForceRemoval(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
// Tested scenario:
|
// Tested scenario:
|
||||||
// 1. some object is stored
|
// 1. some object is stored
|
||||||
// 2. lock object for it is stored, and the object is locked
|
// 2. lock object for it is stored, and the object is locked
|
||||||
|
|
|
@ -17,6 +17,8 @@ import (
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestRebalance(t *testing.T) {
|
func TestRebalance(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
te := newEngineWithErrorThreshold(t, "", 0)
|
te := newEngineWithErrorThreshold(t, "", 0)
|
||||||
|
|
||||||
const (
|
const (
|
||||||
|
@ -101,6 +103,8 @@ loop:
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestRebalanceSingleThread(t *testing.T) {
|
func TestRebalanceSingleThread(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
te := newEngineWithErrorThreshold(t, "", 0)
|
te := newEngineWithErrorThreshold(t, "", 0)
|
||||||
|
|
||||||
obj := testutil.GenerateObjectWithCID(cidtest.ID())
|
obj := testutil.GenerateObjectWithCID(cidtest.ID())
|
||||||
|
|
|
@ -15,6 +15,8 @@ import (
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestDB_Containers(t *testing.T) {
|
func TestDB_Containers(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
db := newDB(t)
|
db := newDB(t)
|
||||||
|
|
||||||
const N = 10
|
const N = 10
|
||||||
|
@ -90,6 +92,8 @@ func TestDB_Containers(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestDB_ContainersCount(t *testing.T) {
|
func TestDB_ContainersCount(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
db := newDB(t)
|
db := newDB(t)
|
||||||
|
|
||||||
const R, T, SG, L = 10, 11, 12, 13 // amount of object per type
|
const R, T, SG, L = 10, 11, 12, 13 // amount of object per type
|
||||||
|
@ -133,6 +137,8 @@ func TestDB_ContainersCount(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestDB_ContainerSize(t *testing.T) {
|
func TestDB_ContainerSize(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
db := newDB(t)
|
db := newDB(t)
|
||||||
|
|
||||||
const (
|
const (
|
||||||
|
|
|
@ -2,6 +2,7 @@ package meta_test
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
|
"os"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
objectcore "git.frostfs.info/TrueCloudLab/frostfs-node/pkg/core/object"
|
objectcore "git.frostfs.info/TrueCloudLab/frostfs-node/pkg/core/object"
|
||||||
|
@ -16,19 +17,23 @@ import (
|
||||||
const objCount = 10
|
const objCount = 10
|
||||||
|
|
||||||
func TestCounters(t *testing.T) {
|
func TestCounters(t *testing.T) {
|
||||||
db := newDB(t)
|
t.Parallel()
|
||||||
|
t.Cleanup(func() {
|
||||||
var c meta.ObjectCounters
|
require.NoError(t, os.RemoveAll(t.Name()))
|
||||||
var err error
|
})
|
||||||
|
|
||||||
t.Run("defaults", func(t *testing.T) {
|
t.Run("defaults", func(t *testing.T) {
|
||||||
c, err = db.ObjectCounters()
|
t.Parallel()
|
||||||
|
db := newDB(t)
|
||||||
|
c, err := db.ObjectCounters()
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
require.Zero(t, c.Phy())
|
require.Zero(t, c.Phy())
|
||||||
require.Zero(t, c.Logic())
|
require.Zero(t, c.Logic())
|
||||||
})
|
})
|
||||||
|
|
||||||
t.Run("put", func(t *testing.T) {
|
t.Run("put", func(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
db := newDB(t)
|
||||||
oo := make([]*object.Object, 0, objCount)
|
oo := make([]*object.Object, 0, objCount)
|
||||||
for i := 0; i < objCount; i++ {
|
for i := 0; i < objCount; i++ {
|
||||||
oo = append(oo, testutil.GenerateObject())
|
oo = append(oo, testutil.GenerateObject())
|
||||||
|
@ -39,10 +44,10 @@ func TestCounters(t *testing.T) {
|
||||||
for i := 0; i < objCount; i++ {
|
for i := 0; i < objCount; i++ {
|
||||||
prm.SetObject(oo[i])
|
prm.SetObject(oo[i])
|
||||||
|
|
||||||
_, err = db.Put(context.Background(), prm)
|
_, err := db.Put(context.Background(), prm)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
c, err = db.ObjectCounters()
|
c, err := db.ObjectCounters()
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
require.Equal(t, uint64(i+1), c.Phy())
|
require.Equal(t, uint64(i+1), c.Phy())
|
||||||
|
@ -50,9 +55,9 @@ func TestCounters(t *testing.T) {
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
require.NoError(t, db.Reset())
|
|
||||||
|
|
||||||
t.Run("delete", func(t *testing.T) {
|
t.Run("delete", func(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
db := newDB(t)
|
||||||
oo := putObjs(t, db, objCount, false)
|
oo := putObjs(t, db, objCount, false)
|
||||||
|
|
||||||
var prm meta.DeletePrm
|
var prm meta.DeletePrm
|
||||||
|
@ -63,7 +68,7 @@ func TestCounters(t *testing.T) {
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
require.Equal(t, uint64(1), res.AvailableObjectsRemoved())
|
require.Equal(t, uint64(1), res.AvailableObjectsRemoved())
|
||||||
|
|
||||||
c, err = db.ObjectCounters()
|
c, err := db.ObjectCounters()
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
require.Equal(t, uint64(i), c.Phy())
|
require.Equal(t, uint64(i), c.Phy())
|
||||||
|
@ -71,9 +76,9 @@ func TestCounters(t *testing.T) {
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
require.NoError(t, db.Reset())
|
|
||||||
|
|
||||||
t.Run("inhume", func(t *testing.T) {
|
t.Run("inhume", func(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
db := newDB(t)
|
||||||
oo := putObjs(t, db, objCount, false)
|
oo := putObjs(t, db, objCount, false)
|
||||||
|
|
||||||
inhumedObjs := make([]oid.Address, objCount/2)
|
inhumedObjs := make([]oid.Address, objCount/2)
|
||||||
|
@ -94,16 +99,16 @@ func TestCounters(t *testing.T) {
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
require.Equal(t, uint64(len(inhumedObjs)), res.AvailableInhumed())
|
require.Equal(t, uint64(len(inhumedObjs)), res.AvailableInhumed())
|
||||||
|
|
||||||
c, err = db.ObjectCounters()
|
c, err := db.ObjectCounters()
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
require.Equal(t, uint64(objCount), c.Phy())
|
require.Equal(t, uint64(objCount), c.Phy())
|
||||||
require.Equal(t, uint64(objCount-len(inhumedObjs)), c.Logic())
|
require.Equal(t, uint64(objCount-len(inhumedObjs)), c.Logic())
|
||||||
})
|
})
|
||||||
|
|
||||||
require.NoError(t, db.Reset())
|
|
||||||
|
|
||||||
t.Run("put_split", func(t *testing.T) {
|
t.Run("put_split", func(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
db := newDB(t)
|
||||||
parObj := testutil.GenerateObject()
|
parObj := testutil.GenerateObject()
|
||||||
|
|
||||||
// put objects and check that parent info
|
// put objects and check that parent info
|
||||||
|
@ -116,16 +121,16 @@ func TestCounters(t *testing.T) {
|
||||||
|
|
||||||
require.NoError(t, putBig(db, o))
|
require.NoError(t, putBig(db, o))
|
||||||
|
|
||||||
c, err = db.ObjectCounters()
|
c, err := db.ObjectCounters()
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
require.Equal(t, uint64(i+1), c.Phy())
|
require.Equal(t, uint64(i+1), c.Phy())
|
||||||
require.Equal(t, uint64(i+1), c.Logic())
|
require.Equal(t, uint64(i+1), c.Logic())
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
require.NoError(t, db.Reset())
|
|
||||||
|
|
||||||
t.Run("delete_split", func(t *testing.T) {
|
t.Run("delete_split", func(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
db := newDB(t)
|
||||||
oo := putObjs(t, db, objCount, true)
|
oo := putObjs(t, db, objCount, true)
|
||||||
|
|
||||||
// delete objects that have parent info
|
// delete objects that have parent info
|
||||||
|
@ -141,9 +146,9 @@ func TestCounters(t *testing.T) {
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
require.NoError(t, db.Reset())
|
|
||||||
|
|
||||||
t.Run("inhume_split", func(t *testing.T) {
|
t.Run("inhume_split", func(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
db := newDB(t)
|
||||||
oo := putObjs(t, db, objCount, true)
|
oo := putObjs(t, db, objCount, true)
|
||||||
|
|
||||||
inhumedObjs := make([]oid.Address, objCount/2)
|
inhumedObjs := make([]oid.Address, objCount/2)
|
||||||
|
@ -160,10 +165,10 @@ func TestCounters(t *testing.T) {
|
||||||
prm.SetTombstoneAddress(oidtest.Address())
|
prm.SetTombstoneAddress(oidtest.Address())
|
||||||
prm.SetAddresses(inhumedObjs...)
|
prm.SetAddresses(inhumedObjs...)
|
||||||
|
|
||||||
_, err = db.Inhume(context.Background(), prm)
|
_, err := db.Inhume(context.Background(), prm)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
c, err = db.ObjectCounters()
|
c, err := db.ObjectCounters()
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
require.Equal(t, uint64(objCount), c.Phy())
|
require.Equal(t, uint64(objCount), c.Phy())
|
||||||
|
|
|
@ -10,6 +10,8 @@ import (
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestGeneric(t *testing.T) {
|
func TestGeneric(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
defer func() { _ = os.RemoveAll(t.Name()) }()
|
defer func() { _ = os.RemoveAll(t.Name()) }()
|
||||||
|
|
||||||
var n int
|
var n int
|
||||||
|
|
|
@ -66,6 +66,8 @@ func benchmarkListWithCursor(b *testing.B, db *meta.DB, batchSize int) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestLisObjectsWithCursor(t *testing.T) {
|
func TestLisObjectsWithCursor(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
db := newDB(t)
|
db := newDB(t)
|
||||||
|
|
||||||
const (
|
const (
|
||||||
|
@ -159,6 +161,8 @@ func TestLisObjectsWithCursor(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestAddObjectDuringListingWithCursor(t *testing.T) {
|
func TestAddObjectDuringListingWithCursor(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
db := newDB(t)
|
db := newDB(t)
|
||||||
|
|
||||||
const total = 5
|
const total = 5
|
||||||
|
|
|
@ -17,6 +17,8 @@ import (
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestDB_Lock(t *testing.T) {
|
func TestDB_Lock(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
cnr := cidtest.ID()
|
cnr := cidtest.ID()
|
||||||
db := newDB(t)
|
db := newDB(t)
|
||||||
|
|
||||||
|
@ -171,6 +173,8 @@ func TestDB_Lock(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestDB_Lock_Expired(t *testing.T) {
|
func TestDB_Lock_Expired(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
es := &epochState{e: 123}
|
es := &epochState{e: 123}
|
||||||
|
|
||||||
db := newDB(t, meta.WithEpochState(es))
|
db := newDB(t, meta.WithEpochState(es))
|
||||||
|
@ -192,6 +196,8 @@ func TestDB_Lock_Expired(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestDB_IsLocked(t *testing.T) {
|
func TestDB_IsLocked(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
db := newDB(t)
|
db := newDB(t)
|
||||||
|
|
||||||
// existing and locked objs
|
// existing and locked objs
|
||||||
|
|
|
@ -20,6 +20,8 @@ import (
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestDB_SelectUserAttributes(t *testing.T) {
|
func TestDB_SelectUserAttributes(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
db := newDB(t)
|
db := newDB(t)
|
||||||
|
|
||||||
cnr := cidtest.ID()
|
cnr := cidtest.ID()
|
||||||
|
@ -142,6 +144,8 @@ func TestDB_SelectUserAttributes(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestDB_SelectRootPhyParent(t *testing.T) {
|
func TestDB_SelectRootPhyParent(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
db := newDB(t)
|
db := newDB(t)
|
||||||
|
|
||||||
cnr := cidtest.ID()
|
cnr := cidtest.ID()
|
||||||
|
@ -293,6 +297,8 @@ func TestDB_SelectRootPhyParent(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestDB_SelectInhume(t *testing.T) {
|
func TestDB_SelectInhume(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
db := newDB(t)
|
db := newDB(t)
|
||||||
|
|
||||||
cnr := cidtest.ID()
|
cnr := cidtest.ID()
|
||||||
|
@ -325,6 +331,8 @@ func TestDB_SelectInhume(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestDB_SelectPayloadHash(t *testing.T) {
|
func TestDB_SelectPayloadHash(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
db := newDB(t)
|
db := newDB(t)
|
||||||
|
|
||||||
cnr := cidtest.ID()
|
cnr := cidtest.ID()
|
||||||
|
@ -393,6 +401,8 @@ func TestDB_SelectPayloadHash(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestDB_SelectWithSlowFilters(t *testing.T) {
|
func TestDB_SelectWithSlowFilters(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
db := newDB(t)
|
db := newDB(t)
|
||||||
|
|
||||||
cnr := cidtest.ID()
|
cnr := cidtest.ID()
|
||||||
|
@ -498,6 +508,8 @@ func TestDB_SelectWithSlowFilters(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestDB_SelectObjectID(t *testing.T) {
|
func TestDB_SelectObjectID(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
db := newDB(t)
|
db := newDB(t)
|
||||||
|
|
||||||
cnr := cidtest.ID()
|
cnr := cidtest.ID()
|
||||||
|
@ -611,6 +623,8 @@ func TestDB_SelectObjectID(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestDB_SelectSplitID(t *testing.T) {
|
func TestDB_SelectSplitID(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
db := newDB(t)
|
db := newDB(t)
|
||||||
|
|
||||||
cnr := cidtest.ID()
|
cnr := cidtest.ID()
|
||||||
|
@ -665,6 +679,8 @@ func TestDB_SelectSplitID(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestDB_SelectContainerID(t *testing.T) {
|
func TestDB_SelectContainerID(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
db := newDB(t)
|
db := newDB(t)
|
||||||
|
|
||||||
cnr := cidtest.ID()
|
cnr := cidtest.ID()
|
||||||
|
@ -750,6 +766,8 @@ func BenchmarkSelect(b *testing.B) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestExpiredObjects(t *testing.T) {
|
func TestExpiredObjects(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
db := newDB(t, meta.WithEpochState(epochState{currEpoch}))
|
db := newDB(t, meta.WithEpochState(epochState{currEpoch}))
|
||||||
|
|
||||||
checkExpiredObjects(t, db, func(exp, nonExp *objectSDK.Object) {
|
checkExpiredObjects(t, db, func(exp, nonExp *objectSDK.Object) {
|
||||||
|
|
|
@ -12,6 +12,8 @@ import (
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestDB_StorageID(t *testing.T) {
|
func TestDB_StorageID(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
db := newDB(t)
|
db := newDB(t)
|
||||||
|
|
||||||
raw1 := testutil.GenerateObject()
|
raw1 := testutil.GenerateObject()
|
||||||
|
|
|
@ -43,6 +43,8 @@ type objAddr struct {
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestShardOpen(t *testing.T) {
|
func TestShardOpen(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
dir := t.TempDir()
|
dir := t.TempDir()
|
||||||
metaPath := filepath.Join(dir, "meta")
|
metaPath := filepath.Join(dir, "meta")
|
||||||
|
|
||||||
|
@ -111,6 +113,8 @@ func TestShardOpen(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestRefillMetabaseCorrupted(t *testing.T) {
|
func TestRefillMetabaseCorrupted(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
dir := t.TempDir()
|
dir := t.TempDir()
|
||||||
|
|
||||||
fsTree := fstree.New(
|
fsTree := fstree.New(
|
||||||
|
@ -164,6 +168,8 @@ func TestRefillMetabaseCorrupted(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestRefillMetabase(t *testing.T) {
|
func TestRefillMetabase(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
p := t.Name()
|
p := t.Name()
|
||||||
|
|
||||||
defer os.RemoveAll(p)
|
defer os.RemoveAll(p)
|
||||||
|
|
|
@ -13,11 +13,15 @@ import (
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestShard_Delete(t *testing.T) {
|
func TestShard_Delete(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
t.Run("without write cache", func(t *testing.T) {
|
t.Run("without write cache", func(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
testShardDelete(t, false)
|
testShardDelete(t, false)
|
||||||
})
|
})
|
||||||
|
|
||||||
t.Run("with write cache", func(t *testing.T) {
|
t.Run("with write cache", func(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
testShardDelete(t, true)
|
testShardDelete(t, true)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
|
@ -25,6 +25,8 @@ import (
|
||||||
)
|
)
|
||||||
|
|
||||||
func Test_GCDropsLockedExpiredObject(t *testing.T) {
|
func Test_GCDropsLockedExpiredObject(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
var sh *shard.Shard
|
var sh *shard.Shard
|
||||||
|
|
||||||
epoch := &epochState{
|
epoch := &epochState{
|
||||||
|
|
|
@ -17,11 +17,15 @@ import (
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestShard_Get(t *testing.T) {
|
func TestShard_Get(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
t.Run("without write cache", func(t *testing.T) {
|
t.Run("without write cache", func(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
testShardGet(t, false)
|
testShardGet(t, false)
|
||||||
})
|
})
|
||||||
|
|
||||||
t.Run("with write cache", func(t *testing.T) {
|
t.Run("with write cache", func(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
testShardGet(t, true)
|
testShardGet(t, true)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
|
@ -15,11 +15,15 @@ import (
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestShard_Head(t *testing.T) {
|
func TestShard_Head(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
t.Run("without write cache", func(t *testing.T) {
|
t.Run("without write cache", func(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
testShardHead(t, false)
|
testShardHead(t, false)
|
||||||
})
|
})
|
||||||
|
|
||||||
t.Run("with write cache", func(t *testing.T) {
|
t.Run("with write cache", func(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
testShardHead(t, true)
|
testShardHead(t, true)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,11 +13,15 @@ import (
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestShard_Inhume(t *testing.T) {
|
func TestShard_Inhume(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
t.Run("without write cache", func(t *testing.T) {
|
t.Run("without write cache", func(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
testShardInhume(t, false)
|
testShardInhume(t, false)
|
||||||
})
|
})
|
||||||
|
|
||||||
t.Run("with write cache", func(t *testing.T) {
|
t.Run("with write cache", func(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
testShardInhume(t, true)
|
testShardInhume(t, true)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,6 +2,7 @@ package shard_test
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
|
"sync"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"git.frostfs.info/TrueCloudLab/frostfs-node/pkg/core/object"
|
"git.frostfs.info/TrueCloudLab/frostfs-node/pkg/core/object"
|
||||||
|
@ -9,22 +10,23 @@ import (
|
||||||
"git.frostfs.info/TrueCloudLab/frostfs-node/pkg/local_object_storage/shard"
|
"git.frostfs.info/TrueCloudLab/frostfs-node/pkg/local_object_storage/shard"
|
||||||
cidtest "git.frostfs.info/TrueCloudLab/frostfs-sdk-go/container/id/test"
|
cidtest "git.frostfs.info/TrueCloudLab/frostfs-sdk-go/container/id/test"
|
||||||
"github.com/stretchr/testify/require"
|
"github.com/stretchr/testify/require"
|
||||||
|
"golang.org/x/sync/errgroup"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestShard_List(t *testing.T) {
|
func TestShard_List(t *testing.T) {
|
||||||
sh := newShard(t, false)
|
t.Parallel()
|
||||||
shWC := newShard(t, true)
|
|
||||||
|
|
||||||
defer func() {
|
|
||||||
releaseShard(sh, t)
|
|
||||||
releaseShard(shWC, t)
|
|
||||||
}()
|
|
||||||
|
|
||||||
t.Run("without write cache", func(t *testing.T) {
|
t.Run("without write cache", func(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
sh := newShard(t, false)
|
||||||
|
defer releaseShard(sh, t)
|
||||||
testShardList(t, sh)
|
testShardList(t, sh)
|
||||||
})
|
})
|
||||||
|
|
||||||
t.Run("with write cache", func(t *testing.T) {
|
t.Run("with write cache", func(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
shWC := newShard(t, true)
|
||||||
|
defer releaseShard(shWC, t)
|
||||||
testShardList(t, shWC)
|
testShardList(t, shWC)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
@ -33,13 +35,17 @@ func testShardList(t *testing.T, sh *shard.Shard) {
|
||||||
const C = 10
|
const C = 10
|
||||||
const N = 5
|
const N = 5
|
||||||
|
|
||||||
|
var mtx sync.Mutex
|
||||||
objs := make(map[string]int)
|
objs := make(map[string]int)
|
||||||
var putPrm shard.PutPrm
|
|
||||||
|
|
||||||
|
var errG errgroup.Group
|
||||||
|
errG.SetLimit(C * N)
|
||||||
for i := 0; i < C; i++ {
|
for i := 0; i < C; i++ {
|
||||||
|
errG.Go(func() error {
|
||||||
cnr := cidtest.ID()
|
cnr := cidtest.ID()
|
||||||
|
|
||||||
for j := 0; j < N; j++ {
|
for j := 0; j < N; j++ {
|
||||||
|
errG.Go(func() error {
|
||||||
obj := testutil.GenerateObjectWithCID(cnr)
|
obj := testutil.GenerateObjectWithCID(cnr)
|
||||||
testutil.AddPayload(obj, 1<<2)
|
testutil.AddPayload(obj, 1<<2)
|
||||||
|
|
||||||
|
@ -49,14 +55,21 @@ func testShardList(t *testing.T, sh *shard.Shard) {
|
||||||
obj.SetParentID(idParent)
|
obj.SetParentID(idParent)
|
||||||
obj.SetParent(parent)
|
obj.SetParent(parent)
|
||||||
|
|
||||||
|
mtx.Lock()
|
||||||
objs[object.AddressOf(obj).EncodeToString()] = 0
|
objs[object.AddressOf(obj).EncodeToString()] = 0
|
||||||
|
mtx.Unlock()
|
||||||
|
|
||||||
|
var putPrm shard.PutPrm
|
||||||
putPrm.SetObject(obj)
|
putPrm.SetObject(obj)
|
||||||
|
|
||||||
_, err := sh.Put(context.Background(), putPrm)
|
_, err := sh.Put(context.Background(), putPrm)
|
||||||
require.NoError(t, err)
|
return err
|
||||||
|
})
|
||||||
}
|
}
|
||||||
|
return nil
|
||||||
|
})
|
||||||
}
|
}
|
||||||
|
require.NoError(t, errG.Wait())
|
||||||
|
|
||||||
res, err := sh.List()
|
res, err := sh.List()
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
|
@ -23,6 +23,8 @@ import (
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestShard_Lock(t *testing.T) {
|
func TestShard_Lock(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
var sh *shard.Shard
|
var sh *shard.Shard
|
||||||
|
|
||||||
rootPath := t.TempDir()
|
rootPath := t.TempDir()
|
||||||
|
|
|
@ -72,6 +72,8 @@ const physical = "phy"
|
||||||
const logical = "logic"
|
const logical = "logic"
|
||||||
|
|
||||||
func TestCounters(t *testing.T) {
|
func TestCounters(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
dir := t.TempDir()
|
dir := t.TempDir()
|
||||||
sh, mm := shardWithMetrics(t, dir)
|
sh, mm := shardWithMetrics(t, dir)
|
||||||
|
|
||||||
|
|
|
@ -22,11 +22,14 @@ import (
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestShard_GetRange(t *testing.T) {
|
func TestShard_GetRange(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
t.Run("without write cache", func(t *testing.T) {
|
t.Run("without write cache", func(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
testShardGetRange(t, false)
|
testShardGetRange(t, false)
|
||||||
})
|
})
|
||||||
|
|
||||||
t.Run("with write cache", func(t *testing.T) {
|
t.Run("with write cache", func(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
testShardGetRange(t, true)
|
testShardGetRange(t, true)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
|
@ -24,6 +24,8 @@ import (
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestShardReload(t *testing.T) {
|
func TestShardReload(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
p := t.Name()
|
p := t.Name()
|
||||||
defer os.RemoveAll(p)
|
defer os.RemoveAll(p)
|
||||||
|
|
||||||
|
|
|
@ -12,9 +12,12 @@ import (
|
||||||
cidtest "git.frostfs.info/TrueCloudLab/frostfs-sdk-go/container/id/test"
|
cidtest "git.frostfs.info/TrueCloudLab/frostfs-sdk-go/container/id/test"
|
||||||
objectSDK "git.frostfs.info/TrueCloudLab/frostfs-sdk-go/object"
|
objectSDK "git.frostfs.info/TrueCloudLab/frostfs-sdk-go/object"
|
||||||
"github.com/stretchr/testify/require"
|
"github.com/stretchr/testify/require"
|
||||||
|
"golang.org/x/sync/errgroup"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestWriteCacheObjectLoss(t *testing.T) {
|
func TestWriteCacheObjectLoss(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
const (
|
const (
|
||||||
smallSize = 1024
|
smallSize = 1024
|
||||||
objCount = 100
|
objCount = 100
|
||||||
|
@ -39,13 +42,17 @@ func TestWriteCacheObjectLoss(t *testing.T) {
|
||||||
|
|
||||||
sh := newCustomShard(t, dir, true, wcOpts, nil)
|
sh := newCustomShard(t, dir, true, wcOpts, nil)
|
||||||
|
|
||||||
var putPrm shard.PutPrm
|
var errG errgroup.Group
|
||||||
|
|
||||||
for i := range objects {
|
for i := range objects {
|
||||||
putPrm.SetObject(objects[i])
|
obj := objects[i]
|
||||||
|
errG.Go(func() error {
|
||||||
|
var putPrm shard.PutPrm
|
||||||
|
putPrm.SetObject(obj)
|
||||||
_, err := sh.Put(context.Background(), putPrm)
|
_, err := sh.Put(context.Background(), putPrm)
|
||||||
require.NoError(t, err)
|
return err
|
||||||
|
})
|
||||||
}
|
}
|
||||||
|
require.NoError(t, errG.Wait())
|
||||||
require.NoError(t, sh.Close())
|
require.NoError(t, sh.Close())
|
||||||
|
|
||||||
sh = newCustomShard(t, dir, true, wcOpts, nil)
|
sh = newCustomShard(t, dir, true, wcOpts, nil)
|
||||||
|
|
Loading…
Reference in a new issue