forked from TrueCloudLab/neoneo-go
core/test: add benchmark for storageFind
Signed-off-by: Evgeniy Stratonikov <evgeniy@nspcc.ru>
This commit is contained in:
parent
0d5ede0bff
commit
b8b272c8c4
1 changed files with 30 additions and 0 deletions
|
@ -258,6 +258,36 @@ func TestStorageDelete(t *testing.T) {
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func BenchmarkStorageFind(b *testing.B) {
|
||||||
|
v, contractState, context, chain := createVMAndContractState(b)
|
||||||
|
require.NoError(b, chain.contracts.Management.PutContractState(chain.dao, contractState))
|
||||||
|
|
||||||
|
const count = 100
|
||||||
|
|
||||||
|
items := make(map[string]state.StorageItem)
|
||||||
|
for i := 0; i < count; i++ {
|
||||||
|
items["abc"+random.String(10)] = random.Bytes(10)
|
||||||
|
}
|
||||||
|
for k, v := range items {
|
||||||
|
require.NoError(b, context.DAO.PutStorageItem(contractState.ID, []byte(k), v))
|
||||||
|
require.NoError(b, context.DAO.PutStorageItem(contractState.ID+1, []byte(k), v))
|
||||||
|
}
|
||||||
|
|
||||||
|
b.ResetTimer()
|
||||||
|
b.ReportAllocs()
|
||||||
|
for i := 0; i < b.N; i++ {
|
||||||
|
b.StopTimer()
|
||||||
|
v.Estack().PushVal(istorage.FindDefault)
|
||||||
|
v.Estack().PushVal("abc")
|
||||||
|
v.Estack().PushVal(stackitem.NewInterop(&StorageContext{ID: contractState.ID}))
|
||||||
|
b.StartTimer()
|
||||||
|
err := storageFind(context)
|
||||||
|
if err != nil {
|
||||||
|
b.FailNow()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func TestStorageFind(t *testing.T) {
|
func TestStorageFind(t *testing.T) {
|
||||||
v, contractState, context, chain := createVMAndContractState(t)
|
v, contractState, context, chain := createVMAndContractState(t)
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue