mirror of
https://github.com/VictoriaMetrics/VictoriaMetrics.git
synced 2025-01-10 15:14:09 +00:00
lib/logstorage: add benchmark for streamID.marshalString
This commit is contained in:
parent
76c74ec57f
commit
d944c162da
2 changed files with 41 additions and 10 deletions
|
@ -6,23 +6,27 @@ import (
|
|||
)
|
||||
|
||||
func TestStreamIDMarshalUnmarshalString(t *testing.T) {
|
||||
f := func(sid *streamID) {
|
||||
f := func(sid *streamID, resultExpected string) {
|
||||
t.Helper()
|
||||
|
||||
s := string(sid.marshalString(nil))
|
||||
result := string(sid.marshalString(nil))
|
||||
|
||||
var sid2 streamID
|
||||
if !sid2.tryUnmarshalFromString(s) {
|
||||
t.Fatalf("cannot unmarshal streamID from %q", s)
|
||||
if result != resultExpected {
|
||||
t.Fatalf("unexpected result\ngot\n%q\nwant\n%q", result, resultExpected)
|
||||
}
|
||||
|
||||
s2 := string(sid2.marshalString(nil))
|
||||
if s != s2 {
|
||||
t.Fatalf("unexpected marshaled streamID; got %s; want %s", s2, s)
|
||||
var sid2 streamID
|
||||
if !sid2.tryUnmarshalFromString(result) {
|
||||
t.Fatalf("cannot unmarshal streamID from %q", result)
|
||||
}
|
||||
|
||||
result2 := string(sid2.marshalString(nil))
|
||||
if result != result2 {
|
||||
t.Fatalf("unexpected marshaled streamID; got %s; want %s", result2, result)
|
||||
}
|
||||
}
|
||||
|
||||
f(&streamID{})
|
||||
f(&streamID{}, "000000000000000000000000000000000000000000000000")
|
||||
f(&streamID{
|
||||
tenantID: TenantID{
|
||||
AccountID: 123,
|
||||
|
@ -32,7 +36,7 @@ func TestStreamIDMarshalUnmarshalString(t *testing.T) {
|
|||
lo: 89,
|
||||
hi: 344334,
|
||||
},
|
||||
})
|
||||
}, "0000007b000001c8000000000005410e0000000000000059")
|
||||
}
|
||||
|
||||
func TestStreamIDMarshalUnmarshal(t *testing.T) {
|
||||
|
|
27
lib/logstorage/stream_id_timing_test.go
Normal file
27
lib/logstorage/stream_id_timing_test.go
Normal file
|
@ -0,0 +1,27 @@
|
|||
package logstorage
|
||||
|
||||
import (
|
||||
"testing"
|
||||
)
|
||||
|
||||
func BenchmarkStreamIDMarshalString(b *testing.B) {
|
||||
b.ReportAllocs()
|
||||
b.SetBytes(1)
|
||||
|
||||
sid := &streamID{
|
||||
tenantID: TenantID{
|
||||
AccountID: 123,
|
||||
ProjectID: 456,
|
||||
},
|
||||
id: u128{
|
||||
lo: 89,
|
||||
hi: 344334,
|
||||
},
|
||||
}
|
||||
b.RunParallel(func(pb *testing.PB) {
|
||||
var b []byte
|
||||
for pb.Next() {
|
||||
b = sid.marshalString(b[:0])
|
||||
}
|
||||
})
|
||||
}
|
Loading…
Reference in a new issue