|
13 | 13 | end |
14 | 14 |
|
15 | 15 | it 'from a JWKS hash with symbol keys' do |
16 | | - jwks = { keys: [{ kty: 'oct', k: 'testkey' }] } |
17 | | - jwk = JWT::JWK.new({ kty: 'oct', k: 'testkey' }) |
| 16 | + jwks = { keys: [{ kty: 'oct', k: Base64.strict_encode64('testkey') }] } |
| 17 | + jwk = JWT::JWK.new({ kty: 'oct', k: Base64.strict_encode64('testkey') }) |
18 | 18 | expect(described_class.new(jwks).keys).to eql([jwk]) |
19 | 19 | end |
20 | 20 |
|
21 | 21 | it 'from a JWKS hash with string keys' do |
22 | | - jwks = { 'keys' => [{ 'kty' => 'oct', 'k' => 'testkey' }] } |
23 | | - jwk = JWT::JWK.new({ kty: 'oct', k: 'testkey' }) |
| 22 | + jwks = { 'keys' => [{ 'kty' => 'oct', 'k' => Base64.strict_encode64('testkey') }] } |
| 23 | + jwk = JWT::JWK.new({ kty: 'oct', k: Base64.strict_encode64('testkey') }) |
24 | 24 | expect(described_class.new(jwks).keys).to eql([jwk]) |
25 | 25 | end |
26 | 26 |
|
|
30 | 30 | end |
31 | 31 |
|
32 | 32 | it 'from an existing JWT::JWK::Set' do |
33 | | - jwk = JWT::JWK.new({ kty: 'oct', k: 'testkey' }) |
| 33 | + jwk = JWT::JWK.new({ kty: 'oct', k: Base64.strict_encode64('testkey') }) |
34 | 34 | jwks = described_class.new(jwk) |
35 | 35 | expect(described_class.new(jwks)).to eql(jwks) |
36 | 36 | end |
|
43 | 43 |
|
44 | 44 | describe '.export' do |
45 | 45 | it 'exports the JWKS to Hash' do |
46 | | - jwk = JWT::JWK.new({ kty: 'oct', k: 'testkey' }) |
| 46 | + jwk = JWT::JWK.new({ kty: 'oct', k: Base64.strict_encode64('testkey') }) |
47 | 47 | jwks = described_class.new(jwk) |
48 | 48 | exported = jwks.export |
49 | 49 | expect(exported[:keys].size).to eql(1) |
|
53 | 53 |
|
54 | 54 | describe '.eql?' do |
55 | 55 | it 'correctly classifies equal sets' do |
56 | | - jwk = JWT::JWK.new({ kty: 'oct', k: 'testkey' }) |
| 56 | + jwk = JWT::JWK.new({ kty: 'oct', k: Base64.strict_encode64('testkey') }) |
57 | 57 | jwks1 = described_class.new(jwk) |
58 | 58 | jwks2 = described_class.new(jwk) |
59 | 59 | expect(jwks1).to eql(jwks2) |
60 | 60 | end |
61 | 61 |
|
62 | 62 | it 'correctly classifies different sets' do |
63 | | - jwk1 = JWT::JWK.new({ kty: 'oct', k: 'testkey' }) |
64 | | - jwk2 = JWT::JWK.new({ kty: 'oct', k: 'testkex' }) |
| 63 | + jwk1 = JWT::JWK.new({ kty: 'oct', k: Base64.strict_encode64('testkey') }) |
| 64 | + jwk2 = JWT::JWK.new({ kty: 'oct', k: Base64.strict_encode64('testkex') }) |
65 | 65 | jwks1 = described_class.new(jwk1) |
66 | 66 | jwks2 = described_class.new(jwk2) |
67 | 67 | expect(jwks1).not_to eql(jwks2) |
|
72 | 72 | # but Array#uniq! doesn't recognize this, despite the documentation saying otherwise |
73 | 73 | describe '.uniq!' do |
74 | 74 | it 'filters out equal keys' do |
75 | | - jwk = JWT::JWK.new({ kty: 'oct', k: 'testkey' }) |
76 | | - jwk2 = JWT::JWK.new({ kty: 'oct', k: 'testkey' }) |
| 75 | + jwk = JWT::JWK.new({ kty: 'oct', k: Base64.strict_encode64('testkey') }) |
| 76 | + jwk2 = JWT::JWK.new({ kty: 'oct', k: Base64.strict_encode64('testkey') }) |
77 | 77 | jwks = described_class.new([jwk, jwk2]) |
78 | 78 | jwks.uniq! |
79 | 79 | expect(jwks.keys.size).to eql(1) |
|
0 commit comments