Files
akvorado/console/authentication/handlers_test.go
Vincent Bernat 3a6ba16a2e
Some checks failed
CI / 🤖 Check dependabot status (push) Has been cancelled
CI / 🐧 Test on Linux (${{ github.ref_type == 'tag' }}, misc) (push) Has been cancelled
CI / 🐧 Test on Linux (coverage) (push) Has been cancelled
CI / 🐧 Test on Linux (regular) (push) Has been cancelled
CI / ❄️ Build on Nix (push) Has been cancelled
CI / 🍏 Build and test on macOS (push) Has been cancelled
CI / 🧪 End-to-end testing (push) Has been cancelled
CI / 🔍 Upload code coverage (push) Has been cancelled
CI / 🔬 Test only Go (push) Has been cancelled
CI / 🔬 Test only JS (${{ needs.dependabot.outputs.package-ecosystem }}, 20) (push) Has been cancelled
CI / 🔬 Test only JS (${{ needs.dependabot.outputs.package-ecosystem }}, 22) (push) Has been cancelled
CI / 🔬 Test only JS (${{ needs.dependabot.outputs.package-ecosystem }}, 24) (push) Has been cancelled
CI / ⚖️ Check licenses (push) Has been cancelled
CI / 🐋 Build Docker images (push) Has been cancelled
CI / 🐋 Tag Docker images (push) Has been cancelled
CI / 🚀 Publish release (push) Has been cancelled
console/authentication: template logout and avatar URLs if not provided
2025-10-19 15:54:07 +02:00

213 lines
6.4 KiB
Go

