Use anonymous interface in test for Storage

This commit is contained in:
aram price 2020-12-03 11:26:36 -08:00
parent 67bf54a9f9
commit 05085d8e23

View File

@ -55,14 +55,6 @@ const (
timeComparisonFudgeSeconds = 15 timeComparisonFudgeSeconds = 15
) )
type CombinedStorage interface {
oauth2.TokenRevocationStorage
oauth2.CoreStorage
openid.OpenIDConnectRequestStorage
pkce.PKCERequestStorage
fosite.ClientManager
}
var ( var (
goodAuthTime = time.Date(1, 2, 3, 4, 5, 6, 7, time.Local) goodAuthTime = time.Date(1, 2, 3, 4, 5, 6, 7, time.Local)
goodRequestedAtTime = time.Date(7, 6, 5, 4, 3, 2, 1, time.Local) goodRequestedAtTime = time.Date(7, 6, 5, 4, 3, 2, 1, time.Local)
@ -206,7 +198,17 @@ func TestTokenEndpoint(t *testing.T) {
name string name string
authRequest func(authRequest *http.Request) authRequest func(authRequest *http.Request)
storage func(t *testing.T, s CombinedStorage, authCode string) storage func(
t *testing.T,
s interface {
oauth2.TokenRevocationStorage
oauth2.CoreStorage
openid.OpenIDConnectRequestStorage
pkce.PKCERequestStorage
fosite.ClientManager
},
authCode string,
)
request func(r *http.Request, authCode string) request func(r *http.Request, authCode string)
wantStatus int wantStatus int
@ -323,7 +325,17 @@ func TestTokenEndpoint(t *testing.T) {
}, },
{ {
name: "auth code is invalidated", name: "auth code is invalidated",
storage: func(t *testing.T, s CombinedStorage, authCode string) { storage: func(
t *testing.T,
s interface {
oauth2.TokenRevocationStorage
oauth2.CoreStorage
openid.OpenIDConnectRequestStorage
pkce.PKCERequestStorage
fosite.ClientManager
},
authCode string,
) {
err := s.InvalidateAuthorizeCodeSession(context.Background(), getFositeDataSignature(t, authCode)) err := s.InvalidateAuthorizeCodeSession(context.Background(), getFositeDataSignature(t, authCode))
require.NoError(t, err) require.NoError(t, err)
}, },
@ -525,7 +537,13 @@ func getFositeDataSignature(t *testing.T, data string) string {
func makeHappyOauthHelper( func makeHappyOauthHelper(
t *testing.T, t *testing.T,
authRequest *http.Request, authRequest *http.Request,
store CombinedStorage, store interface {
oauth2.TokenRevocationStorage
oauth2.CoreStorage
openid.OpenIDConnectRequestStorage
pkce.PKCERequestStorage
fosite.ClientManager
},
) (fosite.OAuth2Provider, string, *ecdsa.PrivateKey) { ) (fosite.OAuth2Provider, string, *ecdsa.PrivateKey) {
t.Helper() t.Helper()
@ -581,7 +599,7 @@ func doSHA256(s string) string {
func requireInvalidAuthCodeStorage( func requireInvalidAuthCodeStorage(
t *testing.T, t *testing.T,
code string, code string,
storage CombinedStorage, storage oauth2.CoreStorage,
) { ) {
t.Helper() t.Helper()
@ -593,7 +611,7 @@ func requireInvalidAuthCodeStorage(
func requireValidAccessTokenStorage( func requireValidAccessTokenStorage(
t *testing.T, t *testing.T,
body map[string]interface{}, body map[string]interface{},
storage CombinedStorage, storage oauth2.CoreStorage,
wantGrantedOpenidScope bool, wantGrantedOpenidScope bool,
) { ) {
t.Helper() t.Helper()
@ -642,7 +660,7 @@ func requireValidAccessTokenStorage(
func requireInvalidAccessTokenStorage( func requireInvalidAccessTokenStorage(
t *testing.T, t *testing.T,
body map[string]interface{}, body map[string]interface{},
storage CombinedStorage, storage oauth2.CoreStorage,
) { ) {
t.Helper() t.Helper()
@ -658,7 +676,7 @@ func requireInvalidAccessTokenStorage(
func requireInvalidPKCEStorage( func requireInvalidPKCEStorage(
t *testing.T, t *testing.T,
code string, code string,
storage CombinedStorage, storage pkce.PKCERequestStorage,
) { ) {
t.Helper() t.Helper()
@ -672,7 +690,7 @@ func requireValidOIDCStorage(
t *testing.T, t *testing.T,
body map[string]interface{}, body map[string]interface{},
code string, code string,
storage CombinedStorage, storage openid.OpenIDConnectRequestStorage,
wantGrantedOpenidScope bool, wantGrantedOpenidScope bool,
) { ) {
t.Helper() t.Helper()