2021-01-09 05:08:20 +01:00
|
|
|
package shared
|
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
2021-05-28 01:19:57 +02:00
|
|
|
"github.com/lbryio/lbry.go/v2/extras/util"
|
2021-01-09 05:08:20 +01:00
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestBlobTrace_Serialize(t *testing.T) {
|
2021-05-28 01:19:57 +02:00
|
|
|
hostName = util.PtrToString("test_machine")
|
2021-01-09 05:08:20 +01:00
|
|
|
stack := NewBlobTrace(10*time.Second, "test")
|
|
|
|
stack.Stack(20*time.Second, "test2")
|
|
|
|
stack.Stack(30*time.Second, "test3")
|
|
|
|
serialized, err := stack.Serialize()
|
|
|
|
assert.NoError(t, err)
|
|
|
|
t.Log(serialized)
|
2021-05-28 01:19:57 +02:00
|
|
|
expected := "{\"stacks\":[{\"timing\":10000000000,\"origin_name\":\"test\",\"host_name\":\"test_machine\"},{\"timing\":20000000000,\"origin_name\":\"test2\",\"host_name\":\"test_machine\"},{\"timing\":30000000000,\"origin_name\":\"test3\",\"host_name\":\"test_machine\"}]}"
|
2021-01-09 05:08:20 +01:00
|
|
|
assert.Equal(t, expected, serialized)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestBlobTrace_Deserialize(t *testing.T) {
|
2021-05-28 01:19:57 +02:00
|
|
|
hostName = util.PtrToString("test_machine")
|
2021-01-09 05:08:20 +01:00
|
|
|
serialized := "{\"stacks\":[{\"timing\":10000000000,\"origin_name\":\"test\"},{\"timing\":20000000000,\"origin_name\":\"test2\"},{\"timing\":30000000000,\"origin_name\":\"test3\"}]}"
|
|
|
|
stack, err := Deserialize(serialized)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
assert.Len(t, stack.Stacks, 3)
|
|
|
|
assert.Equal(t, stack.Stacks[0].Timing, 10*time.Second)
|
|
|
|
assert.Equal(t, stack.Stacks[1].Timing, 20*time.Second)
|
|
|
|
assert.Equal(t, stack.Stacks[2].Timing, 30*time.Second)
|
|
|
|
assert.Equal(t, stack.Stacks[0].OriginName, "test")
|
|
|
|
assert.Equal(t, stack.Stacks[1].OriginName, "test2")
|
|
|
|
assert.Equal(t, stack.Stacks[2].OriginName, "test3")
|
|
|
|
}
|