diff options
Diffstat (limited to 'model/status_test.go')
-rw-r--r-- | model/status_test.go | 42 |
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") + } +} |