auth/jwt/jwt_test.go
shchva 876df38907 edit: jwt
add: VerifyOption
    edit: Verify
2025-01-11 01:31:09 +03:00

140 lines
3.4 KiB
Go

package jwt_test
import (
"errors"
"fmt"
"testing"
"time"
"git.daebt.dev/auth/algo/rs"
"git.daebt.dev/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())
}
})
}
}