photoprism/internal/api/session_test.go

106 lines
4.1 KiB
Go
Raw Normal View History

2020-05-06 12:56:13 +02:00
package api
import (
2020-11-21 18:08:41 +01:00
"net/http"
"testing"
2020-05-06 12:56:13 +02:00
"github.com/stretchr/testify/assert"
"github.com/tidwall/gjson"
"github.com/photoprism/photoprism/internal/i18n"
2020-05-06 12:56:13 +02:00
)
func TestCreateSession(t *testing.T) {
t.Run("successful request", func(t *testing.T) {
app, router, _ := NewApiTest()
CreateSession(router)
r := PerformRequestWithBody(app, http.MethodPost, "/api/v1/session", `{"username": "admin", "password": "photoprism"}`)
log.Debugf("BODY: %s", r.Body.String())
val2 := gjson.Get(r.Body.String(), "data.user.Username")
assert.Equal(t, "admin", val2.String())
2020-05-06 12:56:13 +02:00
assert.Equal(t, http.StatusOK, r.Code)
})
t.Run("bad request", func(t *testing.T) {
app, router, _ := NewApiTest()
CreateSession(router)
r := PerformRequestWithBody(app, http.MethodPost, "/api/v1/session", `{"username": 123, "password": "xxx"}`)
2020-05-06 12:56:13 +02:00
assert.Equal(t, http.StatusBadRequest, r.Code)
})
t.Run("invalid token", func(t *testing.T) {
app, router, _ := NewApiTest()
CreateSession(router)
r := PerformRequestWithBody(app, http.MethodPost, "/api/v1/session", `{"username": "admin", "password": "photoprism", "token": "xxx"}`)
assert.Equal(t, http.StatusBadRequest, r.Code)
})
t.Run("valid token", func(t *testing.T) {
app, router, _ := NewApiTest()
CreateSession(router)
r := PerformRequestWithBody(app, http.MethodPost, "/api/v1/session", `{"username": "admin", "password": "photoprism", "token": "1jxf3jfn2k"}`)
assert.Equal(t, http.StatusOK, r.Code)
})
2020-05-06 12:56:13 +02:00
t.Run("invalid password", func(t *testing.T) {
app, router, _ := NewApiTest()
CreateSession(router)
r := PerformRequestWithBody(app, http.MethodPost, "/api/v1/session", `{"username": "admin", "password": "xxx"}`)
val := gjson.Get(r.Body.String(), "error")
assert.Equal(t, i18n.Msg(i18n.ErrInvalidCredentials), val.String())
assert.Equal(t, http.StatusBadRequest, r.Code)
})
t.Run("alice - successful request", func(t *testing.T) {
app, router, _ := NewApiTest()
CreateSession(router)
r := PerformRequestWithBody(app, http.MethodPost, "/api/v1/session", `{"username": "alice", "password": "Alice123!"}`)
resEmail := gjson.Get(r.Body.String(), "data.user.Email")
resUsername := gjson.Get(r.Body.String(), "data.user.Username")
assert.Equal(t, "alice@example.com", resEmail.String())
assert.Equal(t, "alice", resUsername.String())
assert.Equal(t, http.StatusOK, r.Code)
})
t.Run("bob - successful request", func(t *testing.T) {
app, router, _ := NewApiTest()
CreateSession(router)
r := PerformRequestWithBody(app, http.MethodPost, "/api/v1/session", `{"username": "bob", "password": "Bobbob123!"}`)
resEmail := gjson.Get(r.Body.String(), "data.user.Email")
resUsername := gjson.Get(r.Body.String(), "data.user.Username")
assert.Equal(t, "bob@example.com", resEmail.String())
assert.Equal(t, "bob", resUsername.String())
assert.Equal(t, http.StatusOK, r.Code)
})
t.Run("bob - invalid password", func(t *testing.T) {
app, router, _ := NewApiTest()
CreateSession(router)
r := PerformRequestWithBody(app, http.MethodPost, "/api/v1/session", `{"username": "bob", "password": "helloworld"}`)
2020-05-06 12:56:13 +02:00
val := gjson.Get(r.Body.String(), "error")
assert.Equal(t, i18n.Msg(i18n.ErrInvalidCredentials), val.String())
2020-05-06 12:56:13 +02:00
assert.Equal(t, http.StatusBadRequest, r.Code)
})
}
func TestDeleteSession(t *testing.T) {
t.Run("delete admin session", func(t *testing.T) {
2021-08-11 10:47:52 +02:00
app, router, _ := NewApiTest()
DeleteSession(router)
sessId := AuthenticateAdmin(app, router)
2021-08-11 10:47:52 +02:00
r := PerformRequest(app, http.MethodDelete, "/api/v1/session/"+sessId)
assert.Equal(t, http.StatusOK, r.Code)
})
t.Run("delete user session", func(t *testing.T) {
2021-08-11 10:47:52 +02:00
app, router, _ := NewApiTest()
DeleteSession(router)
sessId := AuthenticateUser(app, router, "alice", "Alice123!")
2021-08-11 10:47:52 +02:00
r := PerformRequest(app, http.MethodDelete, "/api/v1/session/"+sessId)
assert.Equal(t, http.StatusOK, r.Code)
})
t.Run("delete invalid session", func(t *testing.T) {
sessId := "638bffc9b86a8fda0d908ebee84a43930cb8d1e3507f4aa0"
app, router, _ := NewApiTest()
DeleteSession(router)
r := PerformRequest(app, http.MethodDelete, "/api/v1/session/"+sessId)
2020-05-06 12:56:13 +02:00
assert.Equal(t, http.StatusOK, r.Code)
})
}