[Python 2.7] Hex Long Integers handled incorrectly

  • sonarqube:8.6.0-community (dockerized)
  • sonarsource/sonar-scanner-cli:4.5 (dockerized)
  • not sure about scanner version - no version specified in docker logs

Python code:

Minimal repro:

d = {0xB1E70073L: "1", 0xB1E70073L: "1"}

Stack trace:

java.lang.NumberFormatException: For input string: "E70073L"
        at java.base/java.lang.NumberFormatException.forInputString(Unknown Source)
        at java.base/java.lang.Integer.parseInt(Unknown Source)
        at java.base/java.math.BigInteger.<init>(Unknown Source)
        at org.sonar.python.checks.AbstractDuplicateKeyCheck.parseAsBigDecimal(AbstractDuplicateKeyCheck.java:103)
        at org.sonar.python.checks.AbstractDuplicateKeyCheck.toBigDecimal(AbstractDuplicateKeyCheck.java:75)
        at org.sonar.python.checks.AbstractDuplicateKeyCheck.areEquivalentNumbers(AbstractDuplicateKeyCheck.java:70)
        at org.sonar.python.checks.AbstractDuplicateKeyCheck.isSameKey(AbstractDuplicateKeyCheck.java:49)
        at org.sonar.python.checks.DictionaryDuplicateKeyCheck.findIdenticalKeys(DictionaryDuplicateKeyCheck.java:66)
        at org.sonar.python.checks.DictionaryDuplicateKeyCheck.lambda$initialize$1(DictionaryDuplicateKeyCheck.java:49)
        at org.sonar.python.SubscriptionVisitor$SubscriptionContextImpl.execute(SubscriptionVisitor.java:96)
        at java.base/java.util.ArrayList.forEach(Unknown Source)
        at org.sonar.python.SubscriptionVisitor.scan(SubscriptionVisitor.java:77)
        at org.sonar.python.SubscriptionVisitor.analyze(SubscriptionVisitor.java:57)
        at org.sonar.plugins.python.PythonScanner.scanFile(PythonScanner.java:129)
        at org.sonar.plugins.python.Scanner.execute(Scanner.java:52)
        at org.sonar.plugins.python.PythonSensor.execute(PythonSensor.java:84)
        at org.sonar.scanner.sensor.AbstractSensorWrapper.analyse(AbstractSensorWrapper.java:48)
        at org.sonar.scanner.sensor.ModuleSensorsExecutor.execute(ModuleSensorsExecutor.java:85)
        at org.sonar.scanner.sensor.ModuleSensorsExecutor.lambda$execute$1(ModuleSensorsExecutor.java:59)
        at org.sonar.scanner.sensor.ModuleSensorsExecutor.withModuleStrategy(ModuleSensorsExecutor.java:77)
        at org.sonar.scanner.sensor.ModuleSensorsExecutor.execute(ModuleSensorsExecutor.java:59)
        at org.sonar.scanner.scan.ModuleScanContainer.doAfterStart(ModuleScanContainer.java:82)
        at org.sonar.core.platform.ComponentContainer.startComponents(ComponentContainer.java:137)
        at org.sonar.core.platform.ComponentContainer.execute(ComponentContainer.java:123)
        at org.sonar.scanner.scan.ProjectScanContainer.scan(ProjectScanContainer.java:393)
        at org.sonar.scanner.scan.ProjectScanContainer.scanRecursively(ProjectScanContainer.java:389)
        at org.sonar.scanner.scan.ProjectScanContainer.doAfterStart(ProjectScanContainer.java:358)
        at org.sonar.core.platform.ComponentContainer.startComponents(ComponentContainer.java:137)
        at org.sonar.core.platform.ComponentContainer.execute(ComponentContainer.java:123)
        at org.sonar.scanner.bootstrap.GlobalContainer.doAfterStart(GlobalContainer.java:144)
        at org.sonar.core.platform.ComponentContainer.startComponents(ComponentContainer.java:137)
        at org.sonar.core.platform.ComponentContainer.execute(ComponentContainer.java:123)
        at org.sonar.batch.bootstrapper.Batch.doExecute(Batch.java:72)
        at org.sonar.batch.bootstrapper.Batch.execute(Batch.java:66)
        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 com.sun.proxy.$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:112)
        at org.sonarsource.scanner.cli.Main.execute(Main.java:75)
        at org.sonarsource.scanner.cli.Main.main(Main.java:61)

Hi @rogalski,

Thanks for reporting this bug. I created ticket SONARPY-827 to keep track of it.
We plan to provide a fix for next SonarQube version (8.7).