2020-03-23 16:19:30 +00:00
|
|
|
package jwt
|
|
|
|
|
|
|
|
import (
|
2021-02-17 23:38:32 +03:00
|
|
|
"os"
|
2020-03-23 16:19:30 +00:00
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
2020-08-19 17:47:17 +03:00
|
|
|
"github.com/unistack-org/micro/v3/auth"
|
|
|
|
"github.com/unistack-org/micro/v3/util/token"
|
2020-03-23 16:19:30 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestGenerate(t *testing.T) {
|
2021-02-17 23:38:32 +03:00
|
|
|
privKey, err := os.ReadFile("test/sample_key")
|
2020-03-23 16:19:30 +00:00
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("Unable to read private key: %v", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
j := NewTokenProvider(
|
|
|
|
token.WithPrivateKey(string(privKey)),
|
|
|
|
)
|
|
|
|
|
2020-04-01 17:29:17 +01:00
|
|
|
_, err = j.Generate(&auth.Account{ID: "test"})
|
2020-03-23 16:19:30 +00:00
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("Generate returned %v error, expected nil", err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestInspect(t *testing.T) {
|
2021-02-17 23:38:32 +03:00
|
|
|
pubKey, err := os.ReadFile("test/sample_key.pub")
|
2020-03-23 16:19:30 +00:00
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("Unable to read public key: %v", err)
|
|
|
|
}
|
2021-02-17 23:38:32 +03:00
|
|
|
privKey, err := os.ReadFile("test/sample_key")
|
2020-03-23 16:19:30 +00:00
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("Unable to read private key: %v", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
j := NewTokenProvider(
|
|
|
|
token.WithPublicKey(string(pubKey)),
|
|
|
|
token.WithPrivateKey(string(privKey)),
|
|
|
|
)
|
|
|
|
|
|
|
|
t.Run("Valid token", func(t *testing.T) {
|
|
|
|
md := map[string]string{"foo": "bar"}
|
2020-05-21 14:56:17 +01:00
|
|
|
scopes := []string{"admin"}
|
2020-03-23 16:19:30 +00:00
|
|
|
subject := "test"
|
|
|
|
|
2020-05-21 14:56:17 +01:00
|
|
|
acc := &auth.Account{ID: subject, Scopes: scopes, Metadata: md}
|
2020-04-01 17:29:17 +01:00
|
|
|
tok, err := j.Generate(acc)
|
2020-03-23 16:19:30 +00:00
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("Generate returned %v error, expected nil", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
tok2, err := j.Inspect(tok.Token)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("Inspect returned %v error, expected nil", err)
|
|
|
|
}
|
2020-04-01 17:29:17 +01:00
|
|
|
if acc.ID != subject {
|
|
|
|
t.Errorf("Inspect returned %v as the token subject, expected %v", acc.ID, subject)
|
2020-03-23 16:19:30 +00:00
|
|
|
}
|
2020-05-21 14:56:17 +01:00
|
|
|
if len(tok2.Scopes) != len(scopes) {
|
|
|
|
t.Errorf("Inspect returned %v scopes, expected %v", len(tok2.Scopes), len(scopes))
|
2020-03-23 16:19:30 +00:00
|
|
|
}
|
|
|
|
if len(tok2.Metadata) != len(md) {
|
|
|
|
t.Errorf("Inspect returned %v as the token metadata, expected %v", tok2.Metadata, md)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("Expired token", func(t *testing.T) {
|
2020-04-01 17:29:17 +01:00
|
|
|
tok, err := j.Generate(&auth.Account{}, token.WithExpiry(-10*time.Second))
|
2020-03-23 16:19:30 +00:00
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("Generate returned %v error, expected nil", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if _, err = j.Inspect(tok.Token); err != token.ErrInvalidToken {
|
|
|
|
t.Fatalf("Inspect returned %v error, expected %v", err, token.ErrInvalidToken)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("Invalid token", func(t *testing.T) {
|
|
|
|
_, err := j.Inspect("Invalid token")
|
|
|
|
if err != token.ErrInvalidToken {
|
|
|
|
t.Fatalf("Inspect returned %v error, expected %v", err, token.ErrInvalidToken)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|