2012-04-18 05:41:12 +04:00
|
|
|
package jwt
|
|
|
|
|
|
|
|
import (
|
2014-01-02 21:14:07 +04:00
|
|
|
"io/ioutil"
|
2012-04-18 05:41:12 +04:00
|
|
|
"strings"
|
2012-04-18 23:59:37 +04:00
|
|
|
"testing"
|
2012-04-18 05:41:12 +04:00
|
|
|
)
|
|
|
|
|
2012-04-18 23:59:37 +04:00
|
|
|
var rsaTestData = []struct {
|
|
|
|
name string
|
2012-04-18 05:41:12 +04:00
|
|
|
tokenString string
|
2012-04-18 23:59:37 +04:00
|
|
|
claims map[string]interface{}
|
|
|
|
valid bool
|
2012-04-18 05:41:12 +04:00
|
|
|
}{
|
|
|
|
{
|
|
|
|
"basic: foo => bar",
|
|
|
|
"eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiJ9.eyJmb28iOiJiYXIifQ.FhkiHkoESI_cG3NPigFrxEk9Z60_oXrOT2vGm9Pn6RDgYNovYORQmmA0zs1AoAOf09ly2Nx2YAg6ABqAYga1AcMFkJljwxTT5fYphTuqpWdy4BELeSYJx5Ty2gmr8e7RonuUztrdD5WfPqLKMm1Ozp_T6zALpRmwTIW0QPnaBXaQD90FplAg46Iy1UlDKr-Eupy0i5SLch5Q-p2ZpaL_5fnTIUDlxC3pWhJTyx_71qDI-mAA_5lE_VdroOeflG56sSmDxopPEG3bFlSu1eowyBfxtu0_CuVd-M42RU75Zc4Gsj6uV77MBtbMrf4_7M_NUTSgoIF3fRqxrj0NzihIBg",
|
|
|
|
map[string]interface{}{"foo": "bar"},
|
|
|
|
true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"basic invalid: foo => bar",
|
|
|
|
"eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiJ9.eyJmb28iOiJiYXIifQ.EhkiHkoESI_cG3NPigFrxEk9Z60_oXrOT2vGm9Pn6RDgYNovYORQmmA0zs1AoAOf09ly2Nx2YAg6ABqAYga1AcMFkJljwxTT5fYphTuqpWdy4BELeSYJx5Ty2gmr8e7RonuUztrdD5WfPqLKMm1Ozp_T6zALpRmwTIW0QPnaBXaQD90FplAg46Iy1UlDKr-Eupy0i5SLch5Q-p2ZpaL_5fnTIUDlxC3pWhJTyx_71qDI-mAA_5lE_VdroOeflG56sSmDxopPEG3bFlSu1eowyBfxtu0_CuVd-M42RU75Zc4Gsj6uV77MBtbMrf4_7M_NUTSgoIF3fRqxrj0NzihIBg",
|
|
|
|
map[string]interface{}{"foo": "bar"},
|
|
|
|
false,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestRS256Verify(t *testing.T) {
|
2014-01-02 21:14:07 +04:00
|
|
|
key, _ := ioutil.ReadFile("test/sample_key.pub")
|
2012-04-18 23:59:37 +04:00
|
|
|
|
2012-04-18 23:18:31 +04:00
|
|
|
for _, data := range rsaTestData {
|
2012-04-18 05:41:12 +04:00
|
|
|
parts := strings.Split(data.tokenString, ".")
|
2012-04-18 23:59:37 +04:00
|
|
|
|
2013-10-08 09:01:07 +04:00
|
|
|
method := GetSigningMethod("RS256")
|
2012-04-18 09:50:26 +04:00
|
|
|
err := method.Verify(strings.Join(parts[0:2], "."), parts[2], key)
|
2012-04-18 05:41:12 +04:00
|
|
|
if data.valid && err != nil {
|
|
|
|
t.Errorf("[%v] Error while verifying key: %v", data.name, err)
|
|
|
|
}
|
|
|
|
if !data.valid && err == nil {
|
|
|
|
t.Errorf("[%v] Invalid key passed validation", data.name)
|
|
|
|
}
|
|
|
|
}
|
2012-04-18 23:59:37 +04:00
|
|
|
}
|
2012-07-07 02:43:17 +04:00
|
|
|
|
|
|
|
func TestRS256Sign(t *testing.T) {
|
2014-01-02 21:14:07 +04:00
|
|
|
key, _ := ioutil.ReadFile("test/sample_key")
|
2012-07-07 02:43:17 +04:00
|
|
|
|
|
|
|
for _, data := range rsaTestData {
|
|
|
|
if data.valid {
|
|
|
|
parts := strings.Split(data.tokenString, ".")
|
2013-10-08 09:01:07 +04:00
|
|
|
method := GetSigningMethod("RS256")
|
2012-07-07 02:43:17 +04:00
|
|
|
sig, err := method.Sign(strings.Join(parts[0:2], "."), key)
|
|
|
|
if err != nil {
|
|
|
|
t.Errorf("[%v] Error signing token: %v", data.name, err)
|
|
|
|
}
|
|
|
|
if sig != parts[2] {
|
|
|
|
t.Errorf("[%v] Incorrect signature.\nwas:\n%v\nexpecting:\n%v", data.name, sig, parts[2])
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2012-07-07 04:02:20 +04:00
|
|
|
}
|
2014-06-28 22:29:32 +04:00
|
|
|
|
|
|
|
func TestKeyParsing(t *testing.T) {
|
|
|
|
key, _ := ioutil.ReadFile("test/sample_key")
|
|
|
|
pubKey, _ := ioutil.ReadFile("test/sample_key.pub")
|
|
|
|
badKey := []byte("All your base are belong to key")
|
|
|
|
method := GetSigningMethod("RS256").(*SigningMethodRS256)
|
|
|
|
|
|
|
|
if _, e := method.parsePrivateKey(key); e != nil {
|
|
|
|
t.Errorf("Failed to parse valid private key: %v", e)
|
|
|
|
}
|
|
|
|
|
|
|
|
if k, e := method.parsePrivateKey(pubKey); e == nil {
|
|
|
|
t.Errorf("Parsed public key as valid private key: %v", k)
|
|
|
|
}
|
|
|
|
|
|
|
|
if k, e := method.parsePrivateKey(badKey); e == nil {
|
|
|
|
t.Errorf("Parsed invalid key as valid private key: %v", k)
|
|
|
|
}
|
|
|
|
}
|