1
0
mirror of https://github.com/pocketbase/pocketbase.git synced 2025-01-25 06:42:43 +02:00
pocketbase/apis/logs_test.go

197 lines
6.2 KiB
Go
Raw Normal View History

2022-07-07 00:19:05 +03:00
package apis_test
import (
"net/http"
"testing"
"github.com/labstack/echo/v5"
"github.com/pocketbase/pocketbase/tests"
)
2023-11-26 13:33:17 +02:00
func TestLogsList(t *testing.T) {
2022-07-07 00:19:05 +03:00
scenarios := []tests.ApiScenario{
{
Name: "unauthorized",
Method: http.MethodGet,
2023-11-26 13:33:17 +02:00
Url: "/api/logs",
2022-07-07 00:19:05 +03:00
ExpectedStatus: 401,
ExpectedContent: []string{`"data":{}`},
},
{
2022-10-30 10:28:14 +02:00
Name: "authorized as auth record",
2022-07-07 00:19:05 +03:00
Method: http.MethodGet,
2023-11-26 13:33:17 +02:00
Url: "/api/logs",
2022-07-07 00:19:05 +03:00
RequestHeaders: map[string]string{
2022-10-30 10:28:14 +02:00
"Authorization": "eyJhbGciOiJIUzI1NiJ9.eyJpZCI6IjRxMXhsY2xtZmxva3UzMyIsInR5cGUiOiJhdXRoUmVjb3JkIiwiY29sbGVjdGlvbklkIjoiX3BiX3VzZXJzX2F1dGhfIiwiZXhwIjoyMjA4OTg1MjYxfQ.UwD8JvkbQtXpymT09d7J6fdA0aP9g4FJ1GPh_ggEkzc",
2022-07-07 00:19:05 +03:00
},
ExpectedStatus: 401,
ExpectedContent: []string{`"data":{}`},
},
{
Name: "authorized as admin",
Method: http.MethodGet,
2023-11-26 13:33:17 +02:00
Url: "/api/logs",
2022-07-07 00:19:05 +03:00
RequestHeaders: map[string]string{
2022-10-30 10:28:14 +02:00
"Authorization": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpZCI6InN5d2JoZWNuaDQ2cmhtMCIsInR5cGUiOiJhZG1pbiIsImV4cCI6MjIwODk4NTI2MX0.M1m--VOqGyv0d23eeUc0r9xE8ZzHaYVmVFw1VZW6gT8",
2022-07-07 00:19:05 +03:00
},
2022-09-07 20:31:05 +03:00
BeforeTestFunc: func(t *testing.T, app *tests.TestApp, e *echo.Echo) {
2023-11-26 13:33:17 +02:00
if err := tests.MockLogsData(app); err != nil {
2022-07-07 00:19:05 +03:00
t.Fatal(err)
}
},
ExpectedStatus: 200,
ExpectedContent: []string{
`"page":1`,
`"perPage":30`,
`"totalItems":2`,
`"items":[{`,
`"id":"873f2133-9f38-44fb-bf82-c8f53b310d91"`,
`"id":"f2133873-44fb-9f38-bf82-c918f53b310d"`,
},
},
{
Name: "authorized as admin + filter",
Method: http.MethodGet,
2023-11-26 13:33:17 +02:00
Url: "/api/logs?filter=data.status>200",
2022-07-07 00:19:05 +03:00
RequestHeaders: map[string]string{
2022-10-30 10:28:14 +02:00
"Authorization": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpZCI6InN5d2JoZWNuaDQ2cmhtMCIsInR5cGUiOiJhZG1pbiIsImV4cCI6MjIwODk4NTI2MX0.M1m--VOqGyv0d23eeUc0r9xE8ZzHaYVmVFw1VZW6gT8",
2022-07-07 00:19:05 +03:00
},
2022-09-07 20:31:05 +03:00
BeforeTestFunc: func(t *testing.T, app *tests.TestApp, e *echo.Echo) {
2023-11-26 13:33:17 +02:00
if err := tests.MockLogsData(app); err != nil {
2022-07-07 00:19:05 +03:00
t.Fatal(err)
}
},
ExpectedStatus: 200,
ExpectedContent: []string{
`"page":1`,
`"perPage":30`,
`"totalItems":1`,
`"items":[{`,
`"id":"f2133873-44fb-9f38-bf82-c918f53b310d"`,
},
},
}
for _, scenario := range scenarios {
scenario.Test(t)
}
}
2023-11-26 13:33:17 +02:00
func TestLogView(t *testing.T) {
2022-07-07 00:19:05 +03:00
scenarios := []tests.ApiScenario{
{
Name: "unauthorized",
Method: http.MethodGet,
2023-11-26 13:33:17 +02:00
Url: "/api/logs/873f2133-9f38-44fb-bf82-c8f53b310d91",
2022-07-07 00:19:05 +03:00
ExpectedStatus: 401,
ExpectedContent: []string{`"data":{}`},
},
{
2022-10-30 10:28:14 +02:00
Name: "authorized as auth record",
2022-07-07 00:19:05 +03:00
Method: http.MethodGet,
2023-11-26 13:33:17 +02:00
Url: "/api/logs/873f2133-9f38-44fb-bf82-c8f53b310d91",
2022-07-07 00:19:05 +03:00
RequestHeaders: map[string]string{
2022-10-30 10:28:14 +02:00
"Authorization": "eyJhbGciOiJIUzI1NiJ9.eyJpZCI6IjRxMXhsY2xtZmxva3UzMyIsInR5cGUiOiJhdXRoUmVjb3JkIiwiY29sbGVjdGlvbklkIjoiX3BiX3VzZXJzX2F1dGhfIiwiZXhwIjoyMjA4OTg1MjYxfQ.UwD8JvkbQtXpymT09d7J6fdA0aP9g4FJ1GPh_ggEkzc",
2022-07-07 00:19:05 +03:00
},
ExpectedStatus: 401,
ExpectedContent: []string{`"data":{}`},
},
{
Name: "authorized as admin (nonexisting request log)",
Method: http.MethodGet,
2023-11-26 13:33:17 +02:00
Url: "/api/logs/missing1-9f38-44fb-bf82-c8f53b310d91",
2022-07-07 00:19:05 +03:00
RequestHeaders: map[string]string{
2022-10-30 10:28:14 +02:00
"Authorization": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpZCI6InN5d2JoZWNuaDQ2cmhtMCIsInR5cGUiOiJhZG1pbiIsImV4cCI6MjIwODk4NTI2MX0.M1m--VOqGyv0d23eeUc0r9xE8ZzHaYVmVFw1VZW6gT8",
2022-07-07 00:19:05 +03:00
},
2022-09-07 20:31:05 +03:00
BeforeTestFunc: func(t *testing.T, app *tests.TestApp, e *echo.Echo) {
2023-11-26 13:33:17 +02:00
if err := tests.MockLogsData(app); err != nil {
2022-07-07 00:19:05 +03:00
t.Fatal(err)
}
},
ExpectedStatus: 404,
ExpectedContent: []string{`"data":{}`},
},
{
Name: "authorized as admin (existing request log)",
Method: http.MethodGet,
2023-11-26 13:33:17 +02:00
Url: "/api/logs/873f2133-9f38-44fb-bf82-c8f53b310d91",
2022-07-07 00:19:05 +03:00
RequestHeaders: map[string]string{
2022-10-30 10:28:14 +02:00
"Authorization": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpZCI6InN5d2JoZWNuaDQ2cmhtMCIsInR5cGUiOiJhZG1pbiIsImV4cCI6MjIwODk4NTI2MX0.M1m--VOqGyv0d23eeUc0r9xE8ZzHaYVmVFw1VZW6gT8",
2022-07-07 00:19:05 +03:00
},
2022-09-07 20:31:05 +03:00
BeforeTestFunc: func(t *testing.T, app *tests.TestApp, e *echo.Echo) {
2023-11-26 13:33:17 +02:00
if err := tests.MockLogsData(app); err != nil {
2022-07-07 00:19:05 +03:00
t.Fatal(err)
}
},
ExpectedStatus: 200,
ExpectedContent: []string{
`"id":"873f2133-9f38-44fb-bf82-c8f53b310d91"`,
},
},
}
for _, scenario := range scenarios {
scenario.Test(t)
}
}
2023-11-26 13:33:17 +02:00
func TestLogsStats(t *testing.T) {
2022-07-07 00:19:05 +03:00
scenarios := []tests.ApiScenario{
{
Name: "unauthorized",
Method: http.MethodGet,
2023-11-26 13:33:17 +02:00
Url: "/api/logs/stats",
2022-07-07 00:19:05 +03:00
ExpectedStatus: 401,
ExpectedContent: []string{`"data":{}`},
},
{
2022-10-30 10:28:14 +02:00
Name: "authorized as auth record",
2022-07-07 00:19:05 +03:00
Method: http.MethodGet,
2023-11-26 13:33:17 +02:00
Url: "/api/logs/stats",
2022-07-07 00:19:05 +03:00
RequestHeaders: map[string]string{
2022-10-30 10:28:14 +02:00
"Authorization": "eyJhbGciOiJIUzI1NiJ9.eyJpZCI6IjRxMXhsY2xtZmxva3UzMyIsInR5cGUiOiJhdXRoUmVjb3JkIiwiY29sbGVjdGlvbklkIjoiX3BiX3VzZXJzX2F1dGhfIiwiZXhwIjoyMjA4OTg1MjYxfQ.UwD8JvkbQtXpymT09d7J6fdA0aP9g4FJ1GPh_ggEkzc",
2022-07-07 00:19:05 +03:00
},
ExpectedStatus: 401,
ExpectedContent: []string{`"data":{}`},
},
{
Name: "authorized as admin",
Method: http.MethodGet,
2023-11-26 13:33:17 +02:00
Url: "/api/logs/stats",
2022-07-07 00:19:05 +03:00
RequestHeaders: map[string]string{
2022-10-30 10:28:14 +02:00
"Authorization": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpZCI6InN5d2JoZWNuaDQ2cmhtMCIsInR5cGUiOiJhZG1pbiIsImV4cCI6MjIwODk4NTI2MX0.M1m--VOqGyv0d23eeUc0r9xE8ZzHaYVmVFw1VZW6gT8",
2022-07-07 00:19:05 +03:00
},
2022-09-07 20:31:05 +03:00
BeforeTestFunc: func(t *testing.T, app *tests.TestApp, e *echo.Echo) {
2023-11-26 13:33:17 +02:00
if err := tests.MockLogsData(app); err != nil {
2022-07-07 00:19:05 +03:00
t.Fatal(err)
}
},
ExpectedStatus: 200,
ExpectedContent: []string{
2022-10-30 10:28:14 +02:00
`[{"total":1,"date":"2022-05-01 10:00:00.000Z"},{"total":1,"date":"2022-05-02 10:00:00.000Z"}]`,
2022-07-07 00:19:05 +03:00
},
},
{
Name: "authorized as admin + filter",
Method: http.MethodGet,
2023-11-26 13:33:17 +02:00
Url: "/api/logs/stats?filter=data.status>200",
2022-07-07 00:19:05 +03:00
RequestHeaders: map[string]string{
2022-10-30 10:28:14 +02:00
"Authorization": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpZCI6InN5d2JoZWNuaDQ2cmhtMCIsInR5cGUiOiJhZG1pbiIsImV4cCI6MjIwODk4NTI2MX0.M1m--VOqGyv0d23eeUc0r9xE8ZzHaYVmVFw1VZW6gT8",
2022-07-07 00:19:05 +03:00
},
2022-09-07 20:31:05 +03:00
BeforeTestFunc: func(t *testing.T, app *tests.TestApp, e *echo.Echo) {
2023-11-26 13:33:17 +02:00
if err := tests.MockLogsData(app); err != nil {
2022-07-07 00:19:05 +03:00
t.Fatal(err)
}
},
ExpectedStatus: 200,
ExpectedContent: []string{
2022-10-30 10:28:14 +02:00
`[{"total":1,"date":"2022-05-02 10:00:00.000Z"}]`,
2022-07-07 00:19:05 +03:00
},
},
}
for _, scenario := range scenarios {
scenario.Test(t)
}
}