mirror of
https://github.com/pomerium/pomerium.git
synced 2025-05-05 13:26:03 +02:00
- authorize: build whitelist from policy's URLs instead of strings. - internal/httputil: merged httputil and https package. - internal/config: merged config and policy packages. - internal/metrics: removed unused measure struct. - proxy/clients: refactor Addr fields to be urls. - proxy: remove unused extend deadline function. - proxy: use handler middleware for reverse proxy leg. - proxy: change the way websocket requests are made (route based). General improvements - omitted value from range in several cases where for loop could be simplified. - added error checking to many tests. - standardize url parsing. - remove unnecessary return statements. - proxy: add self-signed certificate support. #179 - proxy: add skip tls certificate verification. #179 - proxy: Refactor websocket support to be route based. #204
94 lines
2.1 KiB
Go
94 lines
2.1 KiB
Go
package config // import "github.com/pomerium/pomerium/internal/config"
|
|
|
|
import (
|
|
"testing"
|
|
)
|
|
|
|
func Test_isValidService(t *testing.T) {
|
|
tests := []struct {
|
|
name string
|
|
service string
|
|
want bool
|
|
}{
|
|
{"proxy", "proxy", true},
|
|
{"all", "all", true},
|
|
{"authenticate", "authenticate", true},
|
|
{"authenticate bad case", "AuThenticate", false},
|
|
{"authorize implemented", "authorize", true},
|
|
{"jiberish", "xd23", false},
|
|
}
|
|
for _, tt := range tests {
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
if got := IsValidService(tt.service); got != tt.want {
|
|
t.Errorf("isValidService() = %v, want %v", got, tt.want)
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
func Test_isAuthenticate(t *testing.T) {
|
|
tests := []struct {
|
|
name string
|
|
service string
|
|
want bool
|
|
}{
|
|
{"proxy", "proxy", false},
|
|
{"all", "all", true},
|
|
{"authenticate", "authenticate", true},
|
|
{"authenticate bad case", "AuThenticate", false},
|
|
{"authorize implemented", "authorize", false},
|
|
{"jiberish", "xd23", false},
|
|
}
|
|
for _, tt := range tests {
|
|
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
if got := IsAuthenticate(tt.service); got != tt.want {
|
|
t.Errorf("isAuthenticate() = %v, want %v", got, tt.want)
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
func Test_isAuthorize(t *testing.T) {
|
|
tests := []struct {
|
|
name string
|
|
service string
|
|
want bool
|
|
}{
|
|
{"proxy", "proxy", false},
|
|
{"all", "all", true},
|
|
{"authorize", "authorize", true},
|
|
{"authorize bad case", "AuThorize", false},
|
|
{"authenticate implemented", "authenticate", false},
|
|
{"jiberish", "xd23", false},
|
|
}
|
|
for _, tt := range tests {
|
|
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
if got := IsAuthorize(tt.service); got != tt.want {
|
|
t.Errorf("isAuthenticate() = %v, want %v", got, tt.want)
|
|
}
|
|
})
|
|
}
|
|
}
|
|
func Test_IsProxy(t *testing.T) {
|
|
tests := []struct {
|
|
name string
|
|
service string
|
|
want bool
|
|
}{
|
|
{"proxy", "proxy", true},
|
|
{"all", "all", true},
|
|
{"authorize", "authorize", false},
|
|
{"proxy bad case", "PrOxY", false},
|
|
{"jiberish", "xd23", false},
|
|
}
|
|
for _, tt := range tests {
|
|
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
if got := IsProxy(tt.service); got != tt.want {
|
|
t.Errorf("IsProxy() = %v, want %v", got, tt.want)
|
|
}
|
|
})
|
|
}
|
|
}
|