BigW Consortium Gitlab

rsa_token_spec.rb 1.56 KB
Newer Older
1
describe JSONWebToken::RSAToken do
2 3 4 5 6 7 8 9 10 11 12 13 14
  let(:rsa_key) do
    OpenSSL::PKey::RSA.new <<-eos.strip_heredoc
      -----BEGIN RSA PRIVATE KEY-----
      MIIBOgIBAAJBAMA5sXIBE0HwgIB40iNidN4PGWzOyLQK0bsdOBNgpEXkDlZBvnak
      OUgAPF+rME4PB0Yl415DabUI40T5UNmlwxcCAwEAAQJAZtY2pSwIFm3JAXIh0cZZ
      iXcAfiJ+YzuqinUOS+eW2sBCAEzjcARlU/o6sFQgtsOi4FOMczAd1Yx8UDMXMmrw
      2QIhAPBgVhJiTF09pdmeFWutCvTJDlFFAQNbrbo2X2x/9WF9AiEAzLgqMKeStSRu
      H9N16TuDrUoO8R+DPqriCwkKrSHaWyMCIFzMhE4inuKcSywBaLmiG4m3GQzs++Al
      A6PRG/PSTpQtAiBxtBg6zdf+JC3GH3zt/dA0/10tL4OF2wORfYQghRzyYQIhAL2l
      0ZQW+yLIZAGrdBFWYEAa52GZosncmzBNlsoTgwE4
      -----END RSA PRIVATE KEY-----
    eos
  end
15 16 17
  let(:rsa_token) { described_class.new(nil) }
  let(:rsa_encoded) { rsa_token.encoded }

18 19 20
  before do
    allow_any_instance_of(described_class).to receive(:key).and_return(rsa_key)
  end
21 22 23

  context 'token' do
    context 'for valid key to be validated' do
24 25 26
      before do
        rsa_token['key'] = 'value'
      end
27 28 29

      subject { JWT.decode(rsa_encoded, rsa_key) }

30
      it { expect{subject}.not_to raise_error }
31
      it { expect(subject.first).to include('key' => 'value') }
32 33 34 35 36 37
      it do
        expect(subject.second).to eq(
          "typ" => "JWT",
          "alg" => "RS256",
          "kid" => "OGXY:4TR7:FAVO:WEM2:XXEW:E4FP:TKL7:7ACK:TZAF:D54P:SUIA:P3B2")
      end
38 39 40
    end

    context 'for invalid key to raise an exception' do
41
      let(:new_key) { OpenSSL::PKey::RSA.generate(512) }
42 43 44 45 46 47
      subject { JWT.decode(rsa_encoded, new_key) }

      it { expect{subject}.to raise_error(JWT::DecodeError) }
    end
  end
end