From: Milan Cvetkovic Date: Thu, 21 Sep 2023 10:51:30 +0000 (+0000) Subject: Load openid signing key from endpoint during openid connect test X-Git-Tag: live~1100^2 X-Git-Url: https://git.openstreetmap.org./rails.git/commitdiff_plain/408f2918d0d4ebebbb651363a3aa95a0e0eb5a82 Load openid signing key from endpoint during openid connect test --- diff --git a/test/integration/oauth2_test.rb b/test/integration/oauth2_test.rb index 35893e4ab..fd6b42fec 100644 --- a/test/integration/oauth2_test.rb +++ b/test/integration/oauth2_test.rb @@ -91,7 +91,7 @@ class OAuth2Test < ActionDispatch::IntegrationTest id_token = token["id_token"] assert_not_nil id_token - data, _headers = JWT.decode id_token, Doorkeeper::OpenidConnect.signing_key.public_key, true, { + data, _headers = JWT.decode id_token, nil, true, { :algorithm => [Doorkeeper::OpenidConnect.signing_algorithm.to_s], :verify_iss => true, :iss => "#{Settings.server_protocol}://#{Settings.server_url}", @@ -99,7 +99,13 @@ class OAuth2Test < ActionDispatch::IntegrationTest :sub => user.id, :verify_aud => true, :aud => client.uid - } + } do |headers, _payload| + kid = headers["kid"] + get oauth_discovery_keys_path + keys = response.parsed_body["keys"] + jwk = keys&.detect { |e| e["kid"] == kid } + jwk && JWT::JWK::RSA.import(jwk).public_key + end assert_equal user.id.to_s, data["sub"] assert_not data.key?("preferred_username")