Sonarlint hang with 100% cpu usage for some files

Please provide

  • Operating system: CentOS Linux release 8.2.2004 (Core)
  • SonarLint plugin version: v3.11.0
  • Programming language you’re coding in: PHP
  • Is connected mode used: No
    • Connected to SonarCloud or SonarQube (and which version):

And a thorough description of the problem / question:

It works for some files (which are about 200 lines), but for some particular files(1548 lines), it hangs forever(and cpu usage of the process is 100%).

Regular logs:

[Info  - 17:00:04.164] Analyzing file 'some file path1'...
[Info  - 17:00:05.113] Found 17 issues
[Info  - 17:00:09.529] Analyzing file 'some file path2'...
[Info  - 17:00:11.061] Found 7 issues

Hang logs:

[Info  - 17:24:08.212] Analyzing file 'some file path3'...

Edit:

Put that file into an empty folder and open it in another VSCode window causes the same problem.

Hello, welcome to the community! And thanks for reporting this.

I suspect that there is a construct in this file that is not well supported by our PHP analyzer. Would it be possible for you to privately share (e.g by private message on this forum) the offending file?

Could you also please share the value of the sonarlint.rules property in your user settings? This could help us check whether a particular rule has a performance hotspot.

Thanks!

Sorry I cannot share that file. I’m using the default rules by the way.

After some investigation(trying to remove/modify line by line), I found it’s able to avoid this problem by removing long text which may also cause the linter to produce “0 issues”. Here is an example:

<?php
$a =+ 1;
//AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAa111111f

Thanks a lot for the reproducer!

Would it be possible for you to:

  • Set sonarlint.output.showVerboseLogs and sonarlint.output.showAnalyzerLogs to true in your user settings
  • Open the SonarLint Output (“Command Palette” > “SonarLint: Show SonarLint Output”)
  • Clear the output using (“Command Palette” > “View: Clear Output”)
  • Open the offending file
  • Copy and paste here the content of the SonarLint output (enclosed in tripled backticks like this ```)

I did not manage to reproduce the issue with the reproducer you shared, however with a longer line I got the following:

Analysis of file with very long line
[Debug - 12:57:55.128] Queuing analysis of file 'file:///home/jean-baptistelievremont/Dev/community/repro-dong/freeze.php' (version 5)
[Info  - 12:57:55.128] Analyzing file 'file:///home/jean-baptistelievremont/Dev/community/repro-dong/freeze.php'...
[Debug - 12:57:55.128] Analysis triggered with configuration:
[
  baseDir: /home/jean-baptistelievremont/Dev/community/repro-dong
  extraProperties: {sonar.cfamily.compile-commands=}
  moduleKey: file:///home/jean-baptistelievremont/Dev/community/repro-dong
  excludedRules: []
  includedRules: [javascript:S122]
  ruleParameters: {}
  inputFiles: [
    file:///home/jean-baptistelievremont/Dev/community/repro-dong/freeze.php (UTF-8) [php]
  ]
]

[Debug - 12:57:55.135] Start analysis
[Info  - 12:57:55.137] Index files
[Debug - 12:57:55.137] Language of file 'file:///home/jean-baptistelievremont/Dev/community/repro-dong/freeze.php' is set to 'PHP'
[Debug - 12:57:55.137] File [file:///home/jean-baptistelievremont/Dev/community/repro-dong/freeze.php] is excluded because it is considered generated (average line length is too big).
[Debug - 12:57:55.137] '[uri=file:///home/jean-baptistelievremont/Dev/community/repro-dong/freeze.php]' excluded by org.sonar.plugins.php.PhpExclusionsFileFilter
[Info  - 12:57:55.137] 0 files indexed
[Debug - 12:57:55.150] 'JavaSensor' skipped because there is no related files in the current project
[Debug - 12:57:55.150] 'CFamily' skipped because there is no related files in the current project
[Debug - 12:57:55.150] 'HTML' skipped because there is no related files in the current project
[Debug - 12:57:55.150] Execute Sensor: Sonar Secrets Detection Sensor
[Debug - 12:57:55.150] 'XML Sensor' skipped because there is no related files in the current project
[Debug - 12:57:55.150] 'PHP sensor' skipped because there is no related files in the current project
[Debug - 12:57:55.150] 'Analyzer for "php.ini" files' skipped because there is no related files in the current project
[Debug - 12:57:55.151] 'Python Sensor' skipped because there is no related files in the current project
[Debug - 12:57:55.151] 'JavaScript analysis' skipped because there is no related files in the current project
[Debug - 12:57:55.151] 'TypeScript analysis' skipped because there is no related files in the current project
[Debug - 12:57:55.151] 'JavaScript inside YAML analysis' skipped because there is no related files in the current project
[Info  - 12:57:55.156] Found 0 issues

In the log above, there is one line that tickles my curiosity:

[Debug - 12:57:55.137] File [file:///home/jean-baptistelievremont/Dev/community/repro-dong/freeze.php] is excluded because it is considered generated (average line length is too big).

This could explain why you get 0 issues (although it does not explain the 100% CPU usage).

Here is the output:

[Debug - 09:47:19.767] Queuing analysis of file 'file:///home/root/projects/test/sonarqube/test.php' (version 1)
The 'file:///home/root/projects/test/sonarqube/test.php' file is not in a git repo, consider as not ignored
[Debug - 09:47:19.839] Cached SCM ignore status for file 'file:///home/root/projects/test/sonarqube/test.php': Not ignored
[Info  - 09:47:19.840] Analyzing file 'file:///home/root/projects/test/sonarqube/test.php'...
[Debug - 09:47:19.840] Analysis triggered with configuration:
[
  baseDir: /home/root/projects/test/sonarqube
  extraProperties: {sonar.cfamily.compile-commands=}
  moduleKey: file:///home/root/projects/test/sonarqube
  excludedRules: []
  includedRules: []
  ruleParameters: {}
  inputFiles: [
    file:///home/root/projects/test/sonarqube/test.php (UTF-8) [php]
  ]
]

[Debug - 09:47:19.894] Start analysis
[Info  - 09:47:19.907] Index files
[Debug - 09:47:19.908] Language of file 'file:///home/root/projects/test/sonarqube/test.php' is set to 'PHP'
[Info  - 09:47:20.458] 1 file indexed
[Debug - 09:47:20.512] 'JavaSensor' skipped because there is no related files in the current project
[Debug - 09:47:20.512] 'Python Sensor' skipped because there is no related files in the current project
[Debug - 09:47:20.512] Execute Sensor: HTML
[Debug - 09:47:20.649] 'XML Sensor' skipped because there is no related files in the current project
[Debug - 09:47:20.649] Execute Sensor: PHP sensor
[Info  - 09:47:20.677] Starting PHP symbol indexer
[Info  - 09:47:20.680] 1 source file to be analyzed
[Info  - 09:47:22.100] 1/1 source file has been analyzed
[Warn  - 09:47:22.102] No workDir in SonarLint
[Info  - 09:47:22.127] Starting PHP rules
[Info  - 09:47:22.128] 1 source file to be analyzed
[Info  - 09:47:32.129] 0/1 files analyzed, current file: [uri=file:///home/root/projects/test/sonarqube/test.php]
[Info  - 09:47:42.129] 0/1 files analyzed, current file: [uri=file:///home/root/projects/test/sonarqube/test.php]
[Info  - 09:47:52.130] 0/1 files analyzed, current file: [uri=file:///home/root/projects/test/sonarqube/test.php]
[Info  - 09:48:02.131] 0/1 files analyzed, current file: [uri=file:///home/root/projects/test/sonarqube/test.php]