jwt/rs256_test.go

73 lines
2.3 KiB
Go
Raw Normal View History

2012-04-18 05:41:12 +04:00
package jwt
import (
"bytes"
2012-04-18 23:59:37 +04:00
"io"
"os"
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) {
file, _ := os.Open("test/sample_key.pub")
buf := new(bytes.Buffer)
io.Copy(buf, file)
key := buf.Bytes()
file.Close()
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
2012-04-18 05:41:12 +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
}
func TestRS256Sign(t *testing.T) {
file, _ := os.Open("test/sample_key")
buf := new(bytes.Buffer)
io.Copy(buf, file)
key := buf.Bytes()
file.Close()
for _, data := range rsaTestData {
if data.valid {
parts := strings.Split(data.tokenString, ".")
method, _ := GetSigningMethod("RS256")
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])
}
}
}
}