Scanner version 5.16.0 fails with error 400 for API GET '/api/server/version'

Hi,
after the update of Sonarqube Extension for Azure DevOps today to version 5.16.0 our pipelines fail with the error

##[error][SQ] API GET '/api/server/version' failed, error is Request failed with status code 400

Before the update everything worked for us.
I checked the changes that are included in the update and found this commit: Fix mend vulnerabilities (#291) · SonarSource/sonar-scanner-vsts@4755301 · GitHub

Opening the URL https://our-sonarqube-base-url/api/server/version in a web browser gives the current version without any error.
We are using SonarQube Enterprise edition in version 10.1.0.73491.

Thanks for any help!
Andreas

1 Like

Hey there.

Thanks for the quick feedback. I’ve flagged this for attention.

1 Like

Hello Andreas,

We are investigating your issue and trying to understand why your pipeline started failing. It is related to the last release, but we think there may be something specific to your setup that is, somehow, not working well with this update.
We would need more information to investigate. Could you please tell me if you are using SonarQube behind a reverse proxy?
Also, we would need the full execution log for a failing CI run, including debug logs (You have to check “Enable system diagnostics”)

Thanks

Hi,

Adding my voice to this issue. With the latest update to 5.16.0 that automatically happened 3 hours ago, all our build pipelines started failing with “##[error][SQ] API GET ‘/api/server/version’ failed, error is Request failed with status code 500”

This is with SonarQube 9.9.1 Community Edition behind a reverse proxy.

I’ll follow up with detailed logs.

Edit: Detailed logs as follows:

##[debug]Evaluating: succeeded()
##[debug]Evaluating succeeded:
##[debug]=> True
##[debug]Result: True
Starting: Prepare analysis on SonarQube
==============================================================================
Task         : Prepare Analysis Configuration
Description  : Prepare SonarQube analysis configuration
Version      : 5.16.0
Author       : sonarsource
Help         : Version: 5.16.0. [More Information](http://redirect.sonarsource.com/doc/install-configure-scanner-tfs-ts.html)
==============================================================================
##[debug]Using node path: ***\Agent-01\externals\node10\bin\node.exe
##[debug]agent.TempDirectory=***\Agent-01\build\_temp
##[debug]loading inputs and endpoints
##[debug]loading ENDPOINT_AUTH_***
##[debug]loading ENDPOINT_AUTH_PARAMETER_***_USERNAME
##[debug]loading ENDPOINT_AUTH_PARAMETER_SYSTEMVSSCONNECTION_ACCESSTOKEN
##[debug]loading ENDPOINT_AUTH_SCHEME_***
##[debug]loading ENDPOINT_AUTH_SCHEME_SYSTEMVSSCONNECTION
##[debug]loading ENDPOINT_AUTH_SYSTEMVSSCONNECTION
##[debug]loading INPUT_CLIPROJECTVERSION
##[debug]loading INPUT_CLISOURCES
##[debug]loading INPUT_CONFIGFILE
##[debug]loading INPUT_CONFIGMODE
##[debug]loading INPUT_EXTRAPROPERTIES
##[debug]loading INPUT_PROJECTKEY
##[debug]loading INPUT_PROJECTNAME
##[debug]loading INPUT_PROJECTVERSION
##[debug]loading INPUT_SCANNERMODE
##[debug]loading INPUT_SONARQUBE
##[debug]loaded 16
##[debug]Agent.ProxyUrl=***
##[debug]Agent.ProxyUsername=undefined
##[debug]Agent.ProxyPassword=undefined
##[debug]Agent.ProxyBypassList=["localhost","***"]
##[debug]expose agent proxy configuration.
##[debug]Agent.CAInfo=undefined
##[debug]Agent.ClientCert=undefined
##[debug]Agent.SkipCertValidation=undefined
##[debug]SonarQube=***
##[debug]***=https://sonarqube.***/sonar/
##[debug]*** auth param apitoken = undefined
##[debug]*** auth param username = ***
##[debug]*** auth param password = undefined
##[debug]organization=undefined
##[debug]scannerMode=MSBuild
##[debug]projectKey=project
##[debug]projectName=project
##[debug]projectVersion=2.0
##[debug]organization=undefined
##[debug][SQ] API GET: '/api/server/version' with query "undefined"
##[debug][SQ] API GET '/api/server/version' failed, status code was: 500
##[debug]task result: Failed
##[error][SQ] API GET '/api/server/version' failed, error is Request failed with status code 500
##[debug]Processed: ##vso[task.issue type=error;][SQ] API GET '/api/server/version' failed, error is Request failed with status code 500
##[debug]Processed: ##vso[task.complete result=Failed;][SQ] API GET '/api/server/version' failed, error is Request failed with status code 500
Finishing: Prepare analysis on SonarQube```

GET requests via the browser to /api/server/version result in the current version number as a response:
9.9.1.69595

Hi,
I was now able to take a closer look at the problem.
Our SonarQube is behind a reverse proxy.
The problem only occurs with on-premise build agents that are behind a proxy (without authentication). It works for agents hosted in Azure which don’t use a proxy.

According to the logs, Chris’s setup looks the same.

Here are detailed logs for a failed CI run:

2023-10-18T07:15:45.0208700Z ##[debug]Evaluating condition for step: 'Prepare analysis on SonarQube'
2023-10-18T07:15:45.0209760Z ##[debug]Evaluating: and(succeeded(), eq(variables['RUNSONARQUBE'], 'true'))
2023-10-18T07:15:45.0210051Z ##[debug]Evaluating and:
2023-10-18T07:15:45.0210277Z ##[debug]..Evaluating succeeded:
2023-10-18T07:15:45.0210762Z ##[debug]..=> True
2023-10-18T07:15:45.0211010Z ##[debug]..Evaluating eq:
2023-10-18T07:15:45.0211265Z ##[debug]....Evaluating indexer:
2023-10-18T07:15:45.0211502Z ##[debug]......Evaluating variables:
2023-10-18T07:15:45.0211947Z ##[debug]......=> Object
2023-10-18T07:15:45.0212180Z ##[debug]......Evaluating String:
2023-10-18T07:15:45.0212466Z ##[debug]......=> 'RUNSONARQUBE'
2023-10-18T07:15:45.0213004Z ##[debug]....=> 'true'
2023-10-18T07:15:45.0213265Z ##[debug]....Evaluating String:
2023-10-18T07:15:45.0213492Z ##[debug]....=> 'true'
2023-10-18T07:15:45.0213677Z ##[debug]..=> True
2023-10-18T07:15:45.0213865Z ##[debug]=> True
2023-10-18T07:15:45.0214259Z ##[debug]Expanded: and(True, eq('true', 'true'))
2023-10-18T07:15:45.0214575Z ##[debug]Result: True
2023-10-18T07:15:45.0214873Z ##[section]Starting: Prepare analysis on SonarQube
2023-10-18T07:15:45.0219281Z ==============================================================================
2023-10-18T07:15:45.0219413Z Task : Prepare Analysis Configuration
2023-10-18T07:15:45.0219691Z Description : Prepare SonarQube analysis configuration
2023-10-18T07:15:45.0219790Z Version : 5.16.0
2023-10-18T07:15:45.0219871Z Author : sonarsource
2023-10-18T07:15:45.0219980Z Help : Version: 5.16.0. [More Information](http://redirect.sonarsource.com/doc/install-configure-scanner-tfs-ts.html)
2023-10-18T07:15:45.0220134Z ==============================================================================
2023-10-18T07:15:45.0584260Z ##[debug]Using node path: /vsts/agent/externals/node10/bin/node
2023-10-18T07:15:45.4550210Z ##[debug]agent.TempDirectory=/vsts/agent/***/_temp
2023-10-18T07:15:45.4571898Z ##[debug]loading inputs and endpoints
2023-10-18T07:15:45.4578829Z ##[debug]loading INPUT_SONARQUBE
2023-10-18T07:15:45.4604534Z ##[debug]loading INPUT_SCANNERMODE
2023-10-18T07:15:45.4605554Z ##[debug]loading INPUT_CONFIGMODE
2023-10-18T07:15:45.4606662Z ##[debug]loading INPUT_CONFIGFILE
2023-10-18T07:15:45.4607690Z ##[debug]loading INPUT_CLIPROJECTKEY
2023-10-18T07:15:45.4608630Z ##[debug]loading INPUT_CLIPROJECTNAME
2023-10-18T07:15:45.4609485Z ##[debug]loading INPUT_CLIPROJECTVERSION
2023-10-18T07:15:45.4610349Z ##[debug]loading INPUT_PROJECTVERSION
2023-10-18T07:15:45.4611210Z ##[debug]loading INPUT_CLISOURCES
2023-10-18T07:15:45.4612732Z ##[debug]loading INPUT_EXTRAPROPERTIES
2023-10-18T07:15:45.4613183Z ##[debug]loading ENDPOINT_AUTH_***
2023-10-18T07:15:45.4614341Z ##[debug]loading ENDPOINT_AUTH_SCHEME_***
2023-10-18T07:15:45.4615012Z ##[debug]loading ENDPOINT_AUTH_PARAMETER_***_USERNAME
2023-10-18T07:15:45.4615742Z ##[debug]loading ENDPOINT_AUTH_SYSTEMVSSCONNECTION
2023-10-18T07:15:45.4618468Z ##[debug]loading ENDPOINT_AUTH_SCHEME_SYSTEMVSSCONNECTION
2023-10-18T07:15:45.4627469Z ##[debug]loading ENDPOINT_AUTH_PARAMETER_SYSTEMVSSCONNECTION_ACCESSTOKEN
2023-10-18T07:15:45.4628233Z ##[debug]loading SECRET_BLACKDUCKPW
2023-10-18T07:15:45.4628636Z ##[debug]loading SECRET_FOSSIDAPIKEY
2023-10-18T07:15:45.4629077Z ##[debug]loading SECRET_WHITESOURCEUSERKEY
2023-10-18T07:15:45.4629496Z ##[debug]loading SECRET_ARTIFACTORYSERVERAPIKEY
2023-10-18T07:15:45.4629901Z ##[debug]loading SECRET_ARTIFACTORYPASSWORD
2023-10-18T07:15:45.4630286Z ##[debug]loading SECRET_SOURCECHECKUSER
2023-10-18T07:15:45.4630672Z ##[debug]loading SECRET_IQSERVERPASS
2023-10-18T07:15:45.4631055Z ##[debug]loading SECRET_ARTIFACTORYUSER
2023-10-18T07:15:45.4631443Z ##[debug]loading SECRET_SOURCECHECKPASS
2023-10-18T07:15:45.4631822Z ##[debug]loaded 25
2023-10-18T07:15:45.4635108Z ##[debug]Agent.ProxyUrl=http://***.com:8080
2023-10-18T07:15:45.4635557Z ##[debug]Agent.ProxyUsername=undefined
2023-10-18T07:15:45.4636263Z ##[debug]Agent.ProxyPassword=undefined
2023-10-18T07:15:45.4636856Z ##[debug]Agent.ProxyBypassList=["localhost",***]
2023-10-18T07:15:45.4637369Z ##[debug]expose agent proxy configuration.
2023-10-18T07:15:45.4637764Z ##[debug]Agent.CAInfo=undefined
2023-10-18T07:15:45.4638147Z ##[debug]Agent.ClientCert=undefined
2023-10-18T07:15:45.4638663Z ##[debug]Agent.SkipCertValidation=undefined
2023-10-18T07:15:46.5829835Z ##[debug]SonarQube=***
2023-10-18T07:15:46.5830441Z ##[debug]***=https://***.com/sonarqube
2023-10-18T07:15:46.5832871Z ##[debug]*** auth param apitoken = undefined
2023-10-18T07:15:46.5834516Z ##[debug]*** auth param username = ***
2023-10-18T07:15:46.5835674Z ##[debug]*** auth param password = undefined
2023-10-18T07:15:46.5836617Z ##[debug]organization=undefined
2023-10-18T07:15:46.5837055Z ##[debug]scannerMode=CLI
2023-10-18T07:15:46.5837455Z ##[debug]configMode=manual
2023-10-18T07:15:46.5837869Z ##[debug]cliProjectKey=***
2023-10-18T07:15:46.5838273Z ##[debug]cliProjectName=***
2023-10-18T07:15:46.5839029Z ##[debug]cliProjectVersion=***
2023-10-18T07:15:46.5839467Z ##[debug]cliSources=/vsts/agent/***/515/s/src/***
2023-10-18T07:15:46.5839915Z ##[debug][SQ] API GET: '/api/server/version' with query "undefined"
2023-10-18T07:15:46.5989652Z ##[debug][SQ] API GET '/api/server/version' failed, status code was: 400
2023-10-18T07:15:46.5990204Z ##[debug]task result: Failed
2023-10-18T07:15:46.6018603Z ##[error][SQ] API GET '/api/server/version' failed, error is Request failed with status code 400
2023-10-18T07:15:46.6025747Z ##[debug]Processed: ##vso[task.issue type=error;][SQ] API GET '/api/server/version' failed, error is Request failed with status code 400
2023-10-18T07:15:46.6027286Z ##[debug]Processed: ##vso[task.complete result=Failed;][SQ] API GET '/api/server/version' failed, error is Request failed with status code 400
2023-10-18T07:15:46.6067891Z ##[section]Finishing: Prepare analysis on SonarQube

@cba @andreasfischer we’ve released a patch version of SQ extension 5.17.1 which we hope resolves the issue. Could you let us know if the change works well on your side?

Thanks for your support. For us it is still failing with the same error. But now we have more log output about the reason.
I add here the relevant part of the log:

2023-10-18T11:02:19.0539048Z ##[debug][SQ] API GET: '/api/server/version' with query "undefined"
2023-10-18T11:02:19.1620008Z ##[debug][SQ] API GET '/api/server/version' failed, status code was: 400
2023-10-18T11:02:19.1629577Z ##[debug]API GET error response data: "<HTML>***</HTML>\r\n\t"
2023-10-18T11:02:19.1636288Z ##[debug]API GET error object: {"message":"Request failed with status code 400","name":"AxiosError","config":{"transitional":{"silentJSONParsing":true,"forcedJSONParsing":true,"clarifyTimeoutError":false},"transformRequest":[null],"transformResponse":[null],"timeout":60000,"xsrfCookieName":"XSRF-TOKEN","xsrfHeaderName":"X-XSRF-TOKEN","maxContentLength":-1,"maxBodyLength":-1,"env":{},"headers":{"Accept":"application/json, text/plain, */*","host":"***.com"},"url":"/api/server/version","method":"get","baseURL":"https://***.com/sonarqube","auth":{"username":***}},"code":"ERR_BAD_REQUEST","status":400}
2023-10-18T11:02:19.1637484Z ##[debug]task result: Failed
2023-10-18T11:02:19.1677587Z ##[error][SQ] API GET '/api/server/version' failed, error is Request failed with status code 400
2023-10-18T11:02:19.1685997Z ##[debug]Processed: ##vso[task.issue type=error;][SQ] API GET '/api/server/version' failed, error is Request failed with status code 400
2023-10-18T11:02:19.1687360Z ##[debug]Processed: ##vso[task.complete result=Failed;][SQ] API GET '/api/server/version' failed, error is Request failed with status code 400

From the error response data I extracted the following message:

Request Error
This could be caused by a misconfiguration, or possibly a malformed request. 
Sorry, your request could not be processed. Request could not be handled

This message is from the corporate proxy. So it looks like the request does not reach SonarQube.

@andreasfischer We reverted the change which was breaking your pipelines. Can you let me know if the issue is not present?

1 Like

Our plugin just auto-updated to 15.7.2, which resolves the issue. Thanks!

1 Like

The issue is now solved with 15.7.2. Thanks for your support!

I raised a ticket at our IT support to check why the request couldn’t pass the corporate proxy. In case I get some insights why this happened I will add the information here.

2 Likes

This topic was automatically closed 7 days after the last reply. New replies are no longer allowed.