summaryrefslogtreecommitdiffstats
path: root/model/status_test.go
diff options
context:
space:
mode:
authorCarlos Tadeu Panato Junior <ctadeu@gmail.com>2017-03-30 17:09:39 +0200
committerCorey Hulen <corey@hulen.com>2017-03-30 08:09:39 -0700
commit29e6db5713c57d7bb46d7aea38b1001b9e8a1212 (patch)
tree66d0a06a35068ce26024b0b9c030de0b1c8bab5c /model/status_test.go
parentee3b983a6344d78bafa553607133020e8e1fb0ed (diff)
downloadchat-29e6db5713c57d7bb46d7aea38b1001b9e8a1212.tar.gz
chat-29e6db5713c57d7bb46d7aea38b1001b9e8a1212.tar.bz2
chat-29e6db5713c57d7bb46d7aea38b1001b9e8a1212.zip
Implement POST /users/status/ids for apiv4 (#5894)
Diffstat (limited to 'model/status_test.go')
-rw-r--r--model/status_test.go42
1 files changed, 42 insertions, 0 deletions
diff --git a/model/status_test.go b/model/status_test.go
index 0b4a33d5d..cb1720fd2 100644
--- a/model/status_test.go
+++ b/model/status_test.go
@@ -4,6 +4,7 @@
package model
import (
+ "encoding/json"
"strings"
"testing"
)
@@ -29,3 +30,44 @@ func TestStatus(t *testing.T) {
t.Fatal("Manual should have matched")
}
}
+
+func TestStatusListToJson(t *testing.T) {
+ statuses := []*Status{{NewId(), STATUS_ONLINE, true, 0, ""}, {NewId(), STATUS_OFFLINE, true, 0, ""}}
+ jsonStatuses := StatusListToJson(statuses)
+
+ var dat []map[string]interface{}
+ if err := json.Unmarshal([]byte(jsonStatuses), &dat); err != nil {
+ panic(err)
+ }
+
+ if len(dat) != 2 {
+ t.Fatal("Status array should contain 2 elements")
+ }
+ if statuses[0].UserId != dat[0]["user_id"] {
+ t.Fatal("UserId should be equal")
+ }
+ if statuses[1].UserId != dat[1]["user_id"] {
+ t.Fatal("UserId should be equal")
+ }
+}
+
+func TestStatusListFromJson(t *testing.T) {
+ const jsonStream = `
+ [{"user_id":"k39fowpzhfffjxeaw8ecyrygme","status":"online","manual":true,"last_activity_at":0},{"user_id":"e9f1bbg8wfno7b3k7yk79bbwfy","status":"offline","manual":true,"last_activity_at":0}]
+ `
+ var dat []map[string]interface{}
+ if err := json.Unmarshal([]byte(jsonStream), &dat); err != nil {
+ panic(err)
+ }
+
+ toDec := strings.NewReader(jsonStream)
+ var statusesFromJson []*Status
+ statusesFromJson = StatusListFromJson(toDec)
+
+ if statusesFromJson[0].UserId != dat[0]["user_id"] {
+ t.Fatal("UserId should be equal")
+ }
+ if statusesFromJson[1].UserId != dat[1]["user_id"] {
+ t.Fatal("UserId should be equal")
+ }
+}