@@ -31,7 +31,10 @@ import (
31
31
"strings"
32
32
"testing"
33
33
34
+ "github.com/google/go-cmp/cmp"
34
35
"github.com/stretchr/testify/assert"
36
+ "github.com/stretchr/testify/require"
37
+
35
38
"golang.org/x/crypto/ed25519"
36
39
37
40
"gopkg.in/square/go-jose.v2/json"
@@ -246,37 +249,117 @@ func TestRoundtripX509(t *testing.T) {
246
249
x5tSHA1 := sha1 .Sum (testCertificates [0 ].Raw )
247
250
x5tSHA256 := sha256 .Sum256 (testCertificates [0 ].Raw )
248
251
249
- jwk := JSONWebKey {
250
- Key : testCertificates [0 ].PublicKey ,
251
- KeyID : "bar" ,
252
- Algorithm : "foo" ,
253
- Certificates : testCertificates ,
254
- CertificateThumbprintSHA1 : x5tSHA1 [:],
255
- CertificateThumbprintSHA256 : x5tSHA256 [:],
252
+ cases := []struct {
253
+ name string
254
+ jwk JSONWebKey
255
+ }{
256
+ {
257
+ name : "all fields" ,
258
+ jwk : JSONWebKey {
259
+ Key : testCertificates [0 ].PublicKey ,
260
+ KeyID : "bar" ,
261
+ Algorithm : "foo" ,
262
+ Certificates : testCertificates ,
263
+ CertificateThumbprintSHA1 : x5tSHA1 [:],
264
+ CertificateThumbprintSHA256 : x5tSHA256 [:],
265
+ },
266
+ },
267
+ {
268
+ name : "no optional x5ts" ,
269
+ jwk : JSONWebKey {
270
+ Key : testCertificates [0 ].PublicKey ,
271
+ KeyID : "bar" ,
272
+ Algorithm : "foo" ,
273
+ Certificates : testCertificates ,
274
+ },
275
+ },
276
+ {
277
+ name : "no x5t" ,
278
+ jwk : JSONWebKey {
279
+ Key : testCertificates [0 ].PublicKey ,
280
+ KeyID : "bar" ,
281
+ Algorithm : "foo" ,
282
+ Certificates : testCertificates ,
283
+ CertificateThumbprintSHA256 : x5tSHA256 [:],
284
+ },
285
+ },
286
+ {
287
+ name : "no x5t#S256" ,
288
+ jwk : JSONWebKey {
289
+ Key : testCertificates [0 ].PublicKey ,
290
+ KeyID : "bar" ,
291
+ Algorithm : "foo" ,
292
+ Certificates : testCertificates ,
293
+ CertificateThumbprintSHA1 : x5tSHA1 [:],
294
+ },
295
+ },
256
296
}
257
297
258
- jsonbar , err := jwk .MarshalJSON ()
259
- if err != nil {
260
- t .Error ("problem marshaling" , err )
298
+ for _ , c := range cases {
299
+ t .Run (c .name , func (t * testing.T ) {
300
+ jsonbar , err := c .jwk .MarshalJSON ()
301
+ require .NoError (t , err )
302
+
303
+ var jwk2 JSONWebKey
304
+ err = jwk2 .UnmarshalJSON (jsonbar )
305
+ require .NoError (t , err )
306
+
307
+ if ! reflect .DeepEqual (testCertificates , jwk2 .Certificates ) {
308
+ t .Error ("Certificates not equal" , c .jwk .Certificates , jwk2 .Certificates )
309
+ }
310
+
311
+ jsonbar2 , err := jwk2 .MarshalJSON ()
312
+ require .NoError (t , err )
313
+
314
+ require .Empty (t , cmp .Diff (jsonbar , jsonbar2 ))
315
+ if ! bytes .Equal (jsonbar , jsonbar2 ) {
316
+ t .Error ("roundtrip should not lose information" )
317
+ }
318
+ })
261
319
}
320
+ }
321
+
322
+ func TestRoundtripX509Hex (t * testing.T ) {
323
+ var hexJWK = `{
324
+ "kty":"RSA",
325
+ "kid":"bar",
326
+ "alg":"foo",
327
+ "n":"u7LUr30Mhrh8N79-H4rKiHQ123q6xaBZPYbf1nV4GM19rizSnbEfyebG1kpfCv-XY6c499XiM6lOvcPL-0goTOcfW6Lg7AAR895GbnMeXEmnxICaI8rAZHK6t1WPmiWp82y_qhK2F_pYUaT3GSuiTFiMGq_GNwdpWuMlsInnnMNv1nxFbxtDPwzmCp0fEBxbH5d1EtXZwTPOHMyj8rfa-NIA5Nl4h_5RrbOWveKwBr26_CDAratJgOWh9xcd5g0ot_uDGcMoAgB6xeTuYklfaxCPptvu49kvoxw1J71fp6nKW_ZuhDRAp2F_BQ9inKpTo05sPLJg8tPTdjaeouOuJQ",
328
+ "e":"AQAB",
329
+ "x5c":[
330
+ "MIIDfDCCAmSgAwIBAgIJANWAkzF7PA8/MA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMQswCQYDVQQIEwJDQTEQMA4GA1UEChMHY2VydGlnbzEQMA4GA1UECxMHZXhhbXBsZTEVMBMGA1UEAxMMZXhhbXBsZS1sZWFmMB4XDTE2MDYxMDIyMTQxMVoXDTIzMDQxNTIyMTQxMVowVTELMAkGA1UEBhMCVVMxCzAJBgNVBAgTAkNBMRAwDgYDVQQKEwdjZXJ0aWdvMRAwDgYDVQQLEwdleGFtcGxlMRUwEwYDVQQDEwxleGFtcGxlLWxlYWYwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQC7stSvfQyGuHw3v34fisqIdDXberrFoFk9ht/WdXgYzX2uLNKdsR/J5sbWSl8K/5djpzj31eIzqU69w8v7SChM5x9bouDsABHz3kZucx5cSafEgJojysBkcrq3VY+aJanzbL+qErYX+lhRpPcZK6JMWIwar8Y3B2la4yWwieecw2/WfEVvG0M/DOYKnR8QHFsfl3US1dnBM84czKPyt9r40gDk2XiH/lGts5a94rAGvbr8IMCtq0mA5aH3Fx3mDSi3+4MZwygCAHrF5O5iSV9rEI+m2+7j2S+jHDUnvV+nqcpb9m6ENECnYX8FD2KcqlOjTmw8smDy09N2Np6i464lAgMBAAGjTzBNMB0GA1UdJQQWMBQGCCsGAQUFBwMCBggrBgEFBQcDATAsBgNVHREEJTAjhwR/AAABhxAAAAAAAAAAAAAAAAAAAAABgglsb2NhbGhvc3QwDQYJKoZIhvcNAQELBQADggEBAGM4aa/qrURUweZBIwZYv8O9b2+r4l0HjGAh982/B9sMlM05kojyDCUGvj86z18Lm8mKr4/y+i0nJ+vDIksEvfDuzw5ALAXGcBzPJKtICUf7LstA/n9NNpshWz0kld9ylnB5mbUzSFDncVyeXkEf5sGQXdIIZT9ChRBoiloSaa7dvBVCcsX1LGP2LWqKtD+7nUnw5qCwtyAVT8pthEUxFTpywoiJS5ZdzeEx8MNGvUeLFj2kleqPF78EioEQlSOxViCuctEtnQuPcDLHNFr10byTZY9roObiqdsJLMVvb2XliJjAqaPa9AkYwGE6xHw2ispwg64Rse0+AtKups19WIU=",
331
+ "MIIDUzCCAjugAwIBAgIJAKg+LQlirffwMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMQswCQYDVQQIEwJDQTEQMA4GA1UEChMHY2VydGlnbzEQMA4GA1UECxMHZXhhbXBsZTEVMBMGA1UEAxMMZXhhbXBsZS1yb290MB4XDTE2MDYxMDIyMTQxMVoXDTIzMDQxNTIyMTQxMVowVTELMAkGA1UEBhMCVVMxCzAJBgNVBAgTAkNBMRAwDgYDVQQKEwdjZXJ0aWdvMRAwDgYDVQQLEwdleGFtcGxlMRUwEwYDVQQDEwxleGFtcGxlLXJvb3QwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQDKOEoSiNjMQ8/zUFcQW89LWw+UeTXKGwNDSpGjyi8jBKZ1lWPbnMmrjI6DZ9ReevHHzqBdKZt+9NFPFEz7djDMRByIuJhRvzhfFBflaIdSeNk2+NpUaFuUUUd6IIePu0AdRveJ8ZGHXRwCeEDIVCZS4oBYPHOhX/zMWDg8vSO4pSxTjGc7I8fHxaUSkVzUBbeO9T/1eFk0m2uxs3UziUck2X/8YqRd+p/EaBED78nXvKRALAguKAzqxIgk3ccPK0SVQFNFq+eV1/qo8coueQuqMpCAvwVkfpVKhneyC2NlMrfzlcZZbfG/irlSjQn5+ExZX4Isy1pCUbOiVfSrsCdtAgMBAAGjJjAkMA4GA1UdDwEB/wQEAwICBDASBgNVHRMBAf8ECDAGAQH/AgEAMA0GCSqGSIb3DQEBCwUAA4IBAQCLEJU65vTU+oLbNHLOCR6fALrbjK7xsi6SFDpSXBMm74MWsy3myDBmXpOcN8hCYgsgivUXTQz9ynXP/pzOj4b83zzlaOfPtLTAmMhKWVV4Q85mrDQz+HzG4lKXM78eTsD8PyrocA/tSE7mVEJ0Jal4E2KI/Z9/fqpYFLB6LFlx5n83ehXM/egA0l4OeCC9nBKCeNUN3sIQO85lljyzAJdtWnsdoWogJs6qjcV8n2U5xjZxN5ZFdclYLjq6g2cjEXXMQxb8b7ZhHjLWFdjHP85UvXHK3DpK3JmUg8bYS7t1DJffDQNjawhlsMycKZN+r0ND0Um4m7AjGqxbKT/M2yKF"
332
+ ],
333
+ "x5t": "MDYxMjU0ZmRmNzIwZjJjMGU0YmQzZjMzMzlhMmZlNTM1MGExNWRlMQ",
334
+ "x5t#S256": "MjAzMjRhNGI5MmYxMjI2OGVmOWFlMDI1ZmQ1Yzc5ZDE1OGZmNzQ1NzQwMDkyMTk2ZTgzNTNjMDAzMTUxNzUxMQ"
335
+ }`
336
+
337
+ // json output
338
+ var output = `{
339
+ "kty":"RSA",
340
+ "kid":"bar",
341
+ "alg":"foo",
342
+ "n":"u7LUr30Mhrh8N79-H4rKiHQ123q6xaBZPYbf1nV4GM19rizSnbEfyebG1kpfCv-XY6c499XiM6lOvcPL-0goTOcfW6Lg7AAR895GbnMeXEmnxICaI8rAZHK6t1WPmiWp82y_qhK2F_pYUaT3GSuiTFiMGq_GNwdpWuMlsInnnMNv1nxFbxtDPwzmCp0fEBxbH5d1EtXZwTPOHMyj8rfa-NIA5Nl4h_5RrbOWveKwBr26_CDAratJgOWh9xcd5g0ot_uDGcMoAgB6xeTuYklfaxCPptvu49kvoxw1J71fp6nKW_ZuhDRAp2F_BQ9inKpTo05sPLJg8tPTdjaeouOuJQ",
343
+ "e":"AQAB",
344
+ "x5c":[
345
+ "MIIDfDCCAmSgAwIBAgIJANWAkzF7PA8/MA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMQswCQYDVQQIEwJDQTEQMA4GA1UEChMHY2VydGlnbzEQMA4GA1UECxMHZXhhbXBsZTEVMBMGA1UEAxMMZXhhbXBsZS1sZWFmMB4XDTE2MDYxMDIyMTQxMVoXDTIzMDQxNTIyMTQxMVowVTELMAkGA1UEBhMCVVMxCzAJBgNVBAgTAkNBMRAwDgYDVQQKEwdjZXJ0aWdvMRAwDgYDVQQLEwdleGFtcGxlMRUwEwYDVQQDEwxleGFtcGxlLWxlYWYwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQC7stSvfQyGuHw3v34fisqIdDXberrFoFk9ht/WdXgYzX2uLNKdsR/J5sbWSl8K/5djpzj31eIzqU69w8v7SChM5x9bouDsABHz3kZucx5cSafEgJojysBkcrq3VY+aJanzbL+qErYX+lhRpPcZK6JMWIwar8Y3B2la4yWwieecw2/WfEVvG0M/DOYKnR8QHFsfl3US1dnBM84czKPyt9r40gDk2XiH/lGts5a94rAGvbr8IMCtq0mA5aH3Fx3mDSi3+4MZwygCAHrF5O5iSV9rEI+m2+7j2S+jHDUnvV+nqcpb9m6ENECnYX8FD2KcqlOjTmw8smDy09N2Np6i464lAgMBAAGjTzBNMB0GA1UdJQQWMBQGCCsGAQUFBwMCBggrBgEFBQcDATAsBgNVHREEJTAjhwR/AAABhxAAAAAAAAAAAAAAAAAAAAABgglsb2NhbGhvc3QwDQYJKoZIhvcNAQELBQADggEBAGM4aa/qrURUweZBIwZYv8O9b2+r4l0HjGAh982/B9sMlM05kojyDCUGvj86z18Lm8mKr4/y+i0nJ+vDIksEvfDuzw5ALAXGcBzPJKtICUf7LstA/n9NNpshWz0kld9ylnB5mbUzSFDncVyeXkEf5sGQXdIIZT9ChRBoiloSaa7dvBVCcsX1LGP2LWqKtD+7nUnw5qCwtyAVT8pthEUxFTpywoiJS5ZdzeEx8MNGvUeLFj2kleqPF78EioEQlSOxViCuctEtnQuPcDLHNFr10byTZY9roObiqdsJLMVvb2XliJjAqaPa9AkYwGE6xHw2ispwg64Rse0+AtKups19WIU=",
346
+ "MIIDUzCCAjugAwIBAgIJAKg+LQlirffwMA0GCSqGSIb3DQEBCwUAMFUxCzAJBgNVBAYTAlVTMQswCQYDVQQIEwJDQTEQMA4GA1UEChMHY2VydGlnbzEQMA4GA1UECxMHZXhhbXBsZTEVMBMGA1UEAxMMZXhhbXBsZS1yb290MB4XDTE2MDYxMDIyMTQxMVoXDTIzMDQxNTIyMTQxMVowVTELMAkGA1UEBhMCVVMxCzAJBgNVBAgTAkNBMRAwDgYDVQQKEwdjZXJ0aWdvMRAwDgYDVQQLEwdleGFtcGxlMRUwEwYDVQQDEwxleGFtcGxlLXJvb3QwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQDKOEoSiNjMQ8/zUFcQW89LWw+UeTXKGwNDSpGjyi8jBKZ1lWPbnMmrjI6DZ9ReevHHzqBdKZt+9NFPFEz7djDMRByIuJhRvzhfFBflaIdSeNk2+NpUaFuUUUd6IIePu0AdRveJ8ZGHXRwCeEDIVCZS4oBYPHOhX/zMWDg8vSO4pSxTjGc7I8fHxaUSkVzUBbeO9T/1eFk0m2uxs3UziUck2X/8YqRd+p/EaBED78nXvKRALAguKAzqxIgk3ccPK0SVQFNFq+eV1/qo8coueQuqMpCAvwVkfpVKhneyC2NlMrfzlcZZbfG/irlSjQn5+ExZX4Isy1pCUbOiVfSrsCdtAgMBAAGjJjAkMA4GA1UdDwEB/wQEAwICBDASBgNVHRMBAf8ECDAGAQH/AgEAMA0GCSqGSIb3DQEBCwUAA4IBAQCLEJU65vTU+oLbNHLOCR6fALrbjK7xsi6SFDpSXBMm74MWsy3myDBmXpOcN8hCYgsgivUXTQz9ynXP/pzOj4b83zzlaOfPtLTAmMhKWVV4Q85mrDQz+HzG4lKXM78eTsD8PyrocA/tSE7mVEJ0Jal4E2KI/Z9/fqpYFLB6LFlx5n83ehXM/egA0l4OeCC9nBKCeNUN3sIQO85lljyzAJdtWnsdoWogJs6qjcV8n2U5xjZxN5ZFdclYLjq6g2cjEXXMQxb8b7ZhHjLWFdjHP85UvXHK3DpK3JmUg8bYS7t1DJffDQNjawhlsMycKZN+r0ND0Um4m7AjGqxbKT/M2yKF"
347
+ ],
348
+ "x5t":"BhJU_fcg8sDkvT8zOaL-U1ChXeE",
349
+ "x5t#S256":"IDJKS5LxImjvmuAl_Vx50Vj_dFdACSGW6DU8ADFRdRE"
350
+ }`
262
351
263
352
var jwk2 JSONWebKey
264
- err = jwk2 .UnmarshalJSON (jsonbar )
265
- if err != nil {
266
- t .Fatal ("problem unmarshalling" , err )
267
- }
353
+ err := jwk2 .UnmarshalJSON ([]byte (hexJWK ))
354
+ require .NoError (t , err )
268
355
269
- if ! reflect .DeepEqual (testCertificates , jwk2 .Certificates ) {
270
- t .Error ("Certificates not equal" , jwk .Certificates , jwk2 .Certificates )
271
- }
356
+ js , err := jwk2 .MarshalJSON ()
357
+ require .NoError (t , err )
272
358
273
- jsonbar2 , err := jwk2 .MarshalJSON ()
274
- if err != nil {
275
- t .Error ("problem marshaling" , err )
276
- }
277
- if ! bytes .Equal (jsonbar , jsonbar2 ) {
278
- t .Error ("roundtrip should not lose information" )
279
- }
359
+ var j1 , j2 map [string ]interface {}
360
+ require .NoError (t , json .Unmarshal (js , & j1 ))
361
+ require .NoError (t , json .Unmarshal ([]byte (output ), & j2 ))
362
+ require .Empty (t , cmp .Diff (j1 , j2 ))
280
363
}
281
364
282
365
func TestInvalidThumbprintsX509 (t * testing.T ) {
0 commit comments