Test Summary

Test Results

Expand All Collapse All
All times are UTC
2020-07-31 12:28:30 INFO
TEST-RUNNER
Test instance 4t9r4y6qDcdZrko created
baseUrl
https://www.certification.openid.net/test/a/oidf-authlete-core
variant
{
  "client_auth_type": "client_secret_basic",
  "response_type": "code token",
  "server_metadata": "static",
  "response_mode": "form_post",
  "client_registration": "static_client"
}
alias
oidf-authlete-core
description
Authlete plain OIDC client secret basic - static server config
planId
f4s0MatdN55iD
config
{
  "alias": "oidf-authlete-core",
  "description": "Authlete plain OIDC client secret basic - static server config",
  "publish": "everything",
  "server": {
    "issuer": "https://fapidev-as.authlete.net/",
    "jwks_uri": "https://fapidev-as.authlete.net/api/jwks",
    "authorization_endpoint": "https://fapidev-www.authlete.net/api/authorization",
    "token_endpoint": "https://fapidev-as.authlete.net/api/token",
    "userinfo_endpoint": "https://fapidev-rs.authlete.net/api/userinfo",
    "acr_values": "urn:mace:incommon:iap:silver urn:openbanking:psd2:sca urn:openbanking:psd2:ca",
    "login_hint": "john"
  },
  "client": {
    "client_id": "470519824180317",
    "client_secret": "Ek2CiuOrmfdhvsjGl037_pscCmYseks4bzSSxc3UZUcr-9Ki2rlCRdg_Mt-Ukc9b-LpajnMUcwmzqgXs-eDKzw"
  },
  "client_secret_post": {
    "client_id": "469894541303688",
    "client_secret": "SGMsD1U1t0iZXChy0YtbnICAfU9ULEgh5MElWNX6iOq0sWYI0TGiTn-4mRDlhsSOQGfWoZwYWqKAubsbrY7nfA"
  },
  "client2": {
    "client_id": "470553331604632",
    "client_secret": "3NLezSFOjyxuERp_cH3zFMbym9oNur3NMdYIJWimiTHEKROvsDTT1-BVfo8AbLNiUgyIbbGcr79n7fkTL7D8qA"
  },
  "browser": [
    {
      "match": "https://fapidev-www.authlete.net/api/authorization*",
      "tasks": [
        {
          "task": "Initial Login",
          "optional": true,
          "match": "https://fapidev-www.authlete.net/api/authorization*",
          "commands": [
            [
              "text",
              "id",
              "loginId",
              "john",
              "optional"
            ],
            [
              "text",
              "id",
              "password",
              "john",
              "optional"
            ],
            [
              "click",
              "name",
              "authorized"
            ]
          ]
        },
        {
          "task": "Verify Complete",
          "match": "https://*/test/a/oidf-authlete-core/callback*",
          "commands": [
            [
              "wait",
              "id",
              "submission_complete",
              10
            ]
          ]
        }
      ]
    }
  ]
}
testName
oidcc-refresh-token
2020-07-31 12:28:30 SUCCESS
CreateRedirectUri
Created redirect URI
redirect_uri
https://www.certification.openid.net/test/a/oidf-authlete-core/callback
2020-07-31 12:28:30 SUCCESS
GetStaticServerConfiguration
Found a static server object
issuer
https://fapidev-as.authlete.net/
jwks_uri
https://fapidev-as.authlete.net/api/jwks
authorization_endpoint
https://fapidev-www.authlete.net/api/authorization
token_endpoint
https://fapidev-as.authlete.net/api/token
userinfo_endpoint
https://fapidev-rs.authlete.net/api/userinfo
acr_values
urn:mace:incommon:iap:silver urn:openbanking:psd2:sca urn:openbanking:psd2:ca
login_hint
john
2020-07-31 12:28:30 SUCCESS
CheckServerConfiguration
Found required server configuration keys
required
[
  "authorization_endpoint",
  "token_endpoint",
  "issuer"
]
2020-07-31 12:28:30 SUCCESS
ExtractTLSTestValuesFromServerConfiguration
Extracted TLS information from authorization server configuration
registration_endpoint
authorization_endpoint
{
  "testHost": "fapidev-www.authlete.net",
  "testPort": 443
}
token_endpoint
{
  "testHost": "fapidev-as.authlete.net",
  "testPort": 443
}
userinfo_endpoint
{
  "testHost": "fapidev-rs.authlete.net",
  "testPort": 443
}
2020-07-31 12:28:30
FetchServerKeys
Fetching server key
jwks_uri
https://fapidev-as.authlete.net/api/jwks
2020-07-31 12:28:30
FetchServerKeys
HTTP request
request_uri
https://fapidev-as.authlete.net/api/jwks
request_method
GET
request_headers
{
  "accept": "text/plain, application/json, application/cbor, application/*+json, */*",
  "content-length": "0"
}
request_body

                                
2020-07-31 12:28:30 RESPONSE
FetchServerKeys
HTTP response
response_status_code
200 OK
response_status_text
OK
response_headers
{
  "date": "Fri, 31 Jul 2020 12:28:30 GMT",
  "server": "Jetty(9.4.21-SNAPSHOT)",
  "cache-control": "no-store, no-transform",
  "pragma": "no-cache",
  "content-type": "application/json;charset\u003dutf-8",
  "content-length": "472",
  "keep-alive": "timeout\u003d5, max\u003d100",
  "connection": "Keep-Alive"
}
response_body
{
  "keys": [
    {
      "kty": "RSA",
      "e": "AQAB",
      "kid": "authlete-fapidev-api-20180524",
      "n": "nJclr5TJ3Y21Ggt0lz2EO7wWKn6jTaIlMv1sNMy2VmkcSf8EVsFqJ1vSXjFxWvBj7RolFCyaChFwI_jog9c2rAkIwF8Voi5eB3PRjl3OaNRUYILRgLsaclTj02NWMvwbiJ18yJ63D4Ojzif8_RyAHuM3HO2rs6nPEyZMW3Xd0z3Lw099TpIcxA4Ktfo2DliUfMZh9s3lB_f6DSxX5Z9CXqrzNsoCCxqJZ55WuUUNA4LmYl5OgrH8sD7_TvY1QTjjmRzUptgj1S-gwagIjrkn9ooALa8gRN4etKztA2topBn0KO2VwEo_P4iejBn2Z3I2FlQnDNu0t7xNwBhsM2Vg8Q"
    }
  ]
}
2020-07-31 12:28:30
FetchServerKeys
Found JWK set string
jwk_string
{
  "keys": [
    {
      "kty": "RSA",
      "e": "AQAB",
      "kid": "authlete-fapidev-api-20180524",
      "n": "nJclr5TJ3Y21Ggt0lz2EO7wWKn6jTaIlMv1sNMy2VmkcSf8EVsFqJ1vSXjFxWvBj7RolFCyaChFwI_jog9c2rAkIwF8Voi5eB3PRjl3OaNRUYILRgLsaclTj02NWMvwbiJ18yJ63D4Ojzif8_RyAHuM3HO2rs6nPEyZMW3Xd0z3Lw099TpIcxA4Ktfo2DliUfMZh9s3lB_f6DSxX5Z9CXqrzNsoCCxqJZ55WuUUNA4LmYl5OgrH8sD7_TvY1QTjjmRzUptgj1S-gwagIjrkn9ooALa8gRN4etKztA2topBn0KO2VwEo_P4iejBn2Z3I2FlQnDNu0t7xNwBhsM2Vg8Q"
    }
  ]
}
2020-07-31 12:28:30 SUCCESS
FetchServerKeys
Found server JWK set
server_jwks
{
  "keys": [
    {
      "kty": "RSA",
      "e": "AQAB",
      "kid": "authlete-fapidev-api-20180524",
      "n": "nJclr5TJ3Y21Ggt0lz2EO7wWKn6jTaIlMv1sNMy2VmkcSf8EVsFqJ1vSXjFxWvBj7RolFCyaChFwI_jog9c2rAkIwF8Voi5eB3PRjl3OaNRUYILRgLsaclTj02NWMvwbiJ18yJ63D4Ojzif8_RyAHuM3HO2rs6nPEyZMW3Xd0z3Lw099TpIcxA4Ktfo2DliUfMZh9s3lB_f6DSxX5Z9CXqrzNsoCCxqJZ55WuUUNA4LmYl5OgrH8sD7_TvY1QTjjmRzUptgj1S-gwagIjrkn9ooALa8gRN4etKztA2topBn0KO2VwEo_P4iejBn2Z3I2FlQnDNu0t7xNwBhsM2Vg8Q"
    }
  ]
}
2020-07-31 12:28:30 SUCCESS
CheckServerKeysIsValid
Server JWKs is valid
server_jwks
{
  "keys": [
    {
      "kty": "RSA",
      "e": "AQAB",
      "kid": "authlete-fapidev-api-20180524",
      "n": "nJclr5TJ3Y21Ggt0lz2EO7wWKn6jTaIlMv1sNMy2VmkcSf8EVsFqJ1vSXjFxWvBj7RolFCyaChFwI_jog9c2rAkIwF8Voi5eB3PRjl3OaNRUYILRgLsaclTj02NWMvwbiJ18yJ63D4Ojzif8_RyAHuM3HO2rs6nPEyZMW3Xd0z3Lw099TpIcxA4Ktfo2DliUfMZh9s3lB_f6DSxX5Z9CXqrzNsoCCxqJZ55WuUUNA4LmYl5OgrH8sD7_TvY1QTjjmRzUptgj1S-gwagIjrkn9ooALa8gRN4etKztA2topBn0KO2VwEo_P4iejBn2Z3I2FlQnDNu0t7xNwBhsM2Vg8Q"
    }
  ]
}
2020-07-31 12:28:30 SUCCESS
ValidateServerJWKs
Valid server JWKs: keys are valid JSON, contain the required fields and are correctly encoded using unpadded base64url
2020-07-31 12:28:30 SUCCESS
CheckForKeyIdInServerJWKs
All keys contain kids
2020-07-31 12:28:30 SUCCESS
CheckDistinctKeyIdValueInServerJWKs
Distinct 'kid' value in all keys of server_jwks
see
https://bitbucket.org/openid/connect/issues/1127
2020-07-31 12:28:30 SUCCESS
EnsureServerJwksDoesNotContainPrivateOrSymmetricKeys
Jwks does not contain any private or symmetric keys
2020-07-31 12:28:30 SUCCESS
GetStaticClientConfiguration
Found a static client object
client_id
470519824180317
client_secret
Ek2CiuOrmfdhvsjGl037_pscCmYseks4bzSSxc3UZUcr-9Ki2rlCRdg_Mt-Ukc9b-LpajnMUcwmzqgXs-eDKzw
2020-07-31 12:28:30
SetScopeInClientConfigurationToOpenIdOfflineAccess
Set scope in client configuration to "openid offline_access" so that a refresh token is issued
scope
openid offline_access
2020-07-31 12:28:30 SUCCESS
GetStaticClient2Configuration
Found a static second client object
client_id
470553331604632
client_secret
3NLezSFOjyxuERp_cH3zFMbym9oNur3NMdYIJWimiTHEKROvsDTT1-BVfo8AbLNiUgyIbbGcr79n7fkTL7D8qA
2020-07-31 12:28:30
SetScopeInClientConfigurationToOpenIdOfflineAccess
Set scope in client configuration to "openid offline_access" so that a refresh token is issued
scope
openid offline_access
2020-07-31 12:28:30 SUCCESS
SetProtectedResourceUrlToUserInfoEndpoint
userinfo_endpoint will be used to test access token. The user info is not a mandatory to implement feature in the OpenID Connect specification, but is mandatory for certification.
protected_resource_url
https://fapidev-rs.authlete.net/api/userinfo
2020-07-31 12:28:30
oidcc-refresh-token
Setup Done
Make request to authorization endpoint
2020-07-31 12:28:30 SUCCESS
CreateAuthorizationEndpointRequestFromClientInformation
Created authorization endpoint request
client_id
470519824180317
redirect_uri
https://www.certification.openid.net/test/a/oidf-authlete-core/callback
scope
openid offline_access
2020-07-31 12:28:30
CreateRandomStateValue
Created state value
requested_state_length
10
state
YnMthCLQnO
2020-07-31 12:28:30 SUCCESS
AddStateToAuthorizationEndpointRequest
Added state parameter to request
client_id
470519824180317
redirect_uri
https://www.certification.openid.net/test/a/oidf-authlete-core/callback
scope
openid offline_access
state
YnMthCLQnO
2020-07-31 12:28:30
CreateRandomNonceValue
Created nonce value
requested_nonce_length
10
nonce
1qqan2g8HM
2020-07-31 12:28:30 SUCCESS
AddNonceToAuthorizationEndpointRequest
Added nonce parameter to request
client_id
470519824180317
redirect_uri
https://www.certification.openid.net/test/a/oidf-authlete-core/callback
scope
openid offline_access
state
YnMthCLQnO
nonce
1qqan2g8HM
2020-07-31 12:28:30 SUCCESS
SetAuthorizationEndpointRequestResponseTypeFromEnvironment
Added response_type parameter to request
client_id
470519824180317
redirect_uri
https://www.certification.openid.net/test/a/oidf-authlete-core/callback
scope
openid offline_access
state
YnMthCLQnO
nonce
1qqan2g8HM
response_type
code token
2020-07-31 12:28:30
SetAuthorizationEndpointRequestResponseModeToFormPost
Added response_mode parameter to request
client_id
470519824180317
redirect_uri
https://www.certification.openid.net/test/a/oidf-authlete-core/callback
scope
openid offline_access
state
YnMthCLQnO
nonce
1qqan2g8HM
response_type
code token
response_mode
form_post
2020-07-31 12:28:30 SUCCESS
AddPromptConsentToAuthorizationEndpointRequestIfScopeContainsOfflineAccess
Added prompt=consent to authorization endpoint request
client_id
470519824180317
redirect_uri
https://www.certification.openid.net/test/a/oidf-authlete-core/callback
scope
openid offline_access
state
YnMthCLQnO
nonce
1qqan2g8HM
response_type
code token
response_mode
form_post
prompt
consent
2020-07-31 12:28:30 SUCCESS
BuildPlainRedirectToAuthorizationEndpoint
Sending to authorization endpoint
redirect_to_authorization_endpoint
https://fapidev-www.authlete.net/api/authorization?client_id=470519824180317&redirect_uri=https://www.certification.openid.net/test/a/oidf-authlete-core/callback&scope=openid%20offline_access&state=YnMthCLQnO&nonce=1qqan2g8HM&response_type=code%20token&response_mode=form_post&prompt=consent
2020-07-31 12:28:30 REDIRECT
oidcc-refresh-token
Redirecting to authorization endpoint
redirect_to
https://fapidev-www.authlete.net/api/authorization?client_id=470519824180317&redirect_uri=https://www.certification.openid.net/test/a/oidf-authlete-core/callback&scope=openid%20offline_access&state=YnMthCLQnO&nonce=1qqan2g8HM&response_type=code%20token&response_mode=form_post&prompt=consent
2020-07-31 12:28:30
WebRunner
Scripted browser HTTP request
browser
goToUrl
request_method
GET
request_uri
https://fapidev-www.authlete.net/api/authorization?client_id=470519824180317&redirect_uri=https://www.certification.openid.net/test/a/oidf-authlete-core/callback&scope=openid%20offline_access&state=YnMthCLQnO&nonce=1qqan2g8HM&response_type=code%20token&response_mode=form_post&prompt=consent
2020-07-31 12:28:31 RESPONSE
WebRunner
Scripted browser HTTP response
response_content
<!doctype html>
<!---->
<!--




-->
<html>
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, minimum-scale=1.0, initial-scale=1.0, user-scalable=yes">
  <title>FAPI Test Service | Authorization</title>
  <link rel="stylesheet" href="/css/authorization.css">
  <!--  //-->
