* first draft of a new server interface * allow any response type * complete interface docs * refelct the format from the proposal * intermediate commit with some methods implemented * implement remaining token grant type methods * implement remaining server methods * error handling * rewrite auth request validation * define handlers, routes * input validation and concrete handlers * check if client credential client is authenticated * copy and modify the routes test for the legacy server * run integration tests against both Server and Provider * remove unuse ValidateAuthRequestV2 function * unit tests for error handling * cleanup tokenHandler * move server routest test * unit test authorize * handle client credentials in VerifyClient * change code exchange route test * finish http unit tests * review server interface docs and spelling * add withClient unit test * server options * cleanup unused GrantType method * resolve typo comments * make endpoints pointers to enable/disable them * jwt profile base work * jwt: correct the test expect --------- Co-authored-by: Livio Spring <livio.a@gmail.com>
121 lines
2 KiB
Go
121 lines
2 KiB
Go
package op_test
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/require"
|
|
"github.com/zitadel/oidc/v3/pkg/op"
|
|
)
|
|
|
|
func TestEndpoint_Path(t *testing.T) {
|
|
tests := []struct {
|
|
name string
|
|
e *op.Endpoint
|
|
want string
|
|
}{
|
|
{
|
|
"without starting /",
|
|
op.NewEndpoint("test"),
|
|
"/test",
|
|
},
|
|
{
|
|
"with starting /",
|
|
op.NewEndpoint("/test"),
|
|
"/test",
|
|
},
|
|
{
|
|
"with url",
|
|
op.NewEndpointWithURL("/test", "http://test.com/test"),
|
|
"/test",
|
|
},
|
|
{
|
|
"nil",
|
|
nil,
|
|
"",
|
|
},
|
|
}
|
|
for _, tt := range tests {
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
if got := tt.e.Relative(); got != tt.want {
|
|
t.Errorf("Endpoint.Relative() = %v, want %v", got, tt.want)
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
func TestEndpoint_Absolute(t *testing.T) {
|
|
type args struct {
|
|
host string
|
|
}
|
|
tests := []struct {
|
|
name string
|
|
e *op.Endpoint
|
|
args args
|
|
want string
|
|
}{
|
|
{
|
|
"no /",
|
|
op.NewEndpoint("test"),
|
|
args{"https://host"},
|
|
"https://host/test",
|
|
},
|
|
{
|
|
"endpoint without /",
|
|
op.NewEndpoint("test"),
|
|
args{"https://host/"},
|
|
"https://host/test",
|
|
},
|
|
{
|
|
"host without /",
|
|
op.NewEndpoint("/test"),
|
|
args{"https://host"},
|
|
"https://host/test",
|
|
},
|
|
{
|
|
"both /",
|
|
op.NewEndpoint("/test"),
|
|
args{"https://host/"},
|
|
"https://host/test",
|
|
},
|
|
{
|
|
"with url",
|
|
op.NewEndpointWithURL("test", "https://test.com/test"),
|
|
args{"https://host"},
|
|
"https://test.com/test",
|
|
},
|
|
{
|
|
"nil",
|
|
nil,
|
|
args{"https://host"},
|
|
"",
|
|
},
|
|
}
|
|
for _, tt := range tests {
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
if got := tt.e.Absolute(tt.args.host); got != tt.want {
|
|
t.Errorf("Endpoint.Absolute() = %v, want %v", got, tt.want)
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
// TODO: impl test
|
|
func TestEndpoint_Validate(t *testing.T) {
|
|
tests := []struct {
|
|
name string
|
|
e *op.Endpoint
|
|
wantErr error
|
|
}{
|
|
{
|
|
"nil",
|
|
nil,
|
|
op.ErrNilEndpoint,
|
|
},
|
|
}
|
|
for _, tt := range tests {
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
err := tt.e.Validate()
|
|
require.ErrorIs(t, err, tt.wantErr)
|
|
})
|
|
}
|
|
}
|