summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJoram Wilander <jwawilander@gmail.com>2018-04-20 12:25:14 -0400
committerGitHub <noreply@github.com>2018-04-20 12:25:14 -0400
commit853445dc2ea68f765faa04ad14618b04f1081c43 (patch)
tree9e9c64985a6bfb78548737d42c4d216149f1697b
parent283f34b9c6d207f0a103e7b4c7f6da2c7481c3ef (diff)
downloadchat-853445dc2ea68f765faa04ad14618b04f1081c43.tar.gz
chat-853445dc2ea68f765faa04ad14618b04f1081c43.tar.bz2
chat-853445dc2ea68f765faa04ad14618b04f1081c43.zip
Properly implement session deep copy (#8602)
-rw-r--r--model/session.go17
-rw-r--r--model/session_test.go30
2 files changed, 45 insertions, 2 deletions
diff --git a/model/session.go b/model/session.go
index a407af26a..7c6bbe06d 100644
--- a/model/session.go
+++ b/model/session.go
@@ -38,8 +38,21 @@ type Session struct {
}
func (me *Session) DeepCopy() *Session {
- copy := *me
- return &copy
+ copySession := *me
+
+ if me.Props != nil {
+ copySession.Props = CopyStringMap(me.Props)
+ }
+
+ if me.TeamMembers != nil {
+ copySession.TeamMembers = make([]*TeamMember, len(me.TeamMembers))
+ for index, tm := range me.TeamMembers {
+ copySession.TeamMembers[index] = new(TeamMember)
+ *copySession.TeamMembers[index] = *tm
+ }
+ }
+
+ return &copySession
}
func (me *Session) ToJson() string {
diff --git a/model/session_test.go b/model/session_test.go
index 295f00076..5f4a4730d 100644
--- a/model/session_test.go
+++ b/model/session_test.go
@@ -7,8 +7,38 @@ import (
"strings"
"testing"
"time"
+
+ "github.com/stretchr/testify/assert"
)
+func TestSessionDeepCopy(t *testing.T) {
+ sessionId := NewId()
+ userId := NewId()
+ mapKey := "key"
+ mapValue := "val"
+
+ session := &Session{Id: sessionId, Props: map[string]string{mapKey: mapValue}, TeamMembers: []*TeamMember{&TeamMember{UserId: userId, TeamId: "someteamId"}}}
+
+ copySession := session.DeepCopy()
+ copySession.Id = "changed"
+ copySession.Props[mapKey] = "changed"
+ copySession.TeamMembers[0].UserId = "changed"
+
+ assert.Equal(t, sessionId, session.Id)
+ assert.Equal(t, mapValue, session.Props[mapKey])
+ assert.Equal(t, userId, session.TeamMembers[0].UserId)
+
+ session = &Session{Id: sessionId}
+ copySession = session.DeepCopy()
+
+ assert.Equal(t, sessionId, session.Id)
+
+ session = &Session{TeamMembers: []*TeamMember{}}
+ copySession = session.DeepCopy()
+
+ assert.Equal(t, 0, len(copySession.TeamMembers))
+}
+
func TestSessionJson(t *testing.T) {
session := Session{}
session.PreSave()