// SPDX-FileCopyrightText: 2022 Free Mobile
// SPDX-License-Identifier: AGPL-3.0-only
package authentication
import (
"net/http"
"testing"
"akvorado/common/helpers"
"akvorado/common/httpserver"
"akvorado/common/reporter"
"github.com/gin-gonic/gin"
)
func TestUserHandler(t *testing.T) {
r := reporter.NewMock(t)
h := httpserver.NewMock(t, r)
c, err := New(r, DefaultConfiguration())
if err != nil {
t.Fatalf("New() error:\n%+v", err)
}
// Configure the two endpoints
endpoint := h.GinRouter.Group("/api/v0/console/user", c.UserAuthentication())
endpoint.GET("/info", c.UserInfoHandlerFunc)
endpoint.GET("/avatar", c.UserAvatarHandlerFunc)
t.Run("default user configured", func(t *testing.T) {
helpers.TestHTTPEndpoints(t, h.LocalAddr(), helpers.HTTPEndpointCases{
{
Description: "user info, no user logged in",
URL: "/api/v0/console/user/info",
StatusCode: 200,
JSONOutput: gin.H{"login": "__default", "name": "Default User"},
}, {
Description: "user info, minimal user logged in",
URL: "/api/v0/console/user/info",
Header: func() http.Header {
headers := make(http.Header)
headers.Add("Remote-User", "alfred")
return headers
}(),
StatusCode: 200,
JSONOutput: gin.H{
"login": "alfred",
},
}, {
Description: "user info, complete user logged in",
URL: "/api/v0/console/user/info",
Header: func() http.Header {
headers := make(http.Header)
headers.Add("Remote-User", "alfred")
headers.Add("Remote-Name", "Alfred Pennyworth")
headers.Add("Remote-Email", "alfred@batman.com")
headers.Add("X-Logout-URL", "/logout")
headers.Add("X-Avatar-URL", "https://avatars.githubusercontent.com/akvorado")
return headers
}(),
StatusCode: 200,
JSONOutput: gin.H{
"login": "alfred",
"name": "Alfred Pennyworth",
"email": "alfred@batman.com",
"logout-url": "/logout",
"avatar-url": "https://avatars.githubusercontent.com/akvorado",
},
}, {
Description: "user info, invalid user logged in",
URL: "/api/v0/console/user/info",
Header: func() http.Header {
headers := make(http.Header)
headers.Add("Remote-User", "alfred")
headers.Add("Remote-Email", "alfrednooo")
return headers
}(),
StatusCode: 200,
JSONOutput: gin.H{"login": "__default", "name": "Default User"},
}, {
Description: "avatar, no user logged in",
URL: "/api/v0/console/user/avatar",
ContentType: "image/png",
StatusCode: 200,
}, {
Description: "avatar, simple user",
URL: "/api/v0/console/user/avatar",
Header: func() http.Header {
headers := make(http.Header)
headers.Add("Remote-User", "alfred")
return headers
}(),
ContentType: "image/png",
StatusCode: 200,
}, {
Description: "avatar, simple user, etag",
URL: "/api/v0/console/user/avatar",
Header: func() http.Header {
headers := make(http.Header)
headers.Add("Remote-User", "alfred")
headers.Add("If-None-Match", `"b2e72a535032fa89"`)
return headers
}(),
StatusCode: 304,
},
})
})
t.Run("no default user", func(t *testing.T) {
c.config.DefaultUser.Login = ""
helpers.TestHTTPEndpoints(t, h.LocalAddr(), helpers.HTTPEndpointCases{
{
Description: "user info, no user logged in",
URL: "/api/v0/console/user/info",
StatusCode: 401,
JSONOutput: gin.H{"message": "No user logged in."},
}, {
Description: "user info, invalid user logged in",
URL: "/api/v0/console/user/info",
Header: func() http.Header {
headers := make(http.Header)
headers.Add("Remote-User", "alfred")
headers.Add("Remote-Email", "alfrednooo")
return headers
}(),
StatusCode: 401,
JSONOutput: gin.H{"message": "No user logged in."},
}, {
Description: "avatar, no user logged in",
URL: "/api/v0/console/user/avatar",
StatusCode: 401,
JSONOutput: gin.H{"message": "No user logged in."},
},
})
})
}
func TestUserHandlerWithTemplates(t *testing.T) {
r := reporter.NewMock(t)
h := httpserver.NewMock(t, r)
config := DefaultConfiguration()
config.LogoutURL = "/sso/portals/main/logout"
config.AvatarURL = "https://avatars.githubusercontent.com/{{ .Login }}?s=80"
c, err := New(r, config)
if err != nil {
t.Fatalf("New() error:\n%+v", err)
}
// Configure the endpoint
endpoint := h.GinRouter.Group("/api/v0/console/user", c.UserAuthentication())
endpoint.GET("/info", c.UserInfoHandlerFunc)
t.Run("templates applied when headers not provided", func(t *testing.T) {
helpers.TestHTTPEndpoints(t, h.LocalAddr(), helpers.HTTPEndpointCases{
{
Description: "user info with logout and avatar templates",
URL: "/api/v0/console/user/info",
Header: func() http.Header {
headers := make(http.Header)
headers.Add("Remote-User", "bruce")
headers.Add("Remote-Name", "Bruce Wayne")
headers.Add("Remote-Email", "bruce@wayne.com")
return headers
}(),
StatusCode: 200,
JSONOutput: gin.H{
"login": "bruce",
"name": "Bruce Wayne",
"email": "bruce@wayne.com",
"logout-url": "/sso/portals/main/logout",
"avatar-url": "https://avatars.githubusercontent.com/bruce?s=80",
},
}, {
Description: "user info with different login for avatar template",
URL: "/api/v0/console/user/info",
Header: func() http.Header {
headers := make(http.Header)
headers.Add("Remote-User", "alfred")
return headers
}(),
StatusCode: 200,
JSONOutput: gin.H{
"login": "alfred",
"logout-url": "/sso/portals/main/logout",
"avatar-url": "https://avatars.githubusercontent.com/alfred?s=80",
},
},
})
})
t.Run("templates applied even with headers", func(t *testing.T) {
helpers.TestHTTPEndpoints(t, h.LocalAddr(), helpers.HTTPEndpointCases{
{
Description: "user info with headers provided, templates still override",
URL: "/api/v0/console/user/info",
Header: func() http.Header {
headers := make(http.Header)
headers.Add("Remote-User", "bruce")
headers.Add("X-Logout-URL", "/custom/logout")
headers.Add("X-Avatar-URL", "https://custom.avatar.url/bruce")
return headers
}(),
StatusCode: 200,
JSONOutput: gin.H{
"login": "bruce",
"logout-url": "/sso/portals/main/logout",
"avatar-url": "https://avatars.githubusercontent.com/bruce?s=80",
},
},
})
})
}