140 lines
3.4 KiB
Go
140 lines
3.4 KiB
Go
package jwt_test
|
|
|
|
import (
|
|
"errors"
|
|
"fmt"
|
|
"testing"
|
|
"time"
|
|
|
|
"git.daebt.dev/golang/auth/algo/rs"
|
|
"git.daebt.dev/golang/auth/jwt"
|
|
)
|
|
|
|
var key = `-----BEGIN RSA PRIVATE KEY-----
|
|
MIIEpAIBAAKCAQEAzIWvl1OtwExnQ3HvoYk6bFRIlcCjzdv1yHazJfr6jxk6w+tC
|
|
sIWEdtKsAPm3gmmFG+mTuHq+H53sahm6DD9YC5ZQjnvSYkBKv70Zw331/tg9VLbf
|
|
Jc+gN7kbD3xMQsucYD0973r7l9pEPH4Qw/I+BEKHMxlTmynStgKxnfyO6iPkL5jT
|
|
zpUXlD4V9xqUoMY/uX3EpGwbJJKFJuphYX3jzJQ++tovQGGep7RgNeMEoWjyAkJ2
|
|
yb7tiSWsw7qk6GO2z6NDmnc1UsdSBZ6Vg7BPUp8EINAdX1wbmB0+QH/vp0huM6lS
|
|
Y6NMBugwptQUe5UCaly9fN4kb26U0qglEoGB6wIDAQABAoIBADU244UgRKkwN/4Y
|
|
ex0ws37UPz6XrQc3IDBUkjBjqSXqjpvDbsq3Mswn7JEkaFcKVZP5pnHtneJkGMtS
|
|
flIJeUMqjTNFjGv8Bnb1IOr4rzTr1qlgG5ee+jUFeMECumT2zW1NAfx5p1TPecmz
|
|
k3EoanJ5TOxCvro0m5q4ALb2q8jHrtfvtqEBrHepeEp3Lyh7m4ZUib+0yWXs0EPC
|
|
HhF9kLpCy+tVXUPDyLCt4cldTUda/3xeswzmxVRrHkt/idsNuTAi7o1Cx/OfZYMI
|
|
AzQo8OTh1Bg2DlXKtOX40frIxy3/K77F3ozwV4a3FravUO+wvcQdIyi6KAmNBFS3
|
|
9IVA7IECgYEA4x0TAn7vOvazILmg4Es0/gsWlh7RGmNTqVYtj5TfwOviUGeaculR
|
|
BSsyX8pgaROJKjGDcNzSQQEhHfJXrhNXeMJ0zPUIsJCBmih8oaCpAScWpV+qpdky
|
|
1Eb2akEg7XbpqBJJ1jnoEvIhd4feCAN8Gv8vcmdER7HaGdyef4XxlFsCgYEA5okG
|
|
tbyTtD2cfmYjYsoGqEfGH0Pe9vxc+MBthiPg0f2lpg+YuSPx92ZuJciLNyNWo9qf
|
|
NFnzbSEFxzomK/Bgq9ujGnbPyLOCadIADM4/njEEPe+IsagDxBgTrCEUJ56W9MLj
|
|
N+b4d/gnBkK4roDW8gjy7x4MbePByoDfaWtU/bECgYEApn8RCZpe7V4gMdSEIQph
|
|
fgBI/aL37p10nsbDvegJJRiIoCNjsexj7iMd2eW2SjH9M4Z68smgBfG7AoZASyh4
|
|
ztnX4M2eIjq+GHKn86GhZGvwiSoaI12YitC/I2Q9rHipkQJfSQLIpOMHL+bWGg/b
|
|
8rqzYO5duyWiW6VGOPzL/tMCgYB3JVSZcrfnzHvn+8PIF9+u80FbAUnn3m/yhAlW
|
|
7Y4RGYWWOLNW5FP26DJ/RpFk0tfBYYksllywBwQkflIiHV7pE1/NmqAy+0uog0dR
|
|
VvscN/sYQ4cjQlGH9GWebY4sF9Ou9lZWmwHJhzAsFSm7zozIlIVxvdbwqGiMz2Qn
|
|
6LgJUQKBgQC9H2JGm54wg0YPuDig5LjymUxYJrEiJT0IXz4vy+UEMxw+1EmeD5sm
|
|
kSqHkwNDp7D+3nik5HzoFVifJAvqFWU73fpvqQlvZSNfVrtq8UvJBIuH7eHkrJrC
|
|
L8dEn16HWjLX50GlT+9eYyHWtYI4sMdnzz1/JS6PwQRxKlFQN9HJYg==
|
|
-----END RSA PRIVATE KEY-----`
|
|
|
|
func TestCreate(t *testing.T) {
|
|
alg, err := rs.NewRS256(
|
|
rs.WithPEM(nil, []byte(key)),
|
|
)
|
|
if err != nil {
|
|
t.Fatal(err.Error())
|
|
}
|
|
|
|
tm := time.Now()
|
|
|
|
var data = []*struct {
|
|
o []jwt.Option
|
|
v []jwt.VerifyOption
|
|
e error
|
|
}{
|
|
{
|
|
[]jwt.Option{
|
|
jwt.WithIssuer("https://git.daebt.dev"),
|
|
},
|
|
nil,
|
|
nil,
|
|
},
|
|
{
|
|
[]jwt.Option{
|
|
jwt.WithIssuer("https://git.daebt.dev"),
|
|
jwt.WithIssuedAt(tm),
|
|
jwt.WithExpirationTime(tm.Add(time.Hour)),
|
|
},
|
|
nil,
|
|
nil,
|
|
},
|
|
{
|
|
[]jwt.Option{
|
|
jwt.WithIssuer("https://git.daebt.dev"),
|
|
jwt.WithIssuedAt(tm),
|
|
jwt.WithExpirationTime(tm.Add(-time.Hour)),
|
|
},
|
|
nil,
|
|
jwt.ErrExpired,
|
|
},
|
|
{
|
|
[]jwt.Option{
|
|
jwt.WithIssuer("https://git.daebt.dev"),
|
|
jwt.WithIssuedAt(tm),
|
|
jwt.WithNotBefore(tm.Add(time.Hour)),
|
|
},
|
|
nil,
|
|
jwt.ErrNotActivated,
|
|
},
|
|
{
|
|
[]jwt.Option{
|
|
jwt.WithIssuer("https://git.daebt.dev"),
|
|
jwt.WithIssuedAt(tm),
|
|
},
|
|
[]jwt.VerifyOption{
|
|
jwt.WithVerifyIssuer("https://git.daebt.dev"),
|
|
},
|
|
nil,
|
|
},
|
|
{
|
|
[]jwt.Option{
|
|
jwt.WithIssuedAt(tm),
|
|
},
|
|
[]jwt.VerifyOption{
|
|
jwt.WithVerifyIssuer(),
|
|
},
|
|
jwt.ErrKeyNotExist,
|
|
},
|
|
{
|
|
[]jwt.Option{
|
|
jwt.WithIssuer("https://git.daebt.dev"),
|
|
jwt.WithIssuedAt(tm),
|
|
},
|
|
[]jwt.VerifyOption{
|
|
jwt.WithVerifyIssuer(),
|
|
},
|
|
nil,
|
|
},
|
|
}
|
|
|
|
for i, v := range data {
|
|
t.Run(fmt.Sprint(i), func(t *testing.T) {
|
|
val, err := jwt.New(v.o...).Sign(alg)
|
|
if err != nil {
|
|
t.Fatal(err.Error())
|
|
}
|
|
|
|
tkn, err := jwt.Parse(val)
|
|
if err != nil {
|
|
t.Fatal(err.Error())
|
|
}
|
|
|
|
if err := tkn.Verify(alg, v.v...); !errors.Is(err, v.e) {
|
|
t.Fatal(err.Error())
|
|
}
|
|
})
|
|
}
|
|
|
|
}
|