summaryrefslogtreecommitdiffstats
path: root/model/websocket_message_test.go
diff options
context:
space:
mode:
authorGeorge Goldberg <george@gberg.me>2018-03-02 15:55:03 +0000
committerGeorge Goldberg <george@gberg.me>2018-03-02 15:55:03 +0000
commit901acc9703ae58b625b44e7abfd02333b9bab951 (patch)
tree1a8fc17a85544bc7b8064874923e2fe6e3f44354 /model/websocket_message_test.go
parent21afaf4bedcad578d4f876bb315d1072ccd296e6 (diff)
parent2b3b6051d265edf131d006b2eb14f55284faf1e5 (diff)
downloadchat-901acc9703ae58b625b44e7abfd02333b9bab951.tar.gz
chat-901acc9703ae58b625b44e7abfd02333b9bab951.tar.bz2
chat-901acc9703ae58b625b44e7abfd02333b9bab951.zip
Merge branch 'master' into advanced-permissions-phase-1
Diffstat (limited to 'model/websocket_message_test.go')
-rw-r--r--model/websocket_message_test.go48
1 files changed, 48 insertions, 0 deletions
diff --git a/model/websocket_message_test.go b/model/websocket_message_test.go
index 1b75d0f6e..10404c299 100644
--- a/model/websocket_message_test.go
+++ b/model/websocket_message_test.go
@@ -6,6 +6,8 @@ package model
import (
"strings"
"testing"
+
+ "github.com/stretchr/testify/assert"
)
func TestWebSocketEvent(t *testing.T) {
@@ -54,3 +56,49 @@ func TestWebSocketResponse(t *testing.T) {
t.Fatal("Ids do not match")
}
}
+
+func TestWebSocketEvent_PrecomputeJSON(t *testing.T) {
+ event := NewWebSocketEvent(WEBSOCKET_EVENT_POSTED, "foo", "bar", "baz", nil)
+ event.Sequence = 7
+
+ before := event.ToJson()
+ event.PrecomputeJSON()
+ after := event.ToJson()
+
+ assert.JSONEq(t, before, after)
+}
+
+var stringSink string
+
+func BenchmarkWebSocketEvent_ToJson(b *testing.B) {
+ event := NewWebSocketEvent(WEBSOCKET_EVENT_POSTED, "foo", "bar", "baz", nil)
+ for i := 0; i < 100; i++ {
+ event.Data[NewId()] = NewId()
+ }
+
+ b.Run("SerializedNTimes", func(b *testing.B) {
+ for i := 0; i < b.N; i++ {
+ stringSink = event.ToJson()
+ }
+ })
+
+ b.Run("PrecomputedNTimes", func(b *testing.B) {
+ for i := 0; i < b.N; i++ {
+ event.PrecomputeJSON()
+ }
+ })
+
+ b.Run("PrecomputedAndSerializedNTimes", func(b *testing.B) {
+ for i := 0; i < b.N; i++ {
+ event.PrecomputeJSON()
+ stringSink = event.ToJson()
+ }
+ })
+
+ event.PrecomputeJSON()
+ b.Run("PrecomputedOnceAndSerializedNTimes", func(b *testing.B) {
+ for i := 0; i < b.N; i++ {
+ stringSink = event.ToJson()
+ }
+ })
+}