</head>
<body class="font-default">
  <div id="page_title">FAPI Test Service</div>

  <div id="content">
    <h3 id="client-name">core conformance client secret basic</h3>
    <div class="indent">
      <img id="logo" src="https://button.heenan.me.uk/~joseph/authlete-150x150.png" alt="[Logo] (150x150)">

      <div id="client-summary">
        <p>core conformance client secret basic</p>
        <ul id="client-link-list">
          

          

          
        </ul>
      </div>

      <div style="clear: both;"></div>
    </div>

    
    <h4 id="permissions">Permissions</h4>
    <div class="indent">
      <p>The application is requesting the following permissions.</p>

      <dl id="scope-list">
        
        <dt>offline_access</dt>
        <dd>A permission to request a refresh token exchangeable with an access token which can access the UserInfo Endpoint even when the end-user is offline. See OpenID Connect Core 1.0, 11. for details.</dd>
        
        <dt>openid</dt>
        <dd>A permission to request an OpenID Provider to issue an ID Token. See OpenID Connect Core 1.0, 3.1.2.1. for details.</dd>
        
      </dl>
    </div>
    

    

    

    <h4 id="authorization">Authorization</h4>
    <div class="indent">
      <p>Do you grant authorization to the application?</p>

      <form id="authorization-form" action="/api/authorization/decision" method="POST">
        
        <div id="login-fields" class="indent">
          <div id="login-prompt">Input Login ID and password.</div>
          <input type="text" id="loginId" name="loginId" placeholder="Login ID"
                 autocomplete="off" autocorrect="off" autocapitalize="off" spellcheck="false"
                 class="font-default" required value="" >
          <input type="password" id="password" name="password" placeholder="Password"
                 class="font-default" required>
        </div>
        
        
        <div id="authorization-form-buttons">
          <input type="submit" name="authorized" id="authorize-button" value="Authorize" class="font-default"/>
          <input type="submit" name="denied"     id="deny-button"      value="Deny"      class="font-default"/>
        </div>
      </form>
    </div>
  </div>

