2023-06-18 13:03:41 +01:00
|
|
|
package auth
|
|
|
|
|
|
|
|
import (
|
|
|
|
"crypto/rand"
|
|
|
|
"crypto/rsa"
|
|
|
|
"github.com/MrMelon54/mjwt"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
"testing"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestCreateRefreshToken(t *testing.T) {
|
|
|
|
key, err := rsa.GenerateKey(rand.Reader, 2048)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
|
|
|
s := mjwt.NewMJwtSigner("mjwt.test", key)
|
|
|
|
|
2023-06-20 00:32:16 +01:00
|
|
|
refreshToken, err := CreateRefreshToken(s, "1", "test", "test2", nil)
|
2023-06-18 13:03:41 +01:00
|
|
|
assert.NoError(t, err)
|
|
|
|
|
|
|
|
_, b, err := mjwt.ExtractClaims[RefreshTokenClaims](s, refreshToken)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
assert.Equal(t, "1", b.Subject)
|
|
|
|
assert.Equal(t, "test", b.ID)
|
2023-06-20 00:32:16 +01:00
|
|
|
assert.Equal(t, "test2", b.Claims.AccessTokenId)
|
2023-06-18 13:03:41 +01:00
|
|
|
}
|