forked from mystiq/dex
90 lines
2.5 KiB
Go
90 lines
2.5 KiB
Go
/*-
|
|
* Copyright 2016 Zbigniew Mandziejewicz
|
|
* Copyright 2016 Square, Inc.
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
package jwt
|
|
|
|
import (
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
func TestFieldsMatch(t *testing.T) {
|
|
c := Claims{
|
|
Issuer: "issuer",
|
|
Subject: "subject",
|
|
Audience: []string{"a1", "a2"},
|
|
ID: "42",
|
|
}
|
|
|
|
assert.NoError(t, c.Validate(Expected{Issuer: "issuer"}))
|
|
err := c.Validate(Expected{Issuer: "invalid-issuer"})
|
|
if assert.Error(t, err) {
|
|
assert.Equal(t, err, ErrInvalidIssuer)
|
|
}
|
|
|
|
assert.NoError(t, c.Validate(Expected{Subject: "subject"}))
|
|
err = c.Validate(Expected{Subject: "invalid-subject"})
|
|
if assert.Error(t, err) {
|
|
assert.Equal(t, err, ErrInvalidSubject)
|
|
}
|
|
|
|
assert.NoError(t, c.Validate(Expected{Audience: []string{"a1", "a2"}}))
|
|
err = c.Validate(Expected{Audience: []string{"invalid-audience"}})
|
|
if assert.Error(t, err) {
|
|
assert.Equal(t, err, ErrInvalidAudience)
|
|
}
|
|
|
|
assert.NoError(t, c.Validate(Expected{ID: "42"}))
|
|
err = c.Validate(Expected{ID: "invalid-id"})
|
|
if assert.Error(t, err) {
|
|
assert.Equal(t, err, ErrInvalidID)
|
|
}
|
|
}
|
|
|
|
func TestExpiryAndNotBefore(t *testing.T) {
|
|
now := time.Date(2016, 1, 1, 12, 0, 0, 0, time.UTC)
|
|
twelveHoursAgo := now.Add(-12 * time.Hour)
|
|
|
|
c := Claims{
|
|
IssuedAt: twelveHoursAgo,
|
|
NotBefore: twelveHoursAgo,
|
|
Expiry: now,
|
|
}
|
|
|
|
// expired - default leeway (1 minute)
|
|
assert.NoError(t, c.Validate(Expected{Time: now}))
|
|
err := c.Validate(Expected{Time: now.Add(2 * DefaultLeeway)})
|
|
if assert.Error(t, err) {
|
|
assert.Equal(t, err, ErrExpired)
|
|
}
|
|
|
|
// expired - no leeway
|
|
assert.NoError(t, c.ValidateWithLeeway(Expected{Time: now}, 0))
|
|
err = c.ValidateWithLeeway(Expected{Time: now.Add(1 * time.Second)}, 0)
|
|
if assert.Error(t, err) {
|
|
assert.Equal(t, err, ErrExpired)
|
|
}
|
|
|
|
// not before - default leeway (1 minute)
|
|
assert.NoError(t, c.Validate(Expected{Time: twelveHoursAgo}))
|
|
err = c.Validate(Expected{Time: twelveHoursAgo.Add(-2 * DefaultLeeway)})
|
|
if assert.Error(t, err) {
|
|
assert.Equal(t, err, ErrNotValidYet)
|
|
}
|
|
}
|