</body>
</html>
response_content_type
*/*
response_status_text
200-OK
response_status_code
200
2020-07-31 12:28:31 INFO
WebRunner
Entering text
task
Initial Login
browser
text
element_type
id
value
john
url
https://fapidev-www.authlete.net/api/authorization?client_id=470519824180317&redirect_uri=https://www.certification.openid.net/test/a/oidf-authlete-core/callback&scope=openid%20offline_access&state=YnMthCLQnO&nonce=1qqan2g8HM&response_type=code%20token&response_mode=form_post&prompt=consent
target
loginId
2020-07-31 12:28:31 INFO
WebRunner
Entering text
task
Initial Login
browser
text
element_type
id
value
john
url
https://fapidev-www.authlete.net/api/authorization?client_id=470519824180317&redirect_uri=https://www.certification.openid.net/test/a/oidf-authlete-core/callback&scope=openid%20offline_access&state=YnMthCLQnO&nonce=1qqan2g8HM&response_type=code%20token&response_mode=form_post&prompt=consent
target
password
2020-07-31 12:28:31 INFO
WebRunner
Clicking an element
task
Initial Login
browser
click
element_type
name
url
https://fapidev-www.authlete.net/api/authorization?client_id=470519824180317&redirect_uri=https://www.certification.openid.net/test/a/oidf-authlete-core/callback&scope=openid%20offline_access&state=YnMthCLQnO&nonce=1qqan2g8HM&response_type=code%20token&response_mode=form_post&prompt=consent
target
authorized
2020-07-31 12:28:31 INCOMING
oidcc-refresh-token
Incoming HTTP request to test instance 4t9r4y6qDcdZrko
incoming_headers
{
  "host": "www.certification.openid.net",
  "upgrade-insecure-requests": "1",
  "user-agent": "Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/63.0.3239.108 Safari/537.36",
  "accept": "text/html,application/xhtml+xml,application/xml;q\u003d0.9,image/webp,image/apng,*/*;q\u003d0.8",
  "referer": "https://fapidev-www.authlete.net/api/authorization/decision",
  "accept-encoding": "gzip, deflate",
  "accept-language": "en-US",
  "origin": "https://fapidev-www.authlete.net/api/authorization/decision",
  "cache-control": "max-age\u003d0",
  "content-type": "application/x-www-form-urlencoded",
  "x-ssl-cipher": "ECDHE-RSA-AES256-GCM-SHA384",
  "x-ssl-protocol": "TLSv1.2",
  "content-length": "848",
  "x-forwarded-host": "www.certification.openid.net",
  "x-forwarded-server": "www.certification.openid.net",
  "connection": "close"
}
incoming_path
callback
incoming_body_form_params
{
  "state": "YnMthCLQnO",
  "code": "j3_yhp0w1U7tmPWbS7FUcvVjb8toJNgdGWeRPiM_2Ps",
  "access_token": "eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDkxMSwiaWF0IjoxNTk2MTk4NTExLCJjbGllbnRfaWQiOiI0NzA1MTk4MjQxODAzMTciLCJqdGkiOiJ4RWlsajRnWUNXd3pOLXlqR21Rd2FKYVFQTkVxVTZlX3FsWVdKa2trRFY0In0.hYvMZLEOa4LpDzTiaRDf8Q4iUd4IFWf5_6EZDoTLDHAeT1Y5CTlkrq2MoESoKlatLATLuli1xtwpTn-I00YZknYkqsYPm7urN7mKAlmPfNXcmr4NUcOrXZfA3CKvkf9hLTisZnTkh-2iDIqVyyqorhl0Nt2eTxFDZKdyemeFEJ9Qc1LklU46zE_lU8N3WKqOCv5MFNqViBCv8DkW-NiZAKU_uZzTB2_dlGIPgszmxHyHMj_h2ADGJ689QziPxImCa-Npf9mIt217JudGMsmNdyKP7d3TV1egGeNH6KfpWiqg-J8TqQarbL3zZq_BWYI395tl-_vszUqL6K0fcEKN6w",
  "token_type": "Bearer",
  "expires_in": "86400",
  "scope": "offline_access openid"
}
incoming_method
POST
incoming_body_json
incoming_query_string_params
{}
incoming_body
state=YnMthCLQnO&code=j3_yhp0w1U7tmPWbS7FUcvVjb8toJNgdGWeRPiM_2Ps&access_token=eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDkxMSwiaWF0IjoxNTk2MTk4NTExLCJjbGllbnRfaWQiOiI0NzA1MTk4MjQxODAzMTciLCJqdGkiOiJ4RWlsajRnWUNXd3pOLXlqR21Rd2FKYVFQTkVxVTZlX3FsWVdKa2trRFY0In0.hYvMZLEOa4LpDzTiaRDf8Q4iUd4IFWf5_6EZDoTLDHAeT1Y5CTlkrq2MoESoKlatLATLuli1xtwpTn-I00YZknYkqsYPm7urN7mKAlmPfNXcmr4NUcOrXZfA3CKvkf9hLTisZnTkh-2iDIqVyyqorhl0Nt2eTxFDZKdyemeFEJ9Qc1LklU46zE_lU8N3WKqOCv5MFNqViBCv8DkW-NiZAKU_uZzTB2_dlGIPgszmxHyHMj_h2ADGJ689QziPxImCa-Npf9mIt217JudGMsmNdyKP7d3TV1egGeNH6KfpWiqg-J8TqQarbL3zZq_BWYI395tl-_vszUqL6K0fcEKN6w&token_type=Bearer&expires_in=86400&scope=offline_access+openid
2020-07-31 12:28:31 SUCCESS
CreateRandomImplicitSubmitUrl
Created random implicit submission URL
implicit_submit
{
  "path": "implicit/AJMYxKJPNV2rZUdSRrG7",
  "fullUrl": "https://www.certification.openid.net/test/a/oidf-authlete-core/implicit/AJMYxKJPNV2rZUdSRrG7"
}
2020-07-31 12:28:31 OUTGOING
oidcc-refresh-token
Response to HTTP request to test instance 4t9r4y6qDcdZrko
outgoing
ModelAndView [view="implicitCallback"; model={implicitSubmitUrl=https://www.certification.openid.net/test/a/oidf-authlete-core/implicit/AJMYxKJPNV2rZUdSRrG7, returnUrl=/log-detail.html?log=4t9r4y6qDcdZrko}]
outgoing_path
callback
2020-07-31 12:28:32 INFO
WebRunner
Completed processing of webpage
task
Initial Login
browser
complete
response_status_text
200-
match
https://fapidev-www.authlete.net/api/authorization*
url
https://www.certification.openid.net/test/a/oidf-authlete-core/callback
response_status_code
200
2020-07-31 12:28:32 INFO
WebRunner
Waiting
regexp
seconds
10
task
Verify Complete
browser
wait
action
element_type
id
url
https://www.certification.openid.net/test/a/oidf-authlete-core/callback
target
submission_complete
2020-07-31 12:28:32 INCOMING
oidcc-refresh-token
Incoming HTTP request to test instance 4t9r4y6qDcdZrko
incoming_headers
{
  "host": "www.certification.openid.net",
  "upgrade-insecure-requests": "1",
  "user-agent": "Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/63.0.3239.108 Safari/537.36",
  "accept": "*/*",
  "referer": "https://www.certification.openid.net/test/a/oidf-authlete-core/callback",
  "accept-encoding": "gzip, deflate",
  "accept-language": "en-US",
  "cookie": "JSESSIONID\u003d1E93F318D58E4AE6274302F5B9BDD229",
  "x-requested-with": "XMLHttpRequest",
  "content-type": "text/plain",
  "x-ssl-cipher": "ECDHE-RSA-AES256-GCM-SHA384",
  "x-ssl-protocol": "TLSv1.2",
  "content-length": "0",
  "x-forwarded-host": "www.certification.openid.net",
  "x-forwarded-server": "www.certification.openid.net",
  "connection": "close"
}
incoming_path
implicit/AJMYxKJPNV2rZUdSRrG7
incoming_body_form_params
incoming_method
POST
incoming_body_json
incoming_query_string_params
{}
incoming_body
2020-07-31 12:28:32 OUTGOING
oidcc-refresh-token
Response to HTTP request to test instance 4t9r4y6qDcdZrko
outgoing
org.springframework.web.servlet.view.RedirectView: [RedirectView]; URL [/log-detail.html?log=4t9r4y6qDcdZrko]
outgoing_path
implicit/AJMYxKJPNV2rZUdSRrG7
2020-07-31 12:28:32 SUCCESS
ExtractImplicitHashToCallbackResponse
implicit_hash is empty
2020-07-31 12:28:32 REDIRECT-IN
oidcc-refresh-token
Authorization endpoint response captured
url_query
{}
headers
{
  "host": "www.certification.openid.net",
  "upgrade-insecure-requests": "1",
  "user-agent": "Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/63.0.3239.108 Safari/537.36",
  "accept": "text/html,application/xhtml+xml,application/xml;q\u003d0.9,image/webp,image/apng,*/*;q\u003d0.8",
  "referer": "https://fapidev-www.authlete.net/api/authorization/decision",
  "accept-encoding": "gzip, deflate",
  "accept-language": "en-US",
  "origin": "https://fapidev-www.authlete.net/api/authorization/decision",
  "cache-control": "max-age\u003d0",
  "content-type": "application/x-www-form-urlencoded",
  "x-ssl-cipher": "ECDHE-RSA-AES256-GCM-SHA384",
  "x-ssl-protocol": "TLSv1.2",
  "content-length": "848",
  "x-forwarded-host": "www.certification.openid.net",
  "x-forwarded-server": "www.certification.openid.net",
  "connection": "close"
}
http_method
POST
url_fragment
{}
post_body
{
  "state": "YnMthCLQnO",
  "code": "j3_yhp0w1U7tmPWbS7FUcvVjb8toJNgdGWeRPiM_2Ps",
  "access_token": "eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDkxMSwiaWF0IjoxNTk2MTk4NTExLCJjbGllbnRfaWQiOiI0NzA1MTk4MjQxODAzMTciLCJqdGkiOiJ4RWlsajRnWUNXd3pOLXlqR21Rd2FKYVFQTkVxVTZlX3FsWVdKa2trRFY0In0.hYvMZLEOa4LpDzTiaRDf8Q4iUd4IFWf5_6EZDoTLDHAeT1Y5CTlkrq2MoESoKlatLATLuli1xtwpTn-I00YZknYkqsYPm7urN7mKAlmPfNXcmr4NUcOrXZfA3CKvkf9hLTisZnTkh-2iDIqVyyqorhl0Nt2eTxFDZKdyemeFEJ9Qc1LklU46zE_lU8N3WKqOCv5MFNqViBCv8DkW-NiZAKU_uZzTB2_dlGIPgszmxHyHMj_h2ADGJ689QziPxImCa-Npf9mIt217JudGMsmNdyKP7d3TV1egGeNH6KfpWiqg-J8TqQarbL3zZq_BWYI395tl-_vszUqL6K0fcEKN6w",
  "token_type": "Bearer",
  "expires_in": "86400",
  "scope": "offline_access openid"
}
Verify authorization endpoint response
2020-07-31 12:28:32 SUCCESS
CheckCallbackHttpMethodIsPost
HTTP method used at redirect_uri is 'POST'
2020-07-31 12:28:32 SUCCESS
CheckCallbackContentTypeIsFormUrlEncoded
content-type header to redirect_uri has the expected value
content_type
application/x-www-form-urlencoded
expected
application/x-www-form-urlencoded
2020-07-31 12:28:32 SUCCESS
RejectAuthCodeInUrlQuery
Authorization code is not present in URL query returned from authorization endpoint
2020-07-31 12:28:32 SUCCESS
RejectErrorInUrlQuery
'error' is not present in URL query returned from authorization endpoint
2020-07-31 12:28:32 SUCCESS
CheckMatchingCallbackParameters
Callback parameters successfully verified
2020-07-31 12:28:32 SUCCESS
CheckIfAuthorizationEndpointError
No error from authorization endpoint
2020-07-31 12:28:32 SUCCESS
CheckMatchingStateParameter
State parameter correctly returned
state
YnMthCLQnO
2020-07-31 12:28:32 SUCCESS
ExtractAuthorizationCodeFromAuthorizationResponse
Found authorization code
code
j3_yhp0w1U7tmPWbS7FUcvVjb8toJNgdGWeRPiM_2Ps
2020-07-31 12:28:32 SUCCESS
ExtractAccessTokenFromAuthorizationResponse
Extracted the access token
value
eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDkxMSwiaWF0IjoxNTk2MTk4NTExLCJjbGllbnRfaWQiOiI0NzA1MTk4MjQxODAzMTciLCJqdGkiOiJ4RWlsajRnWUNXd3pOLXlqR21Rd2FKYVFQTkVxVTZlX3FsWVdKa2trRFY0In0.hYvMZLEOa4LpDzTiaRDf8Q4iUd4IFWf5_6EZDoTLDHAeT1Y5CTlkrq2MoESoKlatLATLuli1xtwpTn-I00YZknYkqsYPm7urN7mKAlmPfNXcmr4NUcOrXZfA3CKvkf9hLTisZnTkh-2iDIqVyyqorhl0Nt2eTxFDZKdyemeFEJ9Qc1LklU46zE_lU8N3WKqOCv5MFNqViBCv8DkW-NiZAKU_uZzTB2_dlGIPgszmxHyHMj_h2ADGJ689QziPxImCa-Npf9mIt217JudGMsmNdyKP7d3TV1egGeNH6KfpWiqg-J8TqQarbL3zZq_BWYI395tl-_vszUqL6K0fcEKN6w
type
Bearer
Userinfo endpoint tests
2020-07-31 12:28:32
CallProtectedResourceWithBearerToken
HTTP request
request_uri
https://fapidev-rs.authlete.net/api/userinfo
request_method
GET
request_headers
{
  "accept": "application/json;charset\u003dUTF-8",
  "authorization": "Bearer eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDkxMSwiaWF0IjoxNTk2MTk4NTExLCJjbGllbnRfaWQiOiI0NzA1MTk4MjQxODAzMTciLCJqdGkiOiJ4RWlsajRnWUNXd3pOLXlqR21Rd2FKYVFQTkVxVTZlX3FsWVdKa2trRFY0In0.hYvMZLEOa4LpDzTiaRDf8Q4iUd4IFWf5_6EZDoTLDHAeT1Y5CTlkrq2MoESoKlatLATLuli1xtwpTn-I00YZknYkqsYPm7urN7mKAlmPfNXcmr4NUcOrXZfA3CKvkf9hLTisZnTkh-2iDIqVyyqorhl0Nt2eTxFDZKdyemeFEJ9Qc1LklU46zE_lU8N3WKqOCv5MFNqViBCv8DkW-NiZAKU_uZzTB2_dlGIPgszmxHyHMj_h2ADGJ689QziPxImCa-Npf9mIt217JudGMsmNdyKP7d3TV1egGeNH6KfpWiqg-J8TqQarbL3zZq_BWYI395tl-_vszUqL6K0fcEKN6w",
  "accept-charset": "utf-8",
  "content-length": "0"
}
request_body

                                
2020-07-31 12:28:32 INFO
WebRunner
Completed processing of webpage
task
Verify Complete
browser
complete
response_status_text
200-
match
https://*/test/a/oidf-authlete-core/callback*
url
https://www.certification.openid.net/test/a/oidf-authlete-core/callback
response_status_code
200
2020-07-31 12:28:32 RESPONSE
CallProtectedResourceWithBearerToken
HTTP response
response_status_code
200 OK
response_status_text
OK
response_headers
{
  "date": "Fri, 31 Jul 2020 12:28:32 GMT",
  "server": "Jetty(9.4.21-SNAPSHOT)",
  "cache-control": "no-store, no-transform",
  "pragma": "no-cache",
  "content-type": "application/json;charset\u003dutf-8",
  "content-length": "14",
  "keep-alive": "timeout\u003d5, max\u003d100",
  "connection": "Keep-Alive"
}
response_body
{"sub":"1001"}
2020-07-31 12:28:32 SUCCESS
CallProtectedResourceWithBearerToken
Got a response from the resource endpoint
headers
{
  "date": "Fri, 31 Jul 2020 12:28:32 GMT",
  "server": "Jetty(9.4.21-SNAPSHOT)",
  "cache-control": "no-store, no-transform",
  "pragma": "no-cache",
  "content-type": "application/json;charset\u003dutf-8",
  "content-length": "14",
  "keep-alive": "timeout\u003d5, max\u003d100",
  "connection": "Keep-Alive"
}
status_code
{
  "code": 200
}
body
{"sub":"1001"}
2020-07-31 12:28:32 SUCCESS
CreateTokenEndpointRequestForAuthorizationCodeGrant
grant_type
authorization_code
code
j3_yhp0w1U7tmPWbS7FUcvVjb8toJNgdGWeRPiM_2Ps
redirect_uri
https://www.certification.openid.net/test/a/oidf-authlete-core/callback
2020-07-31 12:28:32 SUCCESS
AddBasicAuthClientSecretAuthenticationParameters
Added basic authorization header
Authorization
Basic NDcwNTE5ODI0MTgwMzE3OkVrMkNpdU9ybWZkaHZzakdsMDM3X3BzY0NtWXNla3M0YnpTU3hjM1VaVWNyLTlLaTJybENSZGdfTXQtVWtjOWItTHBham5NVWN3bXpxZ1hzLWVES3p3
2020-07-31 12:28:32
CallTokenEndpoint
HTTP request
request_uri
https://fapidev-as.authlete.net/api/token
request_method
POST
request_headers
{
  "accept": "application/json;charset\u003dUTF-8",
  "authorization": "Basic NDcwNTE5ODI0MTgwMzE3OkVrMkNpdU9ybWZkaHZzakdsMDM3X3BzY0NtWXNla3M0YnpTU3hjM1VaVWNyLTlLaTJybENSZGdfTXQtVWtjOWItTHBham5NVWN3bXpxZ1hzLWVES3p3",
  "accept-charset": "utf-8",
  "content-type": "application/x-www-form-urlencoded;charset\u003dUTF-8",
  "content-length": "177"
}
request_body
grant_type=authorization_code&code=j3_yhp0w1U7tmPWbS7FUcvVjb8toJNgdGWeRPiM_2Ps&redirect_uri=https%3A%2F%2Fwww.certification.openid.net%2Ftest%2Fa%2Foidf-authlete-core%2Fcallback
2020-07-31 12:28:32 RESPONSE
CallTokenEndpoint
HTTP response
response_status_code
200 OK
response_status_text
OK
response_headers
{
  "date": "Fri, 31 Jul 2020 12:28:32 GMT",
  "server": "Jetty(9.4.21-SNAPSHOT)",
  "cache-control": "no-store, no-transform",
  "pragma": "no-cache",
  "content-type": "application/json;charset\u003dutf-8",
  "content-length": "1547",
  "keep-alive": "timeout\u003d5, max\u003d100",
  "connection": "Keep-Alive"
}
response_body
{"access_token":"eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDkxMiwiaWF0IjoxNTk2MTk4NTEyLCJjbGllbnRfaWQiOiI0NzA1MTk4MjQxODAzMTciLCJqdGkiOiJWTDh0bW50SzJqbEQxN0c0WmljSjdqS05Xb09qbm1PVXNwS1lZaVJuYTlvIn0.LwgU_wAjoW9vLYh1y5NExjvwFYmxdBZOFOiETZfELmcgjAD7nt66OQDfXMyiYlGIv37OKNr49exeb1mH3XEcpHmmz-BFTO_uen6gUdPckSPF5tJDdwc51r-RwQh6WSVuRemJdckNvyJKtY9F_MZ5QKUW3lrLG-Km7rBmyHpRAs5Uc1RizZOwIn_vXKhxlxV_XcpGKZpkT790im2c-QbFgL_6OpvHG9EUtf88dFcGXEk6xXbKIotqe7jeI9STH12r8wdrDDJGYoQbbKR_cqdTd-benX8d2vtT1Yxuq-mGCkGxPvb56dmqB5-l5fiRj2irmZxKaKTWPFLyf3dJyYYqEQ","refresh_token":"pmSZFdQ7YtQfV-GxBK3aAZLm_8-3YXnj8atLFMWQhgI","scope":"offline_access openid","id_token":"eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDUxOTgyNDE4MDMxNyJdLCJzX2hhc2giOiJKQTNIRzN2NXpxOGpwTnhJa1Qxal9BIiwiYXV0aF90aW1lIjoxNTk2MTk4NTExLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODgxMiwiaWF0IjoxNTk2MTk4NTEyLCJub25jZSI6IjFxcWFuMmc4SE0ifQ.EjmVHUPoPi3xP5h2x9ae3t3wCGMwtLFmhKafFQRRZpPyKxa2ikow558mOktLsqqDNpjgz4HcJ5_4bPFcVMoRntIY1vsdIYZ6OVDCnhno1IC3bQ-IwIhoJUl8SfywEc38RDL4JmpsZ1HuT4yZfljp-_9xHve-t7Um5Y18MbhHkN2KWA64KE7mr1u9DbZrM3LuUxBZxuYaavji1RG-V55YYJ78saoe0eVAA96JkTXQjDW1PavcHiOGdLMS-9vLRm41PkAMxrFFF1o0UzdsPXlJY08AQRn0hiB00mSht9NPGUqok2IiKBojktppydFHGaI3uiPTnZZaYiwgqces6AGoOw","token_type":"Bearer","expires_in":86400}
2020-07-31 12:28:32
CallTokenEndpoint
Token endpoint response
token_endpoint_response
{"access_token":"eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDkxMiwiaWF0IjoxNTk2MTk4NTEyLCJjbGllbnRfaWQiOiI0NzA1MTk4MjQxODAzMTciLCJqdGkiOiJWTDh0bW50SzJqbEQxN0c0WmljSjdqS05Xb09qbm1PVXNwS1lZaVJuYTlvIn0.LwgU_wAjoW9vLYh1y5NExjvwFYmxdBZOFOiETZfELmcgjAD7nt66OQDfXMyiYlGIv37OKNr49exeb1mH3XEcpHmmz-BFTO_uen6gUdPckSPF5tJDdwc51r-RwQh6WSVuRemJdckNvyJKtY9F_MZ5QKUW3lrLG-Km7rBmyHpRAs5Uc1RizZOwIn_vXKhxlxV_XcpGKZpkT790im2c-QbFgL_6OpvHG9EUtf88dFcGXEk6xXbKIotqe7jeI9STH12r8wdrDDJGYoQbbKR_cqdTd-benX8d2vtT1Yxuq-mGCkGxPvb56dmqB5-l5fiRj2irmZxKaKTWPFLyf3dJyYYqEQ","refresh_token":"pmSZFdQ7YtQfV-GxBK3aAZLm_8-3YXnj8atLFMWQhgI","scope":"offline_access openid","id_token":"eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDUxOTgyNDE4MDMxNyJdLCJzX2hhc2giOiJKQTNIRzN2NXpxOGpwTnhJa1Qxal9BIiwiYXV0aF90aW1lIjoxNTk2MTk4NTExLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODgxMiwiaWF0IjoxNTk2MTk4NTEyLCJub25jZSI6IjFxcWFuMmc4SE0ifQ.EjmVHUPoPi3xP5h2x9ae3t3wCGMwtLFmhKafFQRRZpPyKxa2ikow558mOktLsqqDNpjgz4HcJ5_4bPFcVMoRntIY1vsdIYZ6OVDCnhno1IC3bQ-IwIhoJUl8SfywEc38RDL4JmpsZ1HuT4yZfljp-_9xHve-t7Um5Y18MbhHkN2KWA64KE7mr1u9DbZrM3LuUxBZxuYaavji1RG-V55YYJ78saoe0eVAA96JkTXQjDW1PavcHiOGdLMS-9vLRm41PkAMxrFFF1o0UzdsPXlJY08AQRn0hiB00mSht9NPGUqok2IiKBojktppydFHGaI3uiPTnZZaYiwgqces6AGoOw","token_type":"Bearer","expires_in":86400}
2020-07-31 12:28:32 SUCCESS
CallTokenEndpoint
Parsed token endpoint response
access_token
eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDkxMiwiaWF0IjoxNTk2MTk4NTEyLCJjbGllbnRfaWQiOiI0NzA1MTk4MjQxODAzMTciLCJqdGkiOiJWTDh0bW50SzJqbEQxN0c0WmljSjdqS05Xb09qbm1PVXNwS1lZaVJuYTlvIn0.LwgU_wAjoW9vLYh1y5NExjvwFYmxdBZOFOiETZfELmcgjAD7nt66OQDfXMyiYlGIv37OKNr49exeb1mH3XEcpHmmz-BFTO_uen6gUdPckSPF5tJDdwc51r-RwQh6WSVuRemJdckNvyJKtY9F_MZ5QKUW3lrLG-Km7rBmyHpRAs5Uc1RizZOwIn_vXKhxlxV_XcpGKZpkT790im2c-QbFgL_6OpvHG9EUtf88dFcGXEk6xXbKIotqe7jeI9STH12r8wdrDDJGYoQbbKR_cqdTd-benX8d2vtT1Yxuq-mGCkGxPvb56dmqB5-l5fiRj2irmZxKaKTWPFLyf3dJyYYqEQ
refresh_token
pmSZFdQ7YtQfV-GxBK3aAZLm_8-3YXnj8atLFMWQhgI
scope
offline_access openid
id_token
eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDUxOTgyNDE4MDMxNyJdLCJzX2hhc2giOiJKQTNIRzN2NXpxOGpwTnhJa1Qxal9BIiwiYXV0aF90aW1lIjoxNTk2MTk4NTExLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODgxMiwiaWF0IjoxNTk2MTk4NTEyLCJub25jZSI6IjFxcWFuMmc4SE0ifQ.EjmVHUPoPi3xP5h2x9ae3t3wCGMwtLFmhKafFQRRZpPyKxa2ikow558mOktLsqqDNpjgz4HcJ5_4bPFcVMoRntIY1vsdIYZ6OVDCnhno1IC3bQ-IwIhoJUl8SfywEc38RDL4JmpsZ1HuT4yZfljp-_9xHve-t7Um5Y18MbhHkN2KWA64KE7mr1u9DbZrM3LuUxBZxuYaavji1RG-V55YYJ78saoe0eVAA96JkTXQjDW1PavcHiOGdLMS-9vLRm41PkAMxrFFF1o0UzdsPXlJY08AQRn0hiB00mSht9NPGUqok2IiKBojktppydFHGaI3uiPTnZZaYiwgqces6AGoOw
token_type
Bearer
expires_in
86400
2020-07-31 12:28:32 SUCCESS
CheckIfTokenEndpointResponseError
No error from token endpoint
2020-07-31 12:28:32 SUCCESS
CheckForAccessTokenValue
Found an access token
access_token
eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDkxMiwiaWF0IjoxNTk2MTk4NTEyLCJjbGllbnRfaWQiOiI0NzA1MTk4MjQxODAzMTciLCJqdGkiOiJWTDh0bW50SzJqbEQxN0c0WmljSjdqS05Xb09qbm1PVXNwS1lZaVJuYTlvIn0.LwgU_wAjoW9vLYh1y5NExjvwFYmxdBZOFOiETZfELmcgjAD7nt66OQDfXMyiYlGIv37OKNr49exeb1mH3XEcpHmmz-BFTO_uen6gUdPckSPF5tJDdwc51r-RwQh6WSVuRemJdckNvyJKtY9F_MZ5QKUW3lrLG-Km7rBmyHpRAs5Uc1RizZOwIn_vXKhxlxV_XcpGKZpkT790im2c-QbFgL_6OpvHG9EUtf88dFcGXEk6xXbKIotqe7jeI9STH12r8wdrDDJGYoQbbKR_cqdTd-benX8d2vtT1Yxuq-mGCkGxPvb56dmqB5-l5fiRj2irmZxKaKTWPFLyf3dJyYYqEQ
2020-07-31 12:28:32 SUCCESS
ExtractAccessTokenFromTokenResponse
Extracted the access token
value
eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDkxMiwiaWF0IjoxNTk2MTk4NTEyLCJjbGllbnRfaWQiOiI0NzA1MTk4MjQxODAzMTciLCJqdGkiOiJWTDh0bW50SzJqbEQxN0c0WmljSjdqS05Xb09qbm1PVXNwS1lZaVJuYTlvIn0.LwgU_wAjoW9vLYh1y5NExjvwFYmxdBZOFOiETZfELmcgjAD7nt66OQDfXMyiYlGIv37OKNr49exeb1mH3XEcpHmmz-BFTO_uen6gUdPckSPF5tJDdwc51r-RwQh6WSVuRemJdckNvyJKtY9F_MZ5QKUW3lrLG-Km7rBmyHpRAs5Uc1RizZOwIn_vXKhxlxV_XcpGKZpkT790im2c-QbFgL_6OpvHG9EUtf88dFcGXEk6xXbKIotqe7jeI9STH12r8wdrDDJGYoQbbKR_cqdTd-benX8d2vtT1Yxuq-mGCkGxPvb56dmqB5-l5fiRj2irmZxKaKTWPFLyf3dJyYYqEQ
type
Bearer
2020-07-31 12:28:32 SUCCESS
ExtractExpiresInFromTokenEndpointResponse
Extracted 'expires_in'
expires_in
86400
2020-07-31 12:28:32 SUCCESS
ValidateExpiresIn
expires_in passed all validation checks
expires_in
86400
2020-07-31 12:28:32 SUCCESS
CheckForRefreshTokenValue
Found a refresh token
refresh_token
pmSZFdQ7YtQfV-GxBK3aAZLm_8-3YXnj8atLFMWQhgI
2020-07-31 12:28:32 SUCCESS
ExtractIdTokenFromTokenResponse
Found and parsed the id_token from token_endpoint_response
value
eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDUxOTgyNDE4MDMxNyJdLCJzX2hhc2giOiJKQTNIRzN2NXpxOGpwTnhJa1Qxal9BIiwiYXV0aF90aW1lIjoxNTk2MTk4NTExLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODgxMiwiaWF0IjoxNTk2MTk4NTEyLCJub25jZSI6IjFxcWFuMmc4SE0ifQ.EjmVHUPoPi3xP5h2x9ae3t3wCGMwtLFmhKafFQRRZpPyKxa2ikow558mOktLsqqDNpjgz4HcJ5_4bPFcVMoRntIY1vsdIYZ6OVDCnhno1IC3bQ-IwIhoJUl8SfywEc38RDL4JmpsZ1HuT4yZfljp-_9xHve-t7Um5Y18MbhHkN2KWA64KE7mr1u9DbZrM3LuUxBZxuYaavji1RG-V55YYJ78saoe0eVAA96JkTXQjDW1PavcHiOGdLMS-9vLRm41PkAMxrFFF1o0UzdsPXlJY08AQRn0hiB00mSht9NPGUqok2IiKBojktppydFHGaI3uiPTnZZaYiwgqces6AGoOw
header
{
  "kid": "authlete-fapidev-api-20180524",
  "alg": "RS256"
}
claims
{
  "sub": "1001",
  "aud": "470519824180317",
  "s_hash": "JA3HG3v5zq8jpNxIkT1j_A",
  "auth_time": 1596198511,
  "iss": "https://fapidev-as.authlete.net/",
  "exp": 1596198812,
  "iat": 1596198512,
  "nonce": "1qqan2g8HM"
}
2020-07-31 12:28:32 SUCCESS
ValidateIdToken
ID token iss, aud, exp, iat, auth_time, acr & nbf claims passed validation checks
2020-07-31 12:28:32 SUCCESS
ValidateIdTokenNonce
Nonce values match
nonce
1qqan2g8HM
2020-07-31 12:28:32 SUCCESS
ValidateIdTokenACRClaimAgainstRequest
Nothing to check; the conformance suite did not request an acr claim in request object
2020-07-31 12:28:32 SUCCESS
ValidateIdTokenSignature
id_token signature validated
id_token
eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDUxOTgyNDE4MDMxNyJdLCJzX2hhc2giOiJKQTNIRzN2NXpxOGpwTnhJa1Qxal9BIiwiYXV0aF90aW1lIjoxNTk2MTk4NTExLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODgxMiwiaWF0IjoxNTk2MTk4NTEyLCJub25jZSI6IjFxcWFuMmc4SE0ifQ.EjmVHUPoPi3xP5h2x9ae3t3wCGMwtLFmhKafFQRRZpPyKxa2ikow558mOktLsqqDNpjgz4HcJ5_4bPFcVMoRntIY1vsdIYZ6OVDCnhno1IC3bQ-IwIhoJUl8SfywEc38RDL4JmpsZ1HuT4yZfljp-_9xHve-t7Um5Y18MbhHkN2KWA64KE7mr1u9DbZrM3LuUxBZxuYaavji1RG-V55YYJ78saoe0eVAA96JkTXQjDW1PavcHiOGdLMS-9vLRm41PkAMxrFFF1o0UzdsPXlJY08AQRn0hiB00mSht9NPGUqok2IiKBojktppydFHGaI3uiPTnZZaYiwgqces6AGoOw
2020-07-31 12:28:32 SUCCESS
ValidateIdTokenSignatureUsingKid
id_token signature validated
id_token
eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDUxOTgyNDE4MDMxNyJdLCJzX2hhc2giOiJKQTNIRzN2NXpxOGpwTnhJa1Qxal9BIiwiYXV0aF90aW1lIjoxNTk2MTk4NTExLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODgxMiwiaWF0IjoxNTk2MTk4NTEyLCJub25jZSI6IjFxcWFuMmc4SE0ifQ.EjmVHUPoPi3xP5h2x9ae3t3wCGMwtLFmhKafFQRRZpPyKxa2ikow558mOktLsqqDNpjgz4HcJ5_4bPFcVMoRntIY1vsdIYZ6OVDCnhno1IC3bQ-IwIhoJUl8SfywEc38RDL4JmpsZ1HuT4yZfljp-_9xHve-t7Um5Y18MbhHkN2KWA64KE7mr1u9DbZrM3LuUxBZxuYaavji1RG-V55YYJ78saoe0eVAA96JkTXQjDW1PavcHiOGdLMS-9vLRm41PkAMxrFFF1o0UzdsPXlJY08AQRn0hiB00mSht9NPGUqok2IiKBojktppydFHGaI3uiPTnZZaYiwgqces6AGoOw
2020-07-31 12:28:32 SUCCESS
CheckForSubjectInIdToken
Found 'sub' in id_token
sub
1001
2020-07-31 12:28:32 SUCCESS
ExtractRefreshTokenFromTokenResponse
Extracted refresh token from response
refresh_token
pmSZFdQ7YtQfV-GxBK3aAZLm_8-3YXnj8atLFMWQhgI
2020-07-31 12:28:32 SUCCESS
EnsureRefreshTokenContainsAllowedCharactersOnly
Refresh token does not contain any illegal characters
Refresh Token Request
2020-07-31 12:28:32 SUCCESS
CreateRefreshTokenRequest
Created token endpoint request parameters
grant_type
refresh_token
refresh_token
pmSZFdQ7YtQfV-GxBK3aAZLm_8-3YXnj8atLFMWQhgI
2020-07-31 12:28:32 SUCCESS
AddScopeToTokenEndpointRequest
Added scope of 'openid offline_access' to token endpoint request
grant_type
refresh_token
refresh_token
pmSZFdQ7YtQfV-GxBK3aAZLm_8-3YXnj8atLFMWQhgI
scope
openid offline_access
2020-07-31 12:28:32 SUCCESS
AddBasicAuthClientSecretAuthenticationParameters
Added basic authorization header
Authorization
Basic NDcwNTE5ODI0MTgwMzE3OkVrMkNpdU9ybWZkaHZzakdsMDM3X3BzY0NtWXNla3M0YnpTU3hjM1VaVWNyLTlLaTJybENSZGdfTXQtVWtjOWItTHBham5NVWN3bXpxZ1hzLWVES3p3
2020-07-31 12:28:32 SUCCESS
WaitForOneSecond
Pausing for 1 seconds
2020-07-31 12:28:33 SUCCESS
WaitForOneSecond
Woke up after 1 seconds sleep
2020-07-31 12:28:33
CallTokenEndpointAndReturnFullResponse
HTTP request
request_uri
https://fapidev-as.authlete.net/api/token
request_method
POST
request_headers
{
  "accept": "application/json;charset\u003dUTF-8",
  "authorization": "Basic NDcwNTE5ODI0MTgwMzE3OkVrMkNpdU9ybWZkaHZzakdsMDM3X3BzY0NtWXNla3M0YnpTU3hjM1VaVWNyLTlLaTJybENSZGdfTXQtVWtjOWItTHBham5NVWN3bXpxZ1hzLWVES3p3",
  "accept-charset": "utf-8",
  "content-type": "application/x-www-form-urlencoded;charset\u003dUTF-8",
  "content-length": "110"
}
request_body
grant_type=refresh_token&refresh_token=pmSZFdQ7YtQfV-GxBK3aAZLm_8-3YXnj8atLFMWQhgI&scope=openid+offline_access
2020-07-31 12:28:34 RESPONSE
CallTokenEndpointAndReturnFullResponse
HTTP response
response_status_code
200 OK
response_status_text
OK
response_headers
{
  "date": "Fri, 31 Jul 2020 12:28:34 GMT",
  "server": "Jetty(9.4.21-SNAPSHOT)",
  "cache-control": "no-store, no-transform",
  "pragma": "no-cache",
  "content-type": "application/json;charset\u003dutf-8",
  "content-length": "860",
  "keep-alive": "timeout\u003d5, max\u003d100",
  "connection": "Keep-Alive"
}
response_body
{"access_token":"eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvcGVuaWQgb2ZmbGluZV9hY2Nlc3MiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDkxNCwiaWF0IjoxNTk2MTk4NTE0LCJjbGllbnRfaWQiOiI0NzA1MTk4MjQxODAzMTciLCJqdGkiOiItaldhdWdHUHM4SVpNY1JoMkpwRmlRalRRaU04Umo3MzZZTThHSUM1SGM4In0.bnKrTsLrHFGOnkwGsYdTEnxxpqtjCAo1_fDQhDvRh7Uzw8iwTCAqeOzys1GtR3LCk4IgheAO1rkGLgTL25R1OaBTwRzmNMZ5yhOylCgRZbkvVhxFnp57D8MuWkcN_ajZKKA0FLsQo4IZwEK9hw355t3jf8Vhlgek8FZ5xFdPTNeBPVD_xVNBjTEjJJIf46MIHfwlHufDlNMK_9HP23xcalwGPTWYvC7zg50JMThKqrOOa8q4eyrPziK_zMeLK2y6IajeRswrVwHQyYxK9myjIj3S_jDkCIM05Wmh__TGm74APuDQtsPgd0kcuVR8wjrVOkgiowpjhysyU0UnEPfbKw","refresh_token":"zDuVT6rgBum5ZF16S5gwYl_8Mj2LuyfCXxNMLaAnZuw","scope":"openid offline_access","token_type":"Bearer","expires_in":86400}
2020-07-31 12:28:34 SUCCESS
CallTokenEndpointAndReturnFullResponse
Parsed token endpoint response
access_token
eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvcGVuaWQgb2ZmbGluZV9hY2Nlc3MiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDkxNCwiaWF0IjoxNTk2MTk4NTE0LCJjbGllbnRfaWQiOiI0NzA1MTk4MjQxODAzMTciLCJqdGkiOiItaldhdWdHUHM4SVpNY1JoMkpwRmlRalRRaU04Umo3MzZZTThHSUM1SGM4In0.bnKrTsLrHFGOnkwGsYdTEnxxpqtjCAo1_fDQhDvRh7Uzw8iwTCAqeOzys1GtR3LCk4IgheAO1rkGLgTL25R1OaBTwRzmNMZ5yhOylCgRZbkvVhxFnp57D8MuWkcN_ajZKKA0FLsQo4IZwEK9hw355t3jf8Vhlgek8FZ5xFdPTNeBPVD_xVNBjTEjJJIf46MIHfwlHufDlNMK_9HP23xcalwGPTWYvC7zg50JMThKqrOOa8q4eyrPziK_zMeLK2y6IajeRswrVwHQyYxK9myjIj3S_jDkCIM05Wmh__TGm74APuDQtsPgd0kcuVR8wjrVOkgiowpjhysyU0UnEPfbKw
refresh_token
zDuVT6rgBum5ZF16S5gwYl_8Mj2LuyfCXxNMLaAnZuw
scope
openid offline_access
token_type
Bearer
expires_in
86400
2020-07-31 12:28:34 SUCCESS
CheckTokenEndpointHttpStatus200
Token endpoint http status code was 200
2020-07-31 12:28:34 SUCCESS
CheckTokenEndpointReturnedJsonContentType
token_endpoint_response_headers Content-Type: header is application/json
2020-07-31 12:28:34 SUCCESS
CheckTokenEndpointCacheHeaders
Checked 'pragma' and 'cache-control' in the headers of token_endpoint_response.
2020-07-31 12:28:34 SUCCESS
CheckIfTokenEndpointResponseError
No error from token endpoint
2020-07-31 12:28:34 SUCCESS
ExtractAccessTokenFromTokenResponse
Extracted the access token
value
eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvcGVuaWQgb2ZmbGluZV9hY2Nlc3MiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDkxNCwiaWF0IjoxNTk2MTk4NTE0LCJjbGllbnRfaWQiOiI0NzA1MTk4MjQxODAzMTciLCJqdGkiOiItaldhdWdHUHM4SVpNY1JoMkpwRmlRalRRaU04Umo3MzZZTThHSUM1SGM4In0.bnKrTsLrHFGOnkwGsYdTEnxxpqtjCAo1_fDQhDvRh7Uzw8iwTCAqeOzys1GtR3LCk4IgheAO1rkGLgTL25R1OaBTwRzmNMZ5yhOylCgRZbkvVhxFnp57D8MuWkcN_ajZKKA0FLsQo4IZwEK9hw355t3jf8Vhlgek8FZ5xFdPTNeBPVD_xVNBjTEjJJIf46MIHfwlHufDlNMK_9HP23xcalwGPTWYvC7zg50JMThKqrOOa8q4eyrPziK_zMeLK2y6IajeRswrVwHQyYxK9myjIj3S_jDkCIM05Wmh__TGm74APuDQtsPgd0kcuVR8wjrVOkgiowpjhysyU0UnEPfbKw
type
Bearer
2020-07-31 12:28:34 SUCCESS
CheckTokenTypeIsBearer
Token type is bearer
2020-07-31 12:28:34 SUCCESS
EnsureMinimumAccessTokenEntropy
Calculated shannon entropy seems sufficient
actual
4132.562979592359
expected
96.0
2020-07-31 12:28:34 SUCCESS
EnsureAccessTokenContainsAllowedCharactersOnly
Access token does not contain any illegal characters
2020-07-31 12:28:34 SUCCESS
ExtractExpiresInFromTokenEndpointResponse
Extracted 'expires_in'
expires_in
86400
2020-07-31 12:28:34 SUCCESS
ValidateExpiresIn
expires_in passed all validation checks
expires_in
86400
2020-07-31 12:28:34 SUCCESS
EnsureAccessTokenValuesAreDifferent
Access token values are not the same
first_access_token
eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDkxMiwiaWF0IjoxNTk2MTk4NTEyLCJjbGllbnRfaWQiOiI0NzA1MTk4MjQxODAzMTciLCJqdGkiOiJWTDh0bW50SzJqbEQxN0c0WmljSjdqS05Xb09qbm1PVXNwS1lZaVJuYTlvIn0.LwgU_wAjoW9vLYh1y5NExjvwFYmxdBZOFOiETZfELmcgjAD7nt66OQDfXMyiYlGIv37OKNr49exeb1mH3XEcpHmmz-BFTO_uen6gUdPckSPF5tJDdwc51r-RwQh6WSVuRemJdckNvyJKtY9F_MZ5QKUW3lrLG-Km7rBmyHpRAs5Uc1RizZOwIn_vXKhxlxV_XcpGKZpkT790im2c-QbFgL_6OpvHG9EUtf88dFcGXEk6xXbKIotqe7jeI9STH12r8wdrDDJGYoQbbKR_cqdTd-benX8d2vtT1Yxuq-mGCkGxPvb56dmqB5-l5fiRj2irmZxKaKTWPFLyf3dJyYYqEQ
second_access_token
eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvcGVuaWQgb2ZmbGluZV9hY2Nlc3MiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDkxNCwiaWF0IjoxNTk2MTk4NTE0LCJjbGllbnRfaWQiOiI0NzA1MTk4MjQxODAzMTciLCJqdGkiOiItaldhdWdHUHM4SVpNY1JoMkpwRmlRalRRaU04Umo3MzZZTThHSUM1SGM4In0.bnKrTsLrHFGOnkwGsYdTEnxxpqtjCAo1_fDQhDvRh7Uzw8iwTCAqeOzys1GtR3LCk4IgheAO1rkGLgTL25R1OaBTwRzmNMZ5yhOylCgRZbkvVhxFnp57D8MuWkcN_ajZKKA0FLsQo4IZwEK9hw355t3jf8Vhlgek8FZ5xFdPTNeBPVD_xVNBjTEjJJIf46MIHfwlHufDlNMK_9HP23xcalwGPTWYvC7zg50JMThKqrOOa8q4eyrPziK_zMeLK2y6IajeRswrVwHQyYxK9myjIj3S_jDkCIM05Wmh__TGm74APuDQtsPgd0kcuVR8wjrVOkgiowpjhysyU0UnEPfbKw
2020-07-31 12:28:34 INFO
ExtractIdTokenFromTokenResponse
Couldn't find id_token in token_endpoint_response
2020-07-31 12:28:34 SUCCESS
ExtractRefreshTokenFromTokenResponse
Extracted refresh token from response
refresh_token
zDuVT6rgBum5ZF16S5gwYl_8Mj2LuyfCXxNMLaAnZuw
2020-07-31 12:28:34 SUCCESS
EnsureMinimumRefreshTokenLength
Refresh token is of sufficient length
actual
344
required
128
2020-07-31 12:28:34 SUCCESS
EnsureMinimumRefreshTokenEntropy
Calculated shannon entropy seems sufficient
actual
211.3293844521902
expected
96.0
2020-07-31 12:28:34 INFO
CompareIdTokenClaims
Skipped evaluation due to missing required object: second_id_token
expected
second_id_token
mapped
second_id_token
Userinfo endpoint tests
2020-07-31 12:28:34
CallProtectedResourceWithBearerToken
HTTP request
request_uri
https://fapidev-rs.authlete.net/api/userinfo
request_method
GET
request_headers
{
  "accept": "application/json;charset\u003dUTF-8",
  "authorization": "Bearer eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvcGVuaWQgb2ZmbGluZV9hY2Nlc3MiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDkxNCwiaWF0IjoxNTk2MTk4NTE0LCJjbGllbnRfaWQiOiI0NzA1MTk4MjQxODAzMTciLCJqdGkiOiItaldhdWdHUHM4SVpNY1JoMkpwRmlRalRRaU04Umo3MzZZTThHSUM1SGM4In0.bnKrTsLrHFGOnkwGsYdTEnxxpqtjCAo1_fDQhDvRh7Uzw8iwTCAqeOzys1GtR3LCk4IgheAO1rkGLgTL25R1OaBTwRzmNMZ5yhOylCgRZbkvVhxFnp57D8MuWkcN_ajZKKA0FLsQo4IZwEK9hw355t3jf8Vhlgek8FZ5xFdPTNeBPVD_xVNBjTEjJJIf46MIHfwlHufDlNMK_9HP23xcalwGPTWYvC7zg50JMThKqrOOa8q4eyrPziK_zMeLK2y6IajeRswrVwHQyYxK9myjIj3S_jDkCIM05Wmh__TGm74APuDQtsPgd0kcuVR8wjrVOkgiowpjhysyU0UnEPfbKw",
  "accept-charset": "utf-8",
  "content-length": "0"
}
request_body

                                
2020-07-31 12:28:34 RESPONSE
CallProtectedResourceWithBearerToken
HTTP response
response_status_code
200 OK
response_status_text
OK
response_headers
{
  "date": "Fri, 31 Jul 2020 12:28:34 GMT",
  "server": "Jetty(9.4.21-SNAPSHOT)",
  "cache-control": "no-store, no-transform",
  "pragma": "no-cache",
  "content-type": "application/json;charset\u003dutf-8",
  "content-length": "14",
  "keep-alive": "timeout\u003d5, max\u003d100",
  "connection": "Keep-Alive"
}
response_body
{"sub":"1001"}
2020-07-31 12:28:34 SUCCESS
CallProtectedResourceWithBearerToken
Got a response from the resource endpoint
headers
{
  "date": "Fri, 31 Jul 2020 12:28:34 GMT",
  "server": "Jetty(9.4.21-SNAPSHOT)",
  "cache-control": "no-store, no-transform",
  "pragma": "no-cache",
  "content-type": "application/json;charset\u003dutf-8",
  "content-length": "14",
  "keep-alive": "timeout\u003d5, max\u003d100",
  "connection": "Keep-Alive"
}
status_code
{
  "code": 200
}
body
{"sub":"1001"}
Second client: Make request to authorization endpoint
2020-07-31 12:28:34 SUCCESS
CreateAuthorizationEndpointRequestFromClientInformation
Created authorization endpoint request
client_id
470553331604632
redirect_uri
https://www.certification.openid.net/test/a/oidf-authlete-core/callback
scope
openid offline_access
2020-07-31 12:28:34
CreateRandomStateValue
Created state value
requested_state_length
10
state
OUHXf3ZMP9
2020-07-31 12:28:34 SUCCESS
AddStateToAuthorizationEndpointRequest
Added state parameter to request
client_id
470553331604632
redirect_uri
https://www.certification.openid.net/test/a/oidf-authlete-core/callback
scope
openid offline_access
state
OUHXf3ZMP9
2020-07-31 12:28:34
CreateRandomNonceValue
Created nonce value
requested_nonce_length
10
nonce
8rY6hHozBc
2020-07-31 12:28:34 SUCCESS
AddNonceToAuthorizationEndpointRequest
Added nonce parameter to request
client_id
470553331604632
redirect_uri
https://www.certification.openid.net/test/a/oidf-authlete-core/callback
scope
openid offline_access
state
OUHXf3ZMP9
nonce
8rY6hHozBc
2020-07-31 12:28:34 SUCCESS
SetAuthorizationEndpointRequestResponseTypeFromEnvironment
Added response_type parameter to request
client_id
470553331604632
redirect_uri
https://www.certification.openid.net/test/a/oidf-authlete-core/callback
scope
openid offline_access
state
OUHXf3ZMP9
nonce
8rY6hHozBc
response_type
code token
2020-07-31 12:28:34
SetAuthorizationEndpointRequestResponseModeToFormPost
Added response_mode parameter to request
client_id
470553331604632
redirect_uri
https://www.certification.openid.net/test/a/oidf-authlete-core/callback
scope
openid offline_access
state
OUHXf3ZMP9
nonce
8rY6hHozBc
response_type
code token
response_mode
form_post
2020-07-31 12:28:34 SUCCESS
AddPromptConsentToAuthorizationEndpointRequestIfScopeContainsOfflineAccess
Added prompt=consent to authorization endpoint request
client_id
470553331604632
redirect_uri
https://www.certification.openid.net/test/a/oidf-authlete-core/callback
scope
openid offline_access
state
OUHXf3ZMP9
nonce
8rY6hHozBc
response_type
code token
response_mode
form_post
prompt
consent
2020-07-31 12:28:34 SUCCESS
BuildPlainRedirectToAuthorizationEndpoint
Sending to authorization endpoint
redirect_to_authorization_endpoint
https://fapidev-www.authlete.net/api/authorization?client_id=470553331604632&redirect_uri=https://www.certification.openid.net/test/a/oidf-authlete-core/callback&scope=openid%20offline_access&state=OUHXf3ZMP9&nonce=8rY6hHozBc&response_type=code%20token&response_mode=form_post&prompt=consent
2020-07-31 12:28:34 REDIRECT
oidcc-refresh-token
Redirecting to authorization endpoint
redirect_to
https://fapidev-www.authlete.net/api/authorization?client_id=470553331604632&redirect_uri=https://www.certification.openid.net/test/a/oidf-authlete-core/callback&scope=openid%20offline_access&state=OUHXf3ZMP9&nonce=8rY6hHozBc&response_type=code%20token&response_mode=form_post&prompt=consent
2020-07-31 12:28:34
WebRunner
Scripted browser HTTP request
browser
goToUrl
request_method
GET
request_uri
https://fapidev-www.authlete.net/api/authorization?client_id=470553331604632&redirect_uri=https://www.certification.openid.net/test/a/oidf-authlete-core/callback&scope=openid%20offline_access&state=OUHXf3ZMP9&nonce=8rY6hHozBc&response_type=code%20token&response_mode=form_post&prompt=consent
2020-07-31 12:28:35 RESPONSE
WebRunner
Scripted browser HTTP response
response_content
<!doctype html>
<!---->
<!--




-->
<html>
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, minimum-scale=1.0, initial-scale=1.0, user-scalable=yes">
  <title>FAPI Test Service | Authorization</title>
  <link rel="stylesheet" href="/css/authorization.css">
  <!--  //-->
</head>
<body class="font-default">
  <div id="page_title">FAPI Test Service</div>

  <div id="content">
    <h3 id="client-name">core conformance client secret basic (2nd client)</h3>
    <div class="indent">
      <img id="logo" src="https://button.heenan.me.uk/~joseph/authlete-150x150.png" alt="[Logo] (150x150)">

      <div id="client-summary">
        <p>core conformance client secret basic (2nd client)</p>
        <ul id="client-link-list">
          

          

          
        </ul>
      </div>

      <div style="clear: both;"></div>
    </div>

    
    <h4 id="permissions">Permissions</h4>
    <div class="indent">
      <p>The application is requesting the following permissions.</p>

      <dl id="scope-list">
        
        <dt>offline_access</dt>
        <dd>A permission to request a refresh token exchangeable with an access token which can access the UserInfo Endpoint even when the end-user is offline. See OpenID Connect Core 1.0, 11. for details.</dd>
        
        <dt>openid</dt>
        <dd>A permission to request an OpenID Provider to issue an ID Token. See OpenID Connect Core 1.0, 3.1.2.1. for details.</dd>
        
      </dl>
    </div>
    

    

    

    <h4 id="authorization">Authorization</h4>
    <div class="indent">
      <p>Do you grant authorization to the application?</p>

      <form id="authorization-form" action="/api/authorization/decision" method="POST">
        
        
        <div id="login-user"><i>Logged in as 1001</i></div>
        
        <div id="authorization-form-buttons">
          <input type="submit" name="authorized" id="authorize-button" value="Authorize" class="font-default"/>
          <input type="submit" name="denied"     id="deny-button"      value="Deny"      class="font-default"/>
        </div>
      </form>
    </div>
  </div>

</body>
</html>
response_content_type
*/*
response_status_text
200-OK
response_status_code
200
2020-07-31 12:28:35 INFO
WebRunner
Entering text
task
Initial Login
browser
text
element_type
id
value
john
url
https://fapidev-www.authlete.net/api/authorization?client_id=470553331604632&redirect_uri=https://www.certification.openid.net/test/a/oidf-authlete-core/callback&scope=openid%20offline_access&state=OUHXf3ZMP9&nonce=8rY6hHozBc&response_type=code%20token&response_mode=form_post&prompt=consent
target
loginId
2020-07-31 12:28:35 INFO
WebRunner
Element not found, skipping as 'text' command is marked 'optional'
task
Initial Login
browser
text
element_type
id
value
john
url
https://fapidev-www.authlete.net/api/authorization?client_id=470553331604632&redirect_uri=https://www.certification.openid.net/test/a/oidf-authlete-core/callback&scope=openid%20offline_access&state=OUHXf3ZMP9&nonce=8rY6hHozBc&response_type=code%20token&response_mode=form_post&prompt=consent
target
loginId
2020-07-31 12:28:35 INFO
WebRunner
Entering text
task
Initial Login
browser
text
element_type
id
value
john
url
https://fapidev-www.authlete.net/api/authorization?client_id=470553331604632&redirect_uri=https://www.certification.openid.net/test/a/oidf-authlete-core/callback&scope=openid%20offline_access&state=OUHXf3ZMP9&nonce=8rY6hHozBc&response_type=code%20token&response_mode=form_post&prompt=consent
target
password
2020-07-31 12:28:35 INFO
WebRunner
Element not found, skipping as 'text' command is marked 'optional'
task
Initial Login
browser
text
element_type
id
value
john
url
https://fapidev-www.authlete.net/api/authorization?client_id=470553331604632&redirect_uri=https://www.certification.openid.net/test/a/oidf-authlete-core/callback&scope=openid%20offline_access&state=OUHXf3ZMP9&nonce=8rY6hHozBc&response_type=code%20token&response_mode=form_post&prompt=consent
target
password
2020-07-31 12:28:35 INFO
WebRunner
Clicking an element
task
Initial Login
browser
click
element_type
name
url
https://fapidev-www.authlete.net/api/authorization?client_id=470553331604632&redirect_uri=https://www.certification.openid.net/test/a/oidf-authlete-core/callback&scope=openid%20offline_access&state=OUHXf3ZMP9&nonce=8rY6hHozBc&response_type=code%20token&response_mode=form_post&prompt=consent
target
authorized
2020-07-31 12:28:35 INCOMING
oidcc-refresh-token
Incoming HTTP request to test instance 4t9r4y6qDcdZrko
incoming_headers
{
  "host": "www.certification.openid.net",
  "upgrade-insecure-requests": "1",
  "user-agent": "Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/63.0.3239.108 Safari/537.36",
  "accept": "text/html,application/xhtml+xml,application/xml;q\u003d0.9,image/webp,image/apng,*/*;q\u003d0.8",
  "referer": "https://fapidev-www.authlete.net/api/authorization/decision",
  "accept-encoding": "gzip, deflate",
  "accept-language": "en-US",
  "cookie": "JSESSIONID\u003d1E93F318D58E4AE6274302F5B9BDD229",
  "origin": "https://fapidev-www.authlete.net/api/authorization/decision",
  "cache-control": "max-age\u003d0",
  "content-type": "application/x-www-form-urlencoded",
  "x-ssl-cipher": "ECDHE-RSA-AES256-GCM-SHA384",
  "x-ssl-protocol": "TLSv1.2",
  "content-length": "848",
  "x-forwarded-host": "www.certification.openid.net",
  "x-forwarded-server": "www.certification.openid.net",
  "connection": "close"
}
incoming_path
callback
incoming_body_form_params
{
  "state": "OUHXf3ZMP9",
  "code": "p_XSIxVhFZI94HR_bF-3RA2_uHYESaogLWKXLcPqG7I",
  "access_token": "eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDkxNSwiaWF0IjoxNTk2MTk4NTE1LCJjbGllbnRfaWQiOiI0NzA1NTMzMzE2MDQ2MzIiLCJqdGkiOiJfRFI4aWtWY1hwZWJRYUZBRVhpZENGd25YRHgzSE81YUtFSHZIZEJkYlo4In0.b3nc6b4F5GqQlku2e_Q64lzdRw_WY-5lhNDsyANvAIDkZNlXXUXAAxb2rf5f3erlOTOaVHyMUBiwJ2-ITSRy-ISzxZLafImNsHhkc3KN9-4vDDjq9sKizdn4oSFeG4FASNb6HWPziH05Z-3Pist9Sl1ROHU2JZBu--oh8tjq5p5i_8gb8gzW9d5DGAZoXncMCRrBo1RRQVjbu97EDErMC3itonkh5FOfzjKFmyd5a6vl_2ELMb4rbRGKwa_TsUNn_f4exmaPLH_zN3mE-CW_CuzPENiJPv3sHoJzWqXeSbCNyw9AtUcpxbywiKvgvgmdQceguoRi3nYc-I9IP53LvA",
  "token_type": "Bearer",
  "expires_in": "86400",
  "scope": "offline_access openid"
}
incoming_method
POST
incoming_body_json
incoming_query_string_params
{}
incoming_body
state=OUHXf3ZMP9&code=p_XSIxVhFZI94HR_bF-3RA2_uHYESaogLWKXLcPqG7I&access_token=eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDkxNSwiaWF0IjoxNTk2MTk4NTE1LCJjbGllbnRfaWQiOiI0NzA1NTMzMzE2MDQ2MzIiLCJqdGkiOiJfRFI4aWtWY1hwZWJRYUZBRVhpZENGd25YRHgzSE81YUtFSHZIZEJkYlo4In0.b3nc6b4F5GqQlku2e_Q64lzdRw_WY-5lhNDsyANvAIDkZNlXXUXAAxb2rf5f3erlOTOaVHyMUBiwJ2-ITSRy-ISzxZLafImNsHhkc3KN9-4vDDjq9sKizdn4oSFeG4FASNb6HWPziH05Z-3Pist9Sl1ROHU2JZBu--oh8tjq5p5i_8gb8gzW9d5DGAZoXncMCRrBo1RRQVjbu97EDErMC3itonkh5FOfzjKFmyd5a6vl_2ELMb4rbRGKwa_TsUNn_f4exmaPLH_zN3mE-CW_CuzPENiJPv3sHoJzWqXeSbCNyw9AtUcpxbywiKvgvgmdQceguoRi3nYc-I9IP53LvA&token_type=Bearer&expires_in=86400&scope=offline_access+openid
2020-07-31 12:28:35 SUCCESS
CreateRandomImplicitSubmitUrl
Created random implicit submission URL
implicit_submit
{
  "path": "implicit/Xq4wTuhKLQ5KJCKddmwS",
  "fullUrl": "https://www.certification.openid.net/test/a/oidf-authlete-core/implicit/Xq4wTuhKLQ5KJCKddmwS"
}
2020-07-31 12:28:35 OUTGOING
oidcc-refresh-token
Response to HTTP request to test instance 4t9r4y6qDcdZrko
outgoing
ModelAndView [view="implicitCallback"; model={implicitSubmitUrl=https://www.certification.openid.net/test/a/oidf-authlete-core/implicit/Xq4wTuhKLQ5KJCKddmwS, returnUrl=/log-detail.html?log=4t9r4y6qDcdZrko}]
outgoing_path
callback
2020-07-31 12:28:35 INFO
WebRunner
Completed processing of webpage
task
Initial Login
browser
complete
response_status_text
200-
match
https://fapidev-www.authlete.net/api/authorization*
url
https://www.certification.openid.net/test/a/oidf-authlete-core/callback
response_status_code
200
2020-07-31 12:28:35 INFO
WebRunner
Waiting
regexp
seconds
10
task
Verify Complete
browser
wait
action
element_type
id
url
https://www.certification.openid.net/test/a/oidf-authlete-core/callback
target
submission_complete
2020-07-31 12:28:35 INCOMING
oidcc-refresh-token
Incoming HTTP request to test instance 4t9r4y6qDcdZrko
incoming_headers
{
  "host": "www.certification.openid.net",
  "upgrade-insecure-requests": "1",
  "user-agent": "Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/63.0.3239.108 Safari/537.36",
  "accept": "*/*",
  "referer": "https://www.certification.openid.net/test/a/oidf-authlete-core/callback",
  "accept-encoding": "gzip, deflate",
  "accept-language": "en-US",
  "cookie": "JSESSIONID\u003d1E93F318D58E4AE6274302F5B9BDD229",
  "x-requested-with": "XMLHttpRequest",
  "content-type": "text/plain",
  "x-ssl-cipher": "ECDHE-RSA-AES256-GCM-SHA384",
  "x-ssl-protocol": "TLSv1.2",
  "content-length": "0",
  "x-forwarded-host": "www.certification.openid.net",
  "x-forwarded-server": "www.certification.openid.net",
  "connection": "close"
}
incoming_path
implicit/Xq4wTuhKLQ5KJCKddmwS
incoming_body_form_params
incoming_method
POST
incoming_body_json
incoming_query_string_params
{}
incoming_body
2020-07-31 12:28:35 OUTGOING
oidcc-refresh-token
Response to HTTP request to test instance 4t9r4y6qDcdZrko
outgoing
org.springframework.web.servlet.view.RedirectView: [RedirectView]; URL [/log-detail.html?log=4t9r4y6qDcdZrko]
outgoing_path
implicit/Xq4wTuhKLQ5KJCKddmwS
2020-07-31 12:28:35 SUCCESS
ExtractImplicitHashToCallbackResponse
implicit_hash is empty
2020-07-31 12:28:35 REDIRECT-IN
oidcc-refresh-token
Authorization endpoint response captured
url_query
{}
headers
{
  "host": "www.certification.openid.net",
  "upgrade-insecure-requests": "1",
  "user-agent": "Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/63.0.3239.108 Safari/537.36",
  "accept": "text/html,application/xhtml+xml,application/xml;q\u003d0.9,image/webp,image/apng,*/*;q\u003d0.8",
  "referer": "https://fapidev-www.authlete.net/api/authorization/decision",
  "accept-encoding": "gzip, deflate",
  "accept-language": "en-US",
  "cookie": "JSESSIONID\u003d1E93F318D58E4AE6274302F5B9BDD229",
  "origin": "https://fapidev-www.authlete.net/api/authorization/decision",
  "cache-control": "max-age\u003d0",
  "content-type": "application/x-www-form-urlencoded",
  "x-ssl-cipher": "ECDHE-RSA-AES256-GCM-SHA384",
  "x-ssl-protocol": "TLSv1.2",
  "content-length": "848",
  "x-forwarded-host": "www.certification.openid.net",
  "x-forwarded-server": "www.certification.openid.net",
  "connection": "close"
}
http_method
POST
url_fragment
{}
post_body
{
  "state": "OUHXf3ZMP9",
  "code": "p_XSIxVhFZI94HR_bF-3RA2_uHYESaogLWKXLcPqG7I",
  "access_token": "eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDkxNSwiaWF0IjoxNTk2MTk4NTE1LCJjbGllbnRfaWQiOiI0NzA1NTMzMzE2MDQ2MzIiLCJqdGkiOiJfRFI4aWtWY1hwZWJRYUZBRVhpZENGd25YRHgzSE81YUtFSHZIZEJkYlo4In0.b3nc6b4F5GqQlku2e_Q64lzdRw_WY-5lhNDsyANvAIDkZNlXXUXAAxb2rf5f3erlOTOaVHyMUBiwJ2-ITSRy-ISzxZLafImNsHhkc3KN9-4vDDjq9sKizdn4oSFeG4FASNb6HWPziH05Z-3Pist9Sl1ROHU2JZBu--oh8tjq5p5i_8gb8gzW9d5DGAZoXncMCRrBo1RRQVjbu97EDErMC3itonkh5FOfzjKFmyd5a6vl_2ELMb4rbRGKwa_TsUNn_f4exmaPLH_zN3mE-CW_CuzPENiJPv3sHoJzWqXeSbCNyw9AtUcpxbywiKvgvgmdQceguoRi3nYc-I9IP53LvA",
  "token_type": "Bearer",
  "expires_in": "86400",
  "scope": "offline_access openid"
}
Second client: Verify authorization endpoint response
2020-07-31 12:28:35 SUCCESS
CheckCallbackHttpMethodIsPost
HTTP method used at redirect_uri is 'POST'
2020-07-31 12:28:35 SUCCESS
CheckCallbackContentTypeIsFormUrlEncoded
content-type header to redirect_uri has the expected value
content_type
application/x-www-form-urlencoded
expected
application/x-www-form-urlencoded
2020-07-31 12:28:35 SUCCESS
RejectAuthCodeInUrlQuery
Authorization code is not present in URL query returned from authorization endpoint
2020-07-31 12:28:35 SUCCESS
RejectErrorInUrlQuery
'error' is not present in URL query returned from authorization endpoint
2020-07-31 12:28:35 SUCCESS
CheckMatchingCallbackParameters
Callback parameters successfully verified
2020-07-31 12:28:35 SUCCESS
CheckIfAuthorizationEndpointError
No error from authorization endpoint
2020-07-31 12:28:35 SUCCESS
CheckMatchingStateParameter
State parameter correctly returned
state
OUHXf3ZMP9
2020-07-31 12:28:35 SUCCESS
ExtractAuthorizationCodeFromAuthorizationResponse
Found authorization code
code
p_XSIxVhFZI94HR_bF-3RA2_uHYESaogLWKXLcPqG7I
2020-07-31 12:28:35 SUCCESS
ExtractAccessTokenFromAuthorizationResponse
Extracted the access token
value
eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDkxNSwiaWF0IjoxNTk2MTk4NTE1LCJjbGllbnRfaWQiOiI0NzA1NTMzMzE2MDQ2MzIiLCJqdGkiOiJfRFI4aWtWY1hwZWJRYUZBRVhpZENGd25YRHgzSE81YUtFSHZIZEJkYlo4In0.b3nc6b4F5GqQlku2e_Q64lzdRw_WY-5lhNDsyANvAIDkZNlXXUXAAxb2rf5f3erlOTOaVHyMUBiwJ2-ITSRy-ISzxZLafImNsHhkc3KN9-4vDDjq9sKizdn4oSFeG4FASNb6HWPziH05Z-3Pist9Sl1ROHU2JZBu--oh8tjq5p5i_8gb8gzW9d5DGAZoXncMCRrBo1RRQVjbu97EDErMC3itonkh5FOfzjKFmyd5a6vl_2ELMb4rbRGKwa_TsUNn_f4exmaPLH_zN3mE-CW_CuzPENiJPv3sHoJzWqXeSbCNyw9AtUcpxbywiKvgvgmdQceguoRi3nYc-I9IP53LvA
type
Bearer
Second client: Userinfo endpoint tests
2020-07-31 12:28:35
CallProtectedResourceWithBearerToken
HTTP request
request_uri
https://fapidev-rs.authlete.net/api/userinfo
request_method
GET
request_headers
{
  "accept": "application/json;charset\u003dUTF-8",
  "authorization": "Bearer eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDkxNSwiaWF0IjoxNTk2MTk4NTE1LCJjbGllbnRfaWQiOiI0NzA1NTMzMzE2MDQ2MzIiLCJqdGkiOiJfRFI4aWtWY1hwZWJRYUZBRVhpZENGd25YRHgzSE81YUtFSHZIZEJkYlo4In0.b3nc6b4F5GqQlku2e_Q64lzdRw_WY-5lhNDsyANvAIDkZNlXXUXAAxb2rf5f3erlOTOaVHyMUBiwJ2-ITSRy-ISzxZLafImNsHhkc3KN9-4vDDjq9sKizdn4oSFeG4FASNb6HWPziH05Z-3Pist9Sl1ROHU2JZBu--oh8tjq5p5i_8gb8gzW9d5DGAZoXncMCRrBo1RRQVjbu97EDErMC3itonkh5FOfzjKFmyd5a6vl_2ELMb4rbRGKwa_TsUNn_f4exmaPLH_zN3mE-CW_CuzPENiJPv3sHoJzWqXeSbCNyw9AtUcpxbywiKvgvgmdQceguoRi3nYc-I9IP53LvA",
  "accept-charset": "utf-8",
  "content-length": "0"
}
request_body

                                
2020-07-31 12:28:35 INFO
WebRunner
Completed processing of webpage
task
Verify Complete
browser
complete
response_status_text
200-
match
https://*/test/a/oidf-authlete-core/callback*
url
https://www.certification.openid.net/test/a/oidf-authlete-core/callback
response_status_code
200
2020-07-31 12:28:35 RESPONSE
CallProtectedResourceWithBearerToken
HTTP response
response_status_code
200 OK
response_status_text
OK
response_headers
{
  "date": "Fri, 31 Jul 2020 12:28:35 GMT",
  "server": "Jetty(9.4.21-SNAPSHOT)",
  "cache-control": "no-store, no-transform",
  "pragma": "no-cache",
  "content-type": "application/json;charset\u003dutf-8",
  "content-length": "14",
  "keep-alive": "timeout\u003d5, max\u003d100",
  "connection": "Keep-Alive"
}
response_body
{"sub":"1001"}
2020-07-31 12:28:35 SUCCESS
CallProtectedResourceWithBearerToken
Got a response from the resource endpoint
headers
{
  "date": "Fri, 31 Jul 2020 12:28:35 GMT",
  "server": "Jetty(9.4.21-SNAPSHOT)",
  "cache-control": "no-store, no-transform",
  "pragma": "no-cache",
  "content-type": "application/json;charset\u003dutf-8",
  "content-length": "14",
  "keep-alive": "timeout\u003d5, max\u003d100",
  "connection": "Keep-Alive"
}
status_code
{
  "code": 200
}
body
{"sub":"1001"}
2020-07-31 12:28:35 SUCCESS
CreateTokenEndpointRequestForAuthorizationCodeGrant
grant_type
authorization_code
code
p_XSIxVhFZI94HR_bF-3RA2_uHYESaogLWKXLcPqG7I
redirect_uri
https://www.certification.openid.net/test/a/oidf-authlete-core/callback
2020-07-31 12:28:35 SUCCESS
AddBasicAuthClientSecretAuthenticationParameters
Added basic authorization header
Authorization
Basic NDcwNTUzMzMxNjA0NjMyOjNOTGV6U0ZPanl4dUVScF9jSDN6Rk1ieW05b051cjNOTWRZSUpXaW1pVEhFS1JPdnNEVFQxLUJWZm84QWJMTmlVZ3lJYmJHY3I3OW43ZmtUTDdEOHFB
2020-07-31 12:28:36
CallTokenEndpoint
HTTP request
request_uri
https://fapidev-as.authlete.net/api/token
request_method
POST
request_headers
{
  "accept": "application/json;charset\u003dUTF-8",
  "authorization": "Basic NDcwNTUzMzMxNjA0NjMyOjNOTGV6U0ZPanl4dUVScF9jSDN6Rk1ieW05b051cjNOTWRZSUpXaW1pVEhFS1JPdnNEVFQxLUJWZm84QWJMTmlVZ3lJYmJHY3I3OW43ZmtUTDdEOHFB",
  "accept-charset": "utf-8",
  "content-type": "application/x-www-form-urlencoded;charset\u003dUTF-8",
  "content-length": "177"
}
request_body
grant_type=authorization_code&code=p_XSIxVhFZI94HR_bF-3RA2_uHYESaogLWKXLcPqG7I&redirect_uri=https%3A%2F%2Fwww.certification.openid.net%2Ftest%2Fa%2Foidf-authlete-core%2Fcallback
2020-07-31 12:28:36 RESPONSE
CallTokenEndpoint
HTTP response
response_status_code
200 OK
response_status_text
OK
response_headers
{
  "date": "Fri, 31 Jul 2020 12:28:36 GMT",
  "server": "Jetty(9.4.21-SNAPSHOT)",
  "cache-control": "no-store, no-transform",
  "pragma": "no-cache",
  "content-type": "application/json;charset\u003dutf-8",
  "content-length": "1547",
  "keep-alive": "timeout\u003d5, max\u003d100",
  "connection": "Keep-Alive"
}
response_body
{"access_token":"eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDkxNiwiaWF0IjoxNTk2MTk4NTE2LCJjbGllbnRfaWQiOiI0NzA1NTMzMzE2MDQ2MzIiLCJqdGkiOiJkRE83RXd2WGpQUVVJMnJXZ25MRmNhSTRfS3M5Ry1PZUl4RmJ5ZHVHYjJzIn0.LbE31LyJK5smwHtVtGaUWjkJAzKhgPo96XLqWSZilHmHR1vMRYJ87UEM8R-2k6M_par80n20G8Ai2E0tPR210wTK5jaUsS0dyBXvjOhPq3HLsC8Ec-YnJylxIqZPqh1Sue90g1XvA3EQA_ySPXsIaPT0i0_T-E_CM6E7kpsAxvtGnYar7Bl6pUlrcs4MRQQuaZ22YwpMxA9ygu4ccKEqvXeYds8U2nYs_YZQh5wx49vU47fVCpZwUmbtbRewLRw_qgiqMd0K6eWdRWdb-G3F0NAmHztUQj3KDW0M9eE6jGeCWL10Kb3-glzEsZWLn2aCxQcyp6HD1psQLQgswOUDxA","refresh_token":"54M5qvzDogpIgLsp8Y5xvOVVN0Ns37kmavq8klhFWvg","scope":"offline_access openid","id_token":"eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDU1MzMzMTYwNDYzMiJdLCJzX2hhc2giOiJ6SGdVWXNxRi14ZDNVTWJKeXZDVDZBIiwiYXV0aF90aW1lIjoxNTk2MTk4NTExLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODgxNiwiaWF0IjoxNTk2MTk4NTE2LCJub25jZSI6IjhyWTZoSG96QmMifQ.LeeuZKA8YuToOg8XHpEqxTk4f7phlodoRSi7rIscwlUgge1sqlECE6wY59_tKRm-AI9MtXBvuTkCYNOV_1MfkHLAjQ0mXuVQH2T33ZOmY70VpA5cnzkju5vs9ko3zL7B1uHmslHEZjjsb1xrii-4fVRcbvoqKDl0syRgL_ar2ERFRrS8SvRYlsszncw4WED58SEBRgHSi9MhtO1URZsZvNV4Ce3w6G2HDFGo73SdfK-tv5m69uqHxX08aNvXCmmFKNwgfVQiYsyTG0T6fXNSyAQqyIKMFLGYRpaUdALXruaWVvmA3x_jEC9tlDOkOjuopzh3Eci-eB6PahlLr3zrsA","token_type":"Bearer","expires_in":86400}
2020-07-31 12:28:36
CallTokenEndpoint
Token endpoint response
token_endpoint_response
{"access_token":"eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDkxNiwiaWF0IjoxNTk2MTk4NTE2LCJjbGllbnRfaWQiOiI0NzA1NTMzMzE2MDQ2MzIiLCJqdGkiOiJkRE83RXd2WGpQUVVJMnJXZ25MRmNhSTRfS3M5Ry1PZUl4RmJ5ZHVHYjJzIn0.LbE31LyJK5smwHtVtGaUWjkJAzKhgPo96XLqWSZilHmHR1vMRYJ87UEM8R-2k6M_par80n20G8Ai2E0tPR210wTK5jaUsS0dyBXvjOhPq3HLsC8Ec-YnJylxIqZPqh1Sue90g1XvA3EQA_ySPXsIaPT0i0_T-E_CM6E7kpsAxvtGnYar7Bl6pUlrcs4MRQQuaZ22YwpMxA9ygu4ccKEqvXeYds8U2nYs_YZQh5wx49vU47fVCpZwUmbtbRewLRw_qgiqMd0K6eWdRWdb-G3F0NAmHztUQj3KDW0M9eE6jGeCWL10Kb3-glzEsZWLn2aCxQcyp6HD1psQLQgswOUDxA","refresh_token":"54M5qvzDogpIgLsp8Y5xvOVVN0Ns37kmavq8klhFWvg","scope":"offline_access openid","id_token":"eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDU1MzMzMTYwNDYzMiJdLCJzX2hhc2giOiJ6SGdVWXNxRi14ZDNVTWJKeXZDVDZBIiwiYXV0aF90aW1lIjoxNTk2MTk4NTExLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODgxNiwiaWF0IjoxNTk2MTk4NTE2LCJub25jZSI6IjhyWTZoSG96QmMifQ.LeeuZKA8YuToOg8XHpEqxTk4f7phlodoRSi7rIscwlUgge1sqlECE6wY59_tKRm-AI9MtXBvuTkCYNOV_1MfkHLAjQ0mXuVQH2T33ZOmY70VpA5cnzkju5vs9ko3zL7B1uHmslHEZjjsb1xrii-4fVRcbvoqKDl0syRgL_ar2ERFRrS8SvRYlsszncw4WED58SEBRgHSi9MhtO1URZsZvNV4Ce3w6G2HDFGo73SdfK-tv5m69uqHxX08aNvXCmmFKNwgfVQiYsyTG0T6fXNSyAQqyIKMFLGYRpaUdALXruaWVvmA3x_jEC9tlDOkOjuopzh3Eci-eB6PahlLr3zrsA","token_type":"Bearer","expires_in":86400}
2020-07-31 12:28:36 SUCCESS
CallTokenEndpoint
Parsed token endpoint response
access_token
eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDkxNiwiaWF0IjoxNTk2MTk4NTE2LCJjbGllbnRfaWQiOiI0NzA1NTMzMzE2MDQ2MzIiLCJqdGkiOiJkRE83RXd2WGpQUVVJMnJXZ25MRmNhSTRfS3M5Ry1PZUl4RmJ5ZHVHYjJzIn0.LbE31LyJK5smwHtVtGaUWjkJAzKhgPo96XLqWSZilHmHR1vMRYJ87UEM8R-2k6M_par80n20G8Ai2E0tPR210wTK5jaUsS0dyBXvjOhPq3HLsC8Ec-YnJylxIqZPqh1Sue90g1XvA3EQA_ySPXsIaPT0i0_T-E_CM6E7kpsAxvtGnYar7Bl6pUlrcs4MRQQuaZ22YwpMxA9ygu4ccKEqvXeYds8U2nYs_YZQh5wx49vU47fVCpZwUmbtbRewLRw_qgiqMd0K6eWdRWdb-G3F0NAmHztUQj3KDW0M9eE6jGeCWL10Kb3-glzEsZWLn2aCxQcyp6HD1psQLQgswOUDxA
refresh_token
54M5qvzDogpIgLsp8Y5xvOVVN0Ns37kmavq8klhFWvg
scope
offline_access openid
id_token
eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDU1MzMzMTYwNDYzMiJdLCJzX2hhc2giOiJ6SGdVWXNxRi14ZDNVTWJKeXZDVDZBIiwiYXV0aF90aW1lIjoxNTk2MTk4NTExLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODgxNiwiaWF0IjoxNTk2MTk4NTE2LCJub25jZSI6IjhyWTZoSG96QmMifQ.LeeuZKA8YuToOg8XHpEqxTk4f7phlodoRSi7rIscwlUgge1sqlECE6wY59_tKRm-AI9MtXBvuTkCYNOV_1MfkHLAjQ0mXuVQH2T33ZOmY70VpA5cnzkju5vs9ko3zL7B1uHmslHEZjjsb1xrii-4fVRcbvoqKDl0syRgL_ar2ERFRrS8SvRYlsszncw4WED58SEBRgHSi9MhtO1URZsZvNV4Ce3w6G2HDFGo73SdfK-tv5m69uqHxX08aNvXCmmFKNwgfVQiYsyTG0T6fXNSyAQqyIKMFLGYRpaUdALXruaWVvmA3x_jEC9tlDOkOjuopzh3Eci-eB6PahlLr3zrsA
token_type
Bearer
expires_in
86400
2020-07-31 12:28:36 SUCCESS
CheckIfTokenEndpointResponseError
No error from token endpoint
2020-07-31 12:28:36 SUCCESS
CheckForAccessTokenValue
Found an access token
access_token
eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDkxNiwiaWF0IjoxNTk2MTk4NTE2LCJjbGllbnRfaWQiOiI0NzA1NTMzMzE2MDQ2MzIiLCJqdGkiOiJkRE83RXd2WGpQUVVJMnJXZ25MRmNhSTRfS3M5Ry1PZUl4RmJ5ZHVHYjJzIn0.LbE31LyJK5smwHtVtGaUWjkJAzKhgPo96XLqWSZilHmHR1vMRYJ87UEM8R-2k6M_par80n20G8Ai2E0tPR210wTK5jaUsS0dyBXvjOhPq3HLsC8Ec-YnJylxIqZPqh1Sue90g1XvA3EQA_ySPXsIaPT0i0_T-E_CM6E7kpsAxvtGnYar7Bl6pUlrcs4MRQQuaZ22YwpMxA9ygu4ccKEqvXeYds8U2nYs_YZQh5wx49vU47fVCpZwUmbtbRewLRw_qgiqMd0K6eWdRWdb-G3F0NAmHztUQj3KDW0M9eE6jGeCWL10Kb3-glzEsZWLn2aCxQcyp6HD1psQLQgswOUDxA
2020-07-31 12:28:36 SUCCESS
ExtractAccessTokenFromTokenResponse
Extracted the access token
value
eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDkxNiwiaWF0IjoxNTk2MTk4NTE2LCJjbGllbnRfaWQiOiI0NzA1NTMzMzE2MDQ2MzIiLCJqdGkiOiJkRE83RXd2WGpQUVVJMnJXZ25MRmNhSTRfS3M5Ry1PZUl4RmJ5ZHVHYjJzIn0.LbE31LyJK5smwHtVtGaUWjkJAzKhgPo96XLqWSZilHmHR1vMRYJ87UEM8R-2k6M_par80n20G8Ai2E0tPR210wTK5jaUsS0dyBXvjOhPq3HLsC8Ec-YnJylxIqZPqh1Sue90g1XvA3EQA_ySPXsIaPT0i0_T-E_CM6E7kpsAxvtGnYar7Bl6pUlrcs4MRQQuaZ22YwpMxA9ygu4ccKEqvXeYds8U2nYs_YZQh5wx49vU47fVCpZwUmbtbRewLRw_qgiqMd0K6eWdRWdb-G3F0NAmHztUQj3KDW0M9eE6jGeCWL10Kb3-glzEsZWLn2aCxQcyp6HD1psQLQgswOUDxA
type
Bearer
2020-07-31 12:28:36 SUCCESS
ExtractExpiresInFromTokenEndpointResponse
Extracted 'expires_in'
expires_in
86400
2020-07-31 12:28:36 SUCCESS
ValidateExpiresIn
expires_in passed all validation checks
expires_in
86400
2020-07-31 12:28:36 SUCCESS
CheckForRefreshTokenValue
Found a refresh token
refresh_token
54M5qvzDogpIgLsp8Y5xvOVVN0Ns37kmavq8klhFWvg
2020-07-31 12:28:36 SUCCESS
ExtractIdTokenFromTokenResponse
Found and parsed the id_token from token_endpoint_response
value
eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDU1MzMzMTYwNDYzMiJdLCJzX2hhc2giOiJ6SGdVWXNxRi14ZDNVTWJKeXZDVDZBIiwiYXV0aF90aW1lIjoxNTk2MTk4NTExLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODgxNiwiaWF0IjoxNTk2MTk4NTE2LCJub25jZSI6IjhyWTZoSG96QmMifQ.LeeuZKA8YuToOg8XHpEqxTk4f7phlodoRSi7rIscwlUgge1sqlECE6wY59_tKRm-AI9MtXBvuTkCYNOV_1MfkHLAjQ0mXuVQH2T33ZOmY70VpA5cnzkju5vs9ko3zL7B1uHmslHEZjjsb1xrii-4fVRcbvoqKDl0syRgL_ar2ERFRrS8SvRYlsszncw4WED58SEBRgHSi9MhtO1URZsZvNV4Ce3w6G2HDFGo73SdfK-tv5m69uqHxX08aNvXCmmFKNwgfVQiYsyTG0T6fXNSyAQqyIKMFLGYRpaUdALXruaWVvmA3x_jEC9tlDOkOjuopzh3Eci-eB6PahlLr3zrsA
header
{
  "kid": "authlete-fapidev-api-20180524",
  "alg": "RS256"
}
claims
{
  "sub": "1001",
  "aud": "470553331604632",
  "s_hash": "zHgUYsqF-xd3UMbJyvCT6A",
  "auth_time": 1596198511,
  "iss": "https://fapidev-as.authlete.net/",
  "exp": 1596198816,
  "iat": 1596198516,
  "nonce": "8rY6hHozBc"
}
2020-07-31 12:28:36 SUCCESS
ValidateIdToken
ID token iss, aud, exp, iat, auth_time, acr & nbf claims passed validation checks
2020-07-31 12:28:36 SUCCESS
ValidateIdTokenNonce
Nonce values match
nonce
8rY6hHozBc
2020-07-31 12:28:36 SUCCESS
ValidateIdTokenACRClaimAgainstRequest
Nothing to check; the conformance suite did not request an acr claim in request object
2020-07-31 12:28:36 SUCCESS
ValidateIdTokenSignature
id_token signature validated
id_token
eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDU1MzMzMTYwNDYzMiJdLCJzX2hhc2giOiJ6SGdVWXNxRi14ZDNVTWJKeXZDVDZBIiwiYXV0aF90aW1lIjoxNTk2MTk4NTExLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODgxNiwiaWF0IjoxNTk2MTk4NTE2LCJub25jZSI6IjhyWTZoSG96QmMifQ.LeeuZKA8YuToOg8XHpEqxTk4f7phlodoRSi7rIscwlUgge1sqlECE6wY59_tKRm-AI9MtXBvuTkCYNOV_1MfkHLAjQ0mXuVQH2T33ZOmY70VpA5cnzkju5vs9ko3zL7B1uHmslHEZjjsb1xrii-4fVRcbvoqKDl0syRgL_ar2ERFRrS8SvRYlsszncw4WED58SEBRgHSi9MhtO1URZsZvNV4Ce3w6G2HDFGo73SdfK-tv5m69uqHxX08aNvXCmmFKNwgfVQiYsyTG0T6fXNSyAQqyIKMFLGYRpaUdALXruaWVvmA3x_jEC9tlDOkOjuopzh3Eci-eB6PahlLr3zrsA
2020-07-31 12:28:36 SUCCESS
ValidateIdTokenSignatureUsingKid
id_token signature validated
id_token
eyJraWQiOiJhdXRobGV0ZS1mYXBpZGV2LWFwaS0yMDE4MDUyNCIsImFsZyI6IlJTMjU2In0.eyJzdWIiOiIxMDAxIiwiYXVkIjpbIjQ3MDU1MzMzMTYwNDYzMiJdLCJzX2hhc2giOiJ6SGdVWXNxRi14ZDNVTWJKeXZDVDZBIiwiYXV0aF90aW1lIjoxNTk2MTk4NTExLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjE5ODgxNiwiaWF0IjoxNTk2MTk4NTE2LCJub25jZSI6IjhyWTZoSG96QmMifQ.LeeuZKA8YuToOg8XHpEqxTk4f7phlodoRSi7rIscwlUgge1sqlECE6wY59_tKRm-AI9MtXBvuTkCYNOV_1MfkHLAjQ0mXuVQH2T33ZOmY70VpA5cnzkju5vs9ko3zL7B1uHmslHEZjjsb1xrii-4fVRcbvoqKDl0syRgL_ar2ERFRrS8SvRYlsszncw4WED58SEBRgHSi9MhtO1URZsZvNV4Ce3w6G2HDFGo73SdfK-tv5m69uqHxX08aNvXCmmFKNwgfVQiYsyTG0T6fXNSyAQqyIKMFLGYRpaUdALXruaWVvmA3x_jEC9tlDOkOjuopzh3Eci-eB6PahlLr3zrsA
2020-07-31 12:28:36 SUCCESS
CheckForSubjectInIdToken
Found 'sub' in id_token
sub
1001
2020-07-31 12:28:36 SUCCESS
ExtractRefreshTokenFromTokenResponse
Extracted refresh token from response
refresh_token
54M5qvzDogpIgLsp8Y5xvOVVN0Ns37kmavq8klhFWvg
2020-07-31 12:28:36 SUCCESS
EnsureRefreshTokenContainsAllowedCharactersOnly
Refresh token does not contain any illegal characters
Second client: Refresh Token Request
2020-07-31 12:28:36 SUCCESS
CreateRefreshTokenRequest
Created token endpoint request parameters
grant_type
refresh_token
refresh_token
54M5qvzDogpIgLsp8Y5xvOVVN0Ns37kmavq8klhFWvg
2020-07-31 12:28:36 SUCCESS
AddBasicAuthClientSecretAuthenticationParameters
Added basic authorization header
Authorization
Basic NDcwNTUzMzMxNjA0NjMyOjNOTGV6U0ZPanl4dUVScF9jSDN6Rk1ieW05b051cjNOTWRZSUpXaW1pVEhFS1JPdnNEVFQxLUJWZm84QWJMTmlVZ3lJYmJHY3I3OW43ZmtUTDdEOHFB
2020-07-31 12:28:36 SUCCESS
WaitForOneSecond
Pausing for 1 seconds
2020-07-31 12:28:37 SUCCESS
WaitForOneSecond
Woke up after 1 seconds sleep
2020-07-31 12:28:37
CallTokenEndpointAndReturnFullResponse
HTTP request
request_uri
https://fapidev-as.authlete.net/api/token
request_method
POST
request_headers
{
  "accept": "application/json;charset\u003dUTF-8",
  "authorization": "Basic NDcwNTUzMzMxNjA0NjMyOjNOTGV6U0ZPanl4dUVScF9jSDN6Rk1ieW05b051cjNOTWRZSUpXaW1pVEhFS1JPdnNEVFQxLUJWZm84QWJMTmlVZ3lJYmJHY3I3OW43ZmtUTDdEOHFB",
  "accept-charset": "utf-8",
  "content-type": "application/x-www-form-urlencoded;charset\u003dUTF-8",
  "content-length": "82"
}
request_body
grant_type=refresh_token&refresh_token=54M5qvzDogpIgLsp8Y5xvOVVN0Ns37kmavq8klhFWvg
2020-07-31 12:28:37 RESPONSE
CallTokenEndpointAndReturnFullResponse
HTTP response
response_status_code
200 OK
response_status_text
OK
response_headers
{
  "date": "Fri, 31 Jul 2020 12:28:37 GMT",
  "server": "Jetty(9.4.21-SNAPSHOT)",
  "cache-control": "no-store, no-transform",
  "pragma": "no-cache",
  "content-type": "application/json;charset\u003dutf-8",
  "content-length": "860",
  "keep-alive": "timeout\u003d5, max\u003d100",
  "connection": "Keep-Alive"
}
response_body
{"access_token":"eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvcGVuaWQgb2ZmbGluZV9hY2Nlc3MiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDkxNywiaWF0IjoxNTk2MTk4NTE3LCJjbGllbnRfaWQiOiI0NzA1NTMzMzE2MDQ2MzIiLCJqdGkiOiJ6VDNvanlPMW1ETXNvM3VSVDItX3NhdjBJUkRIcWlrcm9pNmstNjJXQXY4In0.Y7wtUPRpZGUbIbauNpeP1iKs3v0IEyBvxzzb284yt7g8me_DfmDJo6fKYl6dkz83JFSWLlFejKrm3ZjZapf9Zx_gIGHKNvlqnPb7jJF2GnP4LjhBPPNn2wbO5-w3BGx8KSRdF5TApDlL9P3S3GgylFD_2WGA_kfdSHufaTz5BB_aNPTJOlks7QnzNOQYqggW6gxrWs--vUUUCT2UNWh0zyU6ZiaqdD_7vLHm-1YqsHHBaQ5soNjNUaCd5X7uEs8IKaXpilkj37lIr76u--8aYvV3BbkIxg4yeRtrmnV9mM-vjihd9n4KRf5cdl3XY3CHXOqu8geJJ_U1B8ZwIl5zUw","refresh_token":"qRH5WeWpvu6_lPbRKA4a9bPU2VgyRJtveTYwgorIlqs","scope":"openid offline_access","token_type":"Bearer","expires_in":86400}
2020-07-31 12:28:37 SUCCESS
CallTokenEndpointAndReturnFullResponse
Parsed token endpoint response
access_token
eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvcGVuaWQgb2ZmbGluZV9hY2Nlc3MiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDkxNywiaWF0IjoxNTk2MTk4NTE3LCJjbGllbnRfaWQiOiI0NzA1NTMzMzE2MDQ2MzIiLCJqdGkiOiJ6VDNvanlPMW1ETXNvM3VSVDItX3NhdjBJUkRIcWlrcm9pNmstNjJXQXY4In0.Y7wtUPRpZGUbIbauNpeP1iKs3v0IEyBvxzzb284yt7g8me_DfmDJo6fKYl6dkz83JFSWLlFejKrm3ZjZapf9Zx_gIGHKNvlqnPb7jJF2GnP4LjhBPPNn2wbO5-w3BGx8KSRdF5TApDlL9P3S3GgylFD_2WGA_kfdSHufaTz5BB_aNPTJOlks7QnzNOQYqggW6gxrWs--vUUUCT2UNWh0zyU6ZiaqdD_7vLHm-1YqsHHBaQ5soNjNUaCd5X7uEs8IKaXpilkj37lIr76u--8aYvV3BbkIxg4yeRtrmnV9mM-vjihd9n4KRf5cdl3XY3CHXOqu8geJJ_U1B8ZwIl5zUw
refresh_token
qRH5WeWpvu6_lPbRKA4a9bPU2VgyRJtveTYwgorIlqs
scope
openid offline_access
token_type
Bearer
expires_in
86400
2020-07-31 12:28:37 SUCCESS
CheckTokenEndpointHttpStatus200
Token endpoint http status code was 200
2020-07-31 12:28:37 SUCCESS
CheckTokenEndpointReturnedJsonContentType
token_endpoint_response_headers Content-Type: header is application/json
2020-07-31 12:28:37 SUCCESS
CheckTokenEndpointCacheHeaders
Checked 'pragma' and 'cache-control' in the headers of token_endpoint_response.
2020-07-31 12:28:37 SUCCESS
CheckIfTokenEndpointResponseError
No error from token endpoint
2020-07-31 12:28:37 SUCCESS
ExtractAccessTokenFromTokenResponse
Extracted the access token
value
eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvcGVuaWQgb2ZmbGluZV9hY2Nlc3MiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDkxNywiaWF0IjoxNTk2MTk4NTE3LCJjbGllbnRfaWQiOiI0NzA1NTMzMzE2MDQ2MzIiLCJqdGkiOiJ6VDNvanlPMW1ETXNvM3VSVDItX3NhdjBJUkRIcWlrcm9pNmstNjJXQXY4In0.Y7wtUPRpZGUbIbauNpeP1iKs3v0IEyBvxzzb284yt7g8me_DfmDJo6fKYl6dkz83JFSWLlFejKrm3ZjZapf9Zx_gIGHKNvlqnPb7jJF2GnP4LjhBPPNn2wbO5-w3BGx8KSRdF5TApDlL9P3S3GgylFD_2WGA_kfdSHufaTz5BB_aNPTJOlks7QnzNOQYqggW6gxrWs--vUUUCT2UNWh0zyU6ZiaqdD_7vLHm-1YqsHHBaQ5soNjNUaCd5X7uEs8IKaXpilkj37lIr76u--8aYvV3BbkIxg4yeRtrmnV9mM-vjihd9n4KRf5cdl3XY3CHXOqu8geJJ_U1B8ZwIl5zUw
type
Bearer
2020-07-31 12:28:37 SUCCESS
CheckTokenTypeIsBearer
Token type is bearer
2020-07-31 12:28:37 SUCCESS
EnsureMinimumAccessTokenEntropy
Calculated shannon entropy seems sufficient
actual
4159.820957519061
expected
96.0
2020-07-31 12:28:37 SUCCESS
EnsureAccessTokenContainsAllowedCharactersOnly
Access token does not contain any illegal characters
2020-07-31 12:28:37 SUCCESS
ExtractExpiresInFromTokenEndpointResponse
Extracted 'expires_in'
expires_in
86400
2020-07-31 12:28:37 SUCCESS
ValidateExpiresIn
expires_in passed all validation checks
expires_in
86400
2020-07-31 12:28:37 SUCCESS
EnsureAccessTokenValuesAreDifferent
Access token values are not the same
first_access_token
eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvZmZsaW5lX2FjY2VzcyBvcGVuaWQiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDkxNiwiaWF0IjoxNTk2MTk4NTE2LCJjbGllbnRfaWQiOiI0NzA1NTMzMzE2MDQ2MzIiLCJqdGkiOiJkRE83RXd2WGpQUVVJMnJXZ25MRmNhSTRfS3M5Ry1PZUl4RmJ5ZHVHYjJzIn0.LbE31LyJK5smwHtVtGaUWjkJAzKhgPo96XLqWSZilHmHR1vMRYJ87UEM8R-2k6M_par80n20G8Ai2E0tPR210wTK5jaUsS0dyBXvjOhPq3HLsC8Ec-YnJylxIqZPqh1Sue90g1XvA3EQA_ySPXsIaPT0i0_T-E_CM6E7kpsAxvtGnYar7Bl6pUlrcs4MRQQuaZ22YwpMxA9ygu4ccKEqvXeYds8U2nYs_YZQh5wx49vU47fVCpZwUmbtbRewLRw_qgiqMd0K6eWdRWdb-G3F0NAmHztUQj3KDW0M9eE6jGeCWL10Kb3-glzEsZWLn2aCxQcyp6HD1psQLQgswOUDxA
second_access_token
eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvcGVuaWQgb2ZmbGluZV9hY2Nlc3MiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDkxNywiaWF0IjoxNTk2MTk4NTE3LCJjbGllbnRfaWQiOiI0NzA1NTMzMzE2MDQ2MzIiLCJqdGkiOiJ6VDNvanlPMW1ETXNvM3VSVDItX3NhdjBJUkRIcWlrcm9pNmstNjJXQXY4In0.Y7wtUPRpZGUbIbauNpeP1iKs3v0IEyBvxzzb284yt7g8me_DfmDJo6fKYl6dkz83JFSWLlFejKrm3ZjZapf9Zx_gIGHKNvlqnPb7jJF2GnP4LjhBPPNn2wbO5-w3BGx8KSRdF5TApDlL9P3S3GgylFD_2WGA_kfdSHufaTz5BB_aNPTJOlks7QnzNOQYqggW6gxrWs--vUUUCT2UNWh0zyU6ZiaqdD_7vLHm-1YqsHHBaQ5soNjNUaCd5X7uEs8IKaXpilkj37lIr76u--8aYvV3BbkIxg4yeRtrmnV9mM-vjihd9n4KRf5cdl3XY3CHXOqu8geJJ_U1B8ZwIl5zUw
2020-07-31 12:28:37 INFO
ExtractIdTokenFromTokenResponse
Couldn't find id_token in token_endpoint_response
2020-07-31 12:28:37 SUCCESS
ExtractRefreshTokenFromTokenResponse
Extracted refresh token from response
refresh_token
qRH5WeWpvu6_lPbRKA4a9bPU2VgyRJtveTYwgorIlqs
2020-07-31 12:28:37 SUCCESS
EnsureMinimumRefreshTokenLength
Refresh token is of sufficient length
actual
344
required
128
2020-07-31 12:28:37 SUCCESS
EnsureMinimumRefreshTokenEntropy
Calculated shannon entropy seems sufficient
actual
212.5744969500267
expected
96.0
2020-07-31 12:28:37 INFO
CompareIdTokenClaims
Skipped evaluation due to missing required object: second_id_token
expected
second_id_token
mapped
second_id_token
Second client: Userinfo endpoint tests
2020-07-31 12:28:37
CallProtectedResourceWithBearerToken
HTTP request
request_uri
https://fapidev-rs.authlete.net/api/userinfo
request_method
GET
request_headers
{
  "accept": "application/json;charset\u003dUTF-8",
  "authorization": "Bearer eyJhbGciOiJQUzI1NiIsInR5cCI6ImF0K2p3dCIsImtpZCI6ImF1dGhsZXRlLWZhcGlkZXYtYXBpLTIwMTgwNTI0In0.eyJzdWIiOiIxMDAxIiwic2NvcGUiOiJvcGVuaWQgb2ZmbGluZV9hY2Nlc3MiLCJpc3MiOiJodHRwczovL2ZhcGlkZXYtYXMuYXV0aGxldGUubmV0LyIsImV4cCI6MTU5NjI4NDkxNywiaWF0IjoxNTk2MTk4NTE3LCJjbGllbnRfaWQiOiI0NzA1NTMzMzE2MDQ2MzIiLCJqdGkiOiJ6VDNvanlPMW1ETXNvM3VSVDItX3NhdjBJUkRIcWlrcm9pNmstNjJXQXY4In0.Y7wtUPRpZGUbIbauNpeP1iKs3v0IEyBvxzzb284yt7g8me_DfmDJo6fKYl6dkz83JFSWLlFejKrm3ZjZapf9Zx_gIGHKNvlqnPb7jJF2GnP4LjhBPPNn2wbO5-w3BGx8KSRdF5TApDlL9P3S3GgylFD_2WGA_kfdSHufaTz5BB_aNPTJOlks7QnzNOQYqggW6gxrWs--vUUUCT2UNWh0zyU6ZiaqdD_7vLHm-1YqsHHBaQ5soNjNUaCd5X7uEs8IKaXpilkj37lIr76u--8aYvV3BbkIxg4yeRtrmnV9mM-vjihd9n4KRf5cdl3XY3CHXOqu8geJJ_U1B8ZwIl5zUw",
  "accept-charset": "utf-8",
  "content-length": "0"
}
request_body

                                
2020-07-31 12:28:38 RESPONSE
CallProtectedResourceWithBearerToken
HTTP response
response_status_code
200 OK
response_status_text
OK
response_headers
{
  "date": "Fri, 31 Jul 2020 12:28:38 GMT",
  "server": "Jetty(9.4.21-SNAPSHOT)",
  "cache-control": "no-store, no-transform",
  "pragma": "no-cache",
  "content-type": "application/json;charset\u003dutf-8",
  "content-length": "14",
  "keep-alive": "timeout\u003d5, max\u003d100",
  "connection": "Keep-Alive"
}
response_body
{"sub":"1001"}
2020-07-31 12:28:38 SUCCESS
CallProtectedResourceWithBearerToken
Got a response from the resource endpoint
headers
{
  "date": "Fri, 31 Jul 2020 12:28:38 GMT",
  "server": "Jetty(9.4.21-SNAPSHOT)",
  "cache-control": "no-store, no-transform",
  "pragma": "no-cache",
  "content-type": "application/json;charset\u003dutf-8",
  "content-length": "14",
  "keep-alive": "timeout\u003d5, max\u003d100",
  "connection": "Keep-Alive"
}
status_code
{
  "code": 200
}
body
{"sub":"1001"}
Attempting to use refresh_token issued to client 2 with client 1
2020-07-31 12:28:38 SUCCESS
CreateRefreshTokenRequest
Created token endpoint request parameters
grant_type
refresh_token
refresh_token
qRH5WeWpvu6_lPbRKA4a9bPU2VgyRJtveTYwgorIlqs
2020-07-31 12:28:38 SUCCESS
AddScopeToTokenEndpointRequest
Added scope of 'openid offline_access' to token endpoint request
grant_type
refresh_token
refresh_token
qRH5WeWpvu6_lPbRKA4a9bPU2VgyRJtveTYwgorIlqs
scope
openid offline_access
2020-07-31 12:28:38 SUCCESS
AddBasicAuthClientSecretAuthenticationParameters
Added basic authorization header
Authorization
Basic NDcwNTE5ODI0MTgwMzE3OkVrMkNpdU9ybWZkaHZzakdsMDM3X3BzY0NtWXNla3M0YnpTU3hjM1VaVWNyLTlLaTJybENSZGdfTXQtVWtjOWItTHBham5NVWN3bXpxZ1hzLWVES3p3
2020-07-31 12:28:38
CallTokenEndpointAndReturnFullResponse
HTTP request
request_uri
https://fapidev-as.authlete.net/api/token
request_method
POST
request_headers
{
  "accept": "application/json;charset\u003dUTF-8",
  "authorization": "Basic NDcwNTE5ODI0MTgwMzE3OkVrMkNpdU9ybWZkaHZzakdsMDM3X3BzY0NtWXNla3M0YnpTU3hjM1VaVWNyLTlLaTJybENSZGdfTXQtVWtjOWItTHBham5NVWN3bXpxZ1hzLWVES3p3",
  "accept-charset": "utf-8",
  "content-type": "application/x-www-form-urlencoded;charset\u003dUTF-8",
  "content-length": "110"
}
request_body
grant_type=refresh_token&refresh_token=qRH5WeWpvu6_lPbRKA4a9bPU2VgyRJtveTYwgorIlqs&scope=openid+offline_access
2020-07-31 12:28:38 RESPONSE
CallTokenEndpointAndReturnFullResponse
HTTP response
response_status_code
400 BAD_REQUEST
response_status_text
Bad Request
response_headers
{
  "date": "Fri, 31 Jul 2020 12:28:38 GMT",
  "server": "Jetty(9.4.21-SNAPSHOT)",
  "cache-control": "no-store, no-transform",
  "pragma": "no-cache",
  "content-type": "application/json;charset\u003dutf-8",
  "content-length": "155",
  "connection": "close"
}
response_body
{"error_description":"[A053307] The refresh token does not belong to the client.","error":"invalid_grant","error_uri":"https://docs.authlete.com/#A053307"}
2020-07-31 12:28:38 SUCCESS
CallTokenEndpointAndReturnFullResponse
Parsed token endpoint response
error_description
[A053307] The refresh token does not belong to the client.
error
invalid_grant
error_uri
https://docs.authlete.com/#A053307
2020-07-31 12:28:38 SUCCESS
ValidateErrorFromTokenEndpointResponseError
Token endpoint response error returned valid 'error' field
error
invalid_grant
2020-07-31 12:28:38 SUCCESS
CheckTokenEndpointHttpStatus400
Token endpoint http status code was 400
2020-07-31 12:28:38 SUCCESS
CheckTokenEndpointReturnedJsonContentType
token_endpoint_response_headers Content-Type: header is application/json
2020-07-31 12:28:38 SUCCESS
CheckErrorFromTokenEndpointResponseErrorInvalidGrant
Token Endpoint response error returned expected 'error' of 'invalid_grant'
error
invalid_grant
2020-07-31 12:28:38 FINISHED
oidcc-refresh-token
Test has run to completion
testmodule_result
PASSED
Unregister dynamically registered client
2020-07-31 12:28:38 INFO
UnregisterDynamicallyRegisteredClient
Skipped evaluation due to missing required string: registration_client_uri
expected
registration_client_uri
Second client: Unregister dynamically registered client
2020-07-31 12:28:38 INFO
UnregisterDynamicallyRegisteredClient
Skipped evaluation due to missing required string: registration_client_uri
expected
registration_client_uri
2020-07-31 12:28:38
TEST-RUNNER
Alias has now been claimed by another test
alias
oidf-authlete-core
new_test_id
yBvbfo45ahATLgz
Test Results