Embedded JRE 17 is lacking permissions to execute programs

Hi,

We have recently upgraded sonar-scanner cli to the latest release 5.0.0. Before anything, please note that we are downloading the binary to run it into a Jenkins instance. This was working until we recently upgraded to the latest release 5.0.0 that now embeds the JDK 17.

While running the analysis, we get this error:

13:24:26  ERROR: Unable to parse file: ****. 
13:24:26  ERROR: Cannot parse '****': Cannot run program "****/sonar-go-to-slang-linux-amd64": error=13, Permission denied

After some investigation, we found out that the reason was the lack of execute permission for sonar-scanner/jre/lib/jspawnhelper. After adding a chmod +x for this executable in our pipeline, things got resolved and the analysis are running fine again.

I’m not very clear if our setup is too specific and we are the only ones hit by this but that will at least be documented somewhere if needed.

Bests

2 Likes

Hey Gilthoniel

Thank you for raising this issue.

I experienced the same issue when upgrading the scanner to 5.0.0 to use JDK 17.
In our case we are downloading it in an AWS CodeBuild project before running the scanner.

It all worked fine before the upgrade. The problem is for a golang project.

I upgraded the scanner for another node.js project and it ran the scan successfully, however also noted problems with permissions.

ERROR: Error when running: 'node -v'. Is Node.js available during analysis?
org.sonar.plugins.javascript.nodejs.NodeCommandException: Error when running: 'node -v'. Is Node.js available during analysis?
    at org.sonar.plugins.javascript.nodejs.NodeCommand.start(NodeCommand.java:85)
    at org.sonar.plugins.javascript.nodejs.NodeCommandBuilderImpl.getVersion(NodeCommandBuilderImpl.java:217)
    at org.sonar.plugins.javascript.nodejs.NodeCommandBuilderImpl.checkNodeCompatibility(NodeCommandBuilderImpl.java:173)
    at org.sonar.plugins.javascript.nodejs.NodeCommandBuilderImpl.build(NodeCommandBuilderImpl.java:146)
    at org.sonar.plugins.javascript.eslint.EslintBridgeServerImpl.initNodeCommand(EslintBridgeServerImpl.java:254)
    at org.sonar.plugins.javascript.eslint.EslintBridgeServerImpl.startServer(EslintBridgeServerImpl.java:182)
    at org.sonar.plugins.javascript.eslint.EslintBridgeServerImpl.startServerLazily(EslintBridgeServerImpl.java:294)
    at org.sonar.plugins.javascript.eslint.AbstractEslintSensor.execute(AbstractEslintSensor.java:73)
    at org.sonar.scanner.sensor.AbstractSensorWrapper.analyse(AbstractSensorWrapper.java:62)
    at org.sonar.scanner.sensor.ModuleSensorsExecutor.execute(ModuleSensorsExecutor.java:75)
    at org.sonar.scanner.sensor.ModuleSensorsExecutor.lambda$execute$1(ModuleSensorsExecutor.java:48)
    at org.sonar.scanner.sensor.ModuleSensorsExecutor.withModuleStrategy(ModuleSensorsExecutor.java:66)
    at org.sonar.scanner.sensor.ModuleSensorsExecutor.execute(ModuleSensorsExecutor.java:48)
    at org.sonar.scanner.scan.ModuleScanContainer.doAfterStart(ModuleScanContainer.java:64)
    at org.sonar.core.platform.ComponentContainer.startComponents(ComponentContainer.java:123)
    at org.sonar.core.platform.ComponentContainer.execute(ComponentContainer.java:109)
    at org.sonar.scanner.scan.ProjectScanContainer.scan(ProjectScanContainer.java:468)
    at org.sonar.scanner.scan.ProjectScanContainer.scanRecursively(ProjectScanContainer.java:464)
    at org.sonar.scanner.scan.ProjectScanContainer.doAfterStart(ProjectScanContainer.java:420)
    at org.sonar.core.platform.ComponentContainer.startComponents(ComponentContainer.java:123)
    at org.sonar.core.platform.ComponentContainer.execute(ComponentContainer.java:109)
    at org.sonar.scanner.bootstrap.GlobalContainer.doAfterStart(GlobalContainer.java:128)
    at org.sonar.core.platform.ComponentContainer.startComponents(ComponentContainer.java:123)
    at org.sonar.core.platform.ComponentContainer.execute(ComponentContainer.java:109)
    at org.sonar.batch.bootstrapper.Batch.doExecute(Batch.java:57)
    at org.sonar.batch.bootstrapper.Batch.execute(Batch.java:51)
    at org.sonarsource.scanner.api.internal.batch.BatchIsolatedLauncher.execute(BatchIsolatedLauncher.java:46)
    at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
    at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
    at java.base/java.lang.reflect.Method.invoke(Unknown Source)
    at org.sonarsource.scanner.api.internal.IsolatedLauncherProxy.invoke(IsolatedLauncherProxy.java:60)
    at jdk.proxy1/jdk.proxy1.$Proxy0.execute(Unknown Source)
    at org.sonarsource.scanner.api.EmbeddedScanner.doExecute(EmbeddedScanner.java:189)
    at org.sonarsource.scanner.api.EmbeddedScanner.execute(EmbeddedScanner.java:138)
    at org.sonarsource.scanner.cli.Main.execute(Main.java:126)
    at org.sonarsource.scanner.cli.Main.execute(Main.java:81)
    at org.sonarsource.scanner.cli.Main.main(Main.java:62)
Caused by: java.io.IOException: Cannot run program "node": error=13, Permission denied
    at java.base/java.lang.ProcessBuilder.start(Unknown Source)
    at java.base/java.lang.ProcessBuilder.start(Unknown Source)
    at org.sonar.plugins.javascript.nodejs.ProcessWrapperImpl.startProcess(ProcessWrapperImpl.java:43)
    at org.sonar.plugins.javascript.nodejs.NodeCommand.start(NodeCommand.java:82)
    ... 37 common frames omitted
Caused by: java.io.IOException: error=13, Permission denied
    at java.base/java.lang.ProcessImpl.forkAndExec(Native Method)
    at java.base/java.lang.ProcessImpl.<init>(Unknown Source)
    at java.base/java.lang.ProcessImpl.start(Unknown Source)
    ... 41 common frames omitted

Hopefully this can be resolved without needing to change executable permissions.

1 Like

The same happens to us after upgrading Sonar Scanner from 4.7.0.2747 to 5.0.0.2966 in a Bitbucket Pipelines environment. After seeing this warning message on the scanner report, we decided to update the scanner version.

Warning

  • The version of Java (11.0.14.1) you have used to run this analysis is deprecated and we will stop accepting it soon. Please update to at least Java 17. Read more

However, the new version 5.0.0 fails:

ERROR: Error during SonarScanner execution
java.lang.IllegalStateException: java.io.IOException: Cannot run program "/opt/atlassian/pipelines/agent/build/.scannerwork/.sonartmp/7494877700764160272/subprocess" (in directory "/opt/atlassian/pipelines/agent/build/Src/QLPRLib/build"): error=13, Permission denied
	at com.sonar.cpp.driver.ProcessExecutor.execute(ProcessExecutor.java:73)
1 Like

I seem to be running into the same issue using a Github Action:

ERROR: Error during SonarScanner execution
java.lang.IllegalStateException: java.io.IOException: Cannot run program "/home/runner/work/JoltPhysics/JoltPhysics/.scannerwork/.sonartmp/10092508975637522239/subprocess" (in directory "/home/runner/work/JoltPhysics/JoltPhysics/Build/Linux_ReleaseCoverage"): error=13, Permission denied
INFO: ------------------------------------------------------------------------
	at com.sonar.cpp.driver.ProcessExecutor.execute(ProcessExecutor.java:73)
	at com.sonar.cpp.driver.ProcessExecutor.execute(ProcessExecutor.java:44)
	at com.sonar.cpp.analyzer.ClangDriver.runCompiler(ClangDriver.java:874)
	at com.sonar.cpp.analyzer.ClangDriver.lambda$probeCompiler$12(ClangDriver.java:944)
	at java.base/java.util.HashMap.computeIfAbsent(Unknown Source)
	at com.sonar.cpp.analyzer.ClangDriver.probeCompiler(ClangDriver.java:944)
	at com.sonar.cpp.analyzer.ClangDriver.onCapture(ClangDriver.java:601)
	at com.sonar.cpp.analyzer.CompilerDrivers.onCapture(CompilerDrivers.java:36)

Yesterday it started warning that I should switch to JRE 17 and today it started failing without any configuration changes. I tried upgrading to SonarSource/sonarcloud-github-c-cpp@v2 but that doesn’t make a difference.

Github workflow is located here. I think it is pretty much a copy of what is suggested for the action.

1 Like

Hi all,

Thanks for your reports.

Which OSes are you experiencing this on?

 
Thx,
Ann

Hey everyone.

We’ll take a decision by the end of today about whether or not to rollback the GitHub Action (to use the old version of the scanner), or to roll-forward, perhaps with the suggested change in this PR.

You can also, of course, revert to the previous version of the Scanner / GitHub action and put up with the warning about Java 17 in your analysis.

Thank you for the reports. It is still helpful if you can tell us what OS you are experiencing this on.

1 Like

Thank you for the feedback.

We’re running on CentOS Stream 8 on our side.

1 Like

Thanks for looking into this!

I’m running on Ubuntu 22.04.

1 Like

Hi all,

Thanks for your patience. We’re planning to put out a patch release of the scanner today. We’ll update here once it’s released.

 
Thx,
Ann

1 Like

Hi again,

The final step of the release is running now. This should be available in the next few minutes.

 
Ann

1 Like

Hi,

I’m still getting this error on 5.0.1.3006-linux:

UPDATE: I also forgot to set execute permission on jspawnhelper - unfortunately it can be a common problem when using Sonar Scanner from Ant, because Ant unzip task does not preserve permissions. Therefore, when unzipped, no files in Sonar Scanner are executable.

[exec] ERROR: Error when running: 'node -v'. Is Node.js available during analysis?
     [exec] org.sonar.plugins.javascript.nodejs.NodeCommandException: Error when running: 'node -v'. Is Node.js available during analysis?
     [exec] 	at org.sonar.plugins.javascript.nodejs.NodeCommand.start(NodeCommand.java:85)
     [exec] 	at org.sonar.plugins.javascript.nodejs.NodeCommandBuilderImpl.getVersion(NodeCommandBuilderImpl.java:217)
     [exec] 	at org.sonar.plugins.javascript.nodejs.NodeCommandBuilderImpl.checkNodeCompatibility(NodeCommandBuilderImpl.java:173)
     [exec] 	at org.sonar.plugins.javascript.nodejs.NodeCommandBuilderImpl.build(NodeCommandBuilderImpl.java:146)
     [exec] 	at org.sonar.plugins.javascript.eslint.EslintBridgeServerImpl.initNodeCommand(EslintBridgeServerImpl.java:252)
     [exec] 	at org.sonar.plugins.javascript.eslint.EslintBridgeServerImpl.startServer(EslintBridgeServerImpl.java:180)
     [exec] 	at org.sonar.plugins.javascript.eslint.EslintBridgeServerImpl.startServerLazily(EslintBridgeServerImpl.java:292)
     [exec] 	at org.sonar.plugins.javascript.eslint.AbstractEslintSensor.execute(AbstractEslintSensor.java:74)
     [exec] 	at org.sonar.scanner.sensor.AbstractSensorWrapper.analyse(AbstractSensorWrapper.java:64)
     [exec] 	at org.sonar.scanner.sensor.ModuleSensorsExecutor.execute(ModuleSensorsExecutor.java:88)
     [exec] 	at org.sonar.scanner.sensor.ModuleSensorsExecutor.lambda$execute$1(ModuleSensorsExecutor.java:61)
     [exec] 	at org.sonar.scanner.sensor.ModuleSensorsExecutor.withModuleStrategy(ModuleSensorsExecutor.java:79)
     [exec] 	at org.sonar.scanner.sensor.ModuleSensorsExecutor.execute(ModuleSensorsExecutor.java:61)
     [exec] 	at org.sonar.scanner.scan.SpringModuleScanContainer.doAfterStart(SpringModuleScanContainer.java:82)
     [exec] 	at org.sonar.core.platform.SpringComponentContainer.startComponents(SpringComponentContainer.java:188)
     [exec] 	at org.sonar.core.platform.SpringComponentContainer.execute(SpringComponentContainer.java:167)
     [exec] 	at org.sonar.scanner.scan.SpringProjectScanContainer.scan(SpringProjectScanContainer.java:403)
     [exec] 	at org.sonar.scanner.scan.SpringProjectScanContainer.scanRecursively(SpringProjectScanContainer.java:399)
     [exec] 	at org.sonar.scanner.scan.SpringProjectScanContainer.doAfterStart(SpringProjectScanContainer.java:368)
     [exec] 	at org.sonar.core.platform.SpringComponentContainer.startComponents(SpringComponentContainer.java:188)
     [exec] 	at org.sonar.core.platform.SpringComponentContainer.execute(SpringComponentContainer.java:167)
     [exec] 	at org.sonar.scanner.bootstrap.SpringGlobalContainer.doAfterStart(SpringGlobalContainer.java:137)
     [exec] 	at org.sonar.core.platform.SpringComponentContainer.startComponents(SpringComponentContainer.java:188)
     [exec] 	at org.sonar.core.platform.SpringComponentContainer.execute(SpringComponentContainer.java:167)
     [exec] 	at org.sonar.batch.bootstrapper.Batch.doExecute(Batch.java:71)
     [exec] 	at org.sonar.batch.bootstrapper.Batch.execute(Batch.java:65)
     [exec] 	at org.sonarsource.scanner.api.internal.batch.BatchIsolatedLauncher.execute(BatchIsolatedLauncher.java:46)
     [exec] 	at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
     [exec] 	at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
     [exec] 	at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
     [exec] 	at java.base/java.lang.reflect.Method.invoke(Unknown Source)
     [exec] 	at org.sonarsource.scanner.api.internal.IsolatedLauncherProxy.invoke(IsolatedLauncherProxy.java:60)
     [exec] 	at jdk.proxy1/jdk.proxy1.$Proxy0.execute(Unknown Source)
     [exec] 	at org.sonarsource.scanner.api.EmbeddedScanner.doExecute(EmbeddedScanner.java:189)
     [exec] 	at org.sonarsource.scanner.api.EmbeddedScanner.execute(EmbeddedScanner.java:138)
     [exec] 	at org.sonarsource.scanner.cli.Main.execute(Main.java:126)
     [exec] 	at org.sonarsource.scanner.cli.Main.execute(Main.java:81)
     [exec] 	at org.sonarsource.scanner.cli.Main.main(Main.java:62)
     [exec] Caused by: java.io.IOException: Cannot run program "node": error=13, Permission denied
     [exec] 	at java.base/java.lang.ProcessBuilder.start(Unknown Source)
     [exec] 	at java.base/java.lang.ProcessBuilder.start(Unknown Source)
     [exec] 	at org.sonar.plugins.javascript.nodejs.ProcessWrapperImpl.startProcess(ProcessWrapperImpl.java:43)
     [exec] 	at org.sonar.plugins.javascript.nodejs.NodeCommand.start(NodeCommand.java:82)
     [exec] 	... 37 common frames omitted
     [exec] Caused by: java.io.IOException: error=13, Permission denied
     [exec] 	at java.base/java.lang.ProcessImpl.forkAndExec(Native Method)
     [exec] 	at java.base/java.lang.ProcessImpl.<init>(Unknown Source)
     [exec] 	at java.base/java.lang.ProcessImpl.start(Unknown Source)
     [exec] 	... 41 common frames omitted

$ which node
/snap/bin/node
$ node -v
v16.20.1

Hi @BaboonOnTree,

Thanks for the update.

FYI, we’ll be deprecating the SonarScanner for Ant soon. Your best bet is to switch to an exec of the SonarScanner CLI.

 
Ann

@ganncamp you got me wrong - I didn’t use SonarScanner for Ant. I used a standalone version by fetching, unzipping and executing it from the Ant script. The problem is that when you unzip in the Ant script, as you would usually do for standalone SonarScanner, the Ant "unzip` task does not preserve file permissions and no extracted file can be executed. I think you should maybe document that somewhere because whoever using Ant migrates to standalone SonarScanner might get frustrated by such problems.

1 Like

Hi,

I would expect the scanner to just be installed on the build agent rather than downloaded each time…

 
Ann

Hello Ann,
+1 on this same problem with the exact same sonar scanner 5.0.1.3006. So I integrated sonar scanner with Jenkins by manually downloading the zip file and unzipping into the Jenkins folder on my Ubuntu. Initially I faced problem with my JAVA and so I gave 775 permissions but cannot fix the node problem, strangely though sh ‘node -v’ works perfectly fine in earlier step within the Jenkins pipeline, but why does it fail later??

Hi @Ashwin_S_Rao,

Since 5.0.1 should have fixed the permissions problem, I suspect you have something different going on. Can you start a new thread with all your details, please?

It would be good to include your full Jenkins job log, redacted as necessary.

 
Ann

Sure Ann I have created this new issue SONAR Scanner 5.0.1.3006 failing with node permission issue - SonarQube - Sonar Community (sonarsource.com)