Re-enable selector-test

This commit is contained in:
Ilja Neumann
2020-05-23 06:28:30 +02:00
committed by Ilja Neumann
parent ea254d6036
commit 6b76c2783e

View File

@@ -1,128 +1,127 @@
package policy
// import (
// "context"
// "fmt"
// "net/http/httptest"
// "testing"
import (
"context"
"fmt"
"net/http/httptest"
"testing"
// "github.com/golang/protobuf/ptypes/empty"
// "github.com/micro/go-micro/v2/client"
// "github.com/owncloud/ocis-accounts/pkg/proto/v0"
// "github.com/owncloud/ocis-pkg/v2/oidc"
// "github.com/owncloud/ocis-proxy/pkg/config"
// )
"github.com/micro/go-micro/v2/client"
"github.com/owncloud/ocis-accounts/pkg/proto/v0"
"github.com/owncloud/ocis-pkg/v2/oidc"
"github.com/owncloud/ocis-proxy/pkg/config"
)
// func TestStaticSelector(t *testing.T) {
// ctx := context.Background()
// req := httptest.NewRequest("GET", "https://example.org/foo", nil)
// sel := NewStaticSelector(&config.StaticSelectorConf{Policy: "reva"})
func TestStaticSelector(t *testing.T) {
ctx := context.Background()
req := httptest.NewRequest("GET", "https://example.org/foo", nil)
sel := NewStaticSelector(&config.StaticSelectorConf{Policy: "reva"})
// want := "reva"
// got, err := sel(ctx, req)
// if got != want {
// t.Errorf("Expected policy %v got %v", want, got)
// }
want := "reva"
got, err := sel(ctx, req)
if got != want {
t.Errorf("Expected policy %v got %v", want, got)
}
// if err != nil {
// t.Errorf("Unexpected error %v", err)
// }
if err != nil {
t.Errorf("Unexpected error %v", err)
}
// sel = NewStaticSelector(&config.StaticSelectorConf{Policy: "foo"})
sel = NewStaticSelector(&config.StaticSelectorConf{Policy: "foo"})
// want = "foo"
// got, err = sel(ctx, req)
// if got != want {
// t.Errorf("Expected policy %v got %v", want, got)
// }
want = "foo"
got, err = sel(ctx, req)
if got != want {
t.Errorf("Expected policy %v got %v", want, got)
}
// if err != nil {
// t.Errorf("Unexpected error %v", err)
// }
// }
if err != nil {
t.Errorf("Unexpected error %v", err)
}
}
// type testCase struct {
// AccSvcShouldReturnError bool
// Claims *oidc.StandardClaims
// Expected string
// }
type testCase struct {
AccSvcShouldReturnError bool
Claims *oidc.StandardClaims
Expected string
}
// func TestMigrationSelector(t *testing.T) {
// cfg := config.MigrationSelectorConf{
// AccFoundPolicy: "found",
// AccNotFoundPolicy: "not_found",
// UnauthenticatedPolicy: "unauth",
// }
// var tests = []testCase{
// {true, &oidc.StandardClaims{PreferredUsername: "Hans"}, "not_found"},
// {false, &oidc.StandardClaims{PreferredUsername: "Hans"}, "found"},
// {false, nil, "unauth"},
// }
func TestMigrationSelector(t *testing.T) {
cfg := config.MigrationSelectorConf{
AccFoundPolicy: "found",
AccNotFoundPolicy: "not_found",
UnauthenticatedPolicy: "unauth",
}
var tests = []testCase{
{true, &oidc.StandardClaims{PreferredUsername: "Hans"}, "not_found"},
{false, &oidc.StandardClaims{PreferredUsername: "Hans"}, "found"},
{false, nil, "unauth"},
}
// for k, tc := range tests {
// t.Run(fmt.Sprintf("#%v", k), func(t *testing.T) {
// t.Parallel()
// tc := tc
// sut := NewMigrationSelector(&cfg, mockAccSvc(tc.AccSvcShouldReturnError))
// r := httptest.NewRequest("GET", "https://example.com", nil)
// ctx := oidc.NewContext(r.Context(), tc.Claims)
// nr := r.WithContext(ctx)
for k, tc := range tests {
t.Run(fmt.Sprintf("#%v", k), func(t *testing.T) {
t.Parallel()
tc := tc
sut := NewMigrationSelector(&cfg, mockAccSvc(tc.AccSvcShouldReturnError))
r := httptest.NewRequest("GET", "https://example.com", nil)
ctx := oidc.NewContext(r.Context(), tc.Claims)
nr := r.WithContext(ctx)
// got, err := sut(ctx, nr)
// if err != nil {
// t.Errorf("Unexpected error: %v", err)
// }
got, err := sut(ctx, nr)
if err != nil {
t.Errorf("Unexpected error: %v", err)
}
// if got != tc.Expected {
// t.Errorf("Expected Policy %v got %v", tc.Expected, got)
// }
// })
// }
// }
if got != tc.Expected {
t.Errorf("Expected Policy %v got %v", tc.Expected, got)
}
})
}
}
// func mockAccSvc(retErr bool) proto.AccountsService {
// if retErr {
// return &mockSettingsService{
// getFunc: func(ctx context.Context, in *proto.Query, opts ...client.CallOption) (record *proto.Record, err error) {
// return nil, fmt.Errorf("error returned by mockSettingService GET")
// },
// }
// }
func mockAccSvc(retErr bool) proto.AccountsService {
if retErr {
return &mockAccountsService{
getFunc: func(ctx context.Context, in *proto.GetRequest, opts ...client.CallOption) (record *proto.Record, err error) {
return nil, fmt.Errorf("error returned by mockAccountsService GET")
},
}
}
// return &mockSettingsService{
// getFunc: func(ctx context.Context, in *proto.Query, opts ...client.CallOption) (record *proto.Record, err error) {
// return &proto.Record{}, nil
// },
// }
return &mockAccountsService{
getFunc: func(ctx context.Context, in *proto.GetRequest, opts ...client.CallOption) (record *proto.Record, err error) {
return &proto.Record{}, nil
},
}
// }
}
// type mockSettingsService struct {
// setFunc func(ctx context.Context, in *proto.Record, opts ...client.CallOption) (*proto.Record, error)
// getFunc func(ctx context.Context, in *proto.GetRequest, opts ...client.CallOption) (*proto.Record, error)
// searchFunc func(ctx context.Context, in *proto.Query, opts ...client.CallOption) (*proto.Records, error)
// }
type mockAccountsService struct {
setFunc func(ctx context.Context, in *proto.Record, opts ...client.CallOption) (*proto.Record, error)
getFunc func(ctx context.Context, in *proto.GetRequest, opts ...client.CallOption) (*proto.Record, error)
searchFunc func(ctx context.Context, in *proto.Query, opts ...client.CallOption) (*proto.Records, error)
}
// func (m mockSettingsService) Set(ctx context.Context, in *proto.Record, opts ...client.CallOption) (*proto.Record, error) {
// if m.setFunc != nil {
// return m.setFunc(ctx, in, opts...)
// }
func (m mockAccountsService) Set(ctx context.Context, in *proto.Record, opts ...client.CallOption) (*proto.Record, error) {
if m.setFunc != nil {
return m.setFunc(ctx, in, opts...)
}
// panic("setFunc was called in test but not mocked")
// }
panic("setFunc was called in test but not mocked")
}
// func (m mockSettingsService) Get(ctx context.Context, in *proto.Query, opts ...client.CallOption) (*proto.Record, error) {
// if m.getFunc != nil {
// return m.getFunc(ctx, in, opts...)
// }
func (m mockAccountsService) Get(ctx context.Context, in *proto.GetRequest, opts ...client.CallOption) (*proto.Record, error) {
if m.getFunc != nil {
return m.getFunc(ctx, in, opts...)
}
// panic("getFunc was called in test but not mocked")
// }
panic("getFunc was called in test but not mocked")
}
// func (m mockSettingsService) List(ctx context.Context, in *empty.Empty, opts ...client.CallOption) (*proto.Records, error) {
// if m.listFunc != nil {
// return m.listFunc(ctx, in, opts...)
// }
func (m mockAccountsService) Search(ctx context.Context, in *proto.Query, opts ...client.CallOption) (*proto.Records, error) {
if m.searchFunc != nil {
return m.searchFunc(ctx, in, opts...)
}
// panic("listFunc was called in test but not mocked")
// }
panic("listFunc was called in test but not mocked")
}