alternate approach to fixing tests
This commit is contained in:
parent
58f1bb4556
commit
bbaea52ea6
5 changed files with 36 additions and 13 deletions
|
@ -159,9 +159,9 @@ func TestInvitationHandler(t *testing.T) {
|
|||
t.Errorf("case %d: password token is invalid: %v", i, err)
|
||||
}
|
||||
|
||||
expTime := pwrReset.Claims["exp"].(float64)
|
||||
if expTime > float64(tZero.Add(handler.redirectValidityWindow).Unix()) ||
|
||||
expTime < float64(tZero.Unix()) {
|
||||
expTime := pwrReset.Claims["exp"].(int64)
|
||||
if expTime > tZero.Add(handler.redirectValidityWindow).Unix() ||
|
||||
expTime < tZero.Unix() {
|
||||
t.Errorf("case %d: funny expiration time detected: %d", i, pwrReset.Claims["exp"])
|
||||
}
|
||||
|
||||
|
|
|
@ -34,8 +34,8 @@ func TestSessionClaims(t *testing.T) {
|
|||
"iss": issuerURL,
|
||||
"sub": "elroy-id",
|
||||
"aud": "XXX",
|
||||
"iat": float64(now.Unix()),
|
||||
"exp": float64(now.Add(time.Hour).Unix()),
|
||||
"iat": now.Unix(),
|
||||
"exp": now.Add(time.Hour).Unix(),
|
||||
},
|
||||
},
|
||||
|
||||
|
@ -57,8 +57,8 @@ func TestSessionClaims(t *testing.T) {
|
|||
"iss": issuerURL,
|
||||
"sub": "elroy-id",
|
||||
"aud": "XXX",
|
||||
"iat": float64(now.Unix()),
|
||||
"exp": float64(now.Add(time.Hour).Unix()),
|
||||
"iat": now.Unix(),
|
||||
"exp": now.Add(time.Hour).Unix(),
|
||||
},
|
||||
},
|
||||
// Nonce gets propagated.
|
||||
|
@ -79,8 +79,8 @@ func TestSessionClaims(t *testing.T) {
|
|||
"iss": issuerURL,
|
||||
"sub": "elroy-id",
|
||||
"aud": "XXX",
|
||||
"iat": float64(now.Unix()),
|
||||
"exp": float64(now.Add(time.Hour).Unix()),
|
||||
"iat": now.Unix(),
|
||||
"exp": now.Add(time.Hour).Unix(),
|
||||
"nonce": "oncenay",
|
||||
},
|
||||
},
|
||||
|
|
|
@ -45,9 +45,9 @@ func TestNewEmailVerification(t *testing.T) {
|
|||
"aud": clientID,
|
||||
ClaimEmailVerificationCallback: callback,
|
||||
ClaimEmailVerificationEmail: usr.Email,
|
||||
"exp": float64(now.Add(expires).Unix()),
|
||||
"exp": now.Add(expires).Unix(),
|
||||
"sub": usr.ID,
|
||||
"iat": float64(now.Unix()),
|
||||
"iat": now.Unix(),
|
||||
},
|
||||
},
|
||||
}
|
||||
|
|
|
@ -106,9 +106,9 @@ func TestNewPasswordReset(t *testing.T) {
|
|||
"aud": clientID,
|
||||
ClaimPasswordResetCallback: callback,
|
||||
ClaimPasswordResetPassword: string(password),
|
||||
"exp": float64(now.Add(expires).Unix()),
|
||||
"exp": now.Add(expires).Unix(),
|
||||
"sub": usr.ID,
|
||||
"iat": float64(now.Unix()),
|
||||
"iat": now.Unix(),
|
||||
},
|
||||
},
|
||||
}
|
||||
|
|
23
user/user.go
23
user/user.go
|
@ -4,6 +4,7 @@ import (
|
|||
"encoding/json"
|
||||
"errors"
|
||||
"fmt"
|
||||
"math"
|
||||
"time"
|
||||
|
||||
"net/mail"
|
||||
|
@ -259,5 +260,27 @@ func parseAndVerifyTokenClaims(token string, issuer url.URL, keys []key.PublicKe
|
|||
return TokenClaims{}, err
|
||||
}
|
||||
|
||||
timeClaimsToInt(claims)
|
||||
|
||||
return TokenClaims{claims}, nil
|
||||
}
|
||||
|
||||
// timeClaimsToInt converts float64 time claims to ints.
|
||||
// This is unfortunately neccessary for interop as some clients incorrectly fail
|
||||
// to marshal floats as times.
|
||||
func timeClaimsToInt(claims jose.Claims) {
|
||||
for _, k := range []string{"exp", "iat"} {
|
||||
v, ok := claims[k]
|
||||
if !ok {
|
||||
continue
|
||||
}
|
||||
|
||||
fVal, ok := v.(float64)
|
||||
if !ok {
|
||||
continue
|
||||
}
|
||||
|
||||
// round
|
||||
claims[k] = int64(fVal + math.Copysign(0.5, fVal))
|
||||
}
|
||||
}
|
||||
|
|
Reference in a